The most intuitive memory model for shared-memory multi-threaded programming is
sequential consistency
(SC), but it disallows the use of many compiler and hardware optimizations and thus affects performance. Data-race-free (DRF) models, such as the C++11 memory model, guarantee SC execution for data-race-free programs. But these models provide no guarantee at all for racy programs, compromising the safety and debuggability of such programs. To address the safety issue, the Java memory model, which is also based on the DRF model, provides a weak semantics for racy executions. However, this semantics is subtle and complex, making it difficult for programmers to reason about their programs and for compiler writers to ensure the correctness of compiler optimizations.
We present the
drf
x
memory model, which is simple for programmers to understand and use while still supporting many common optimizations. We introduce a
memory model (MM) exception
that can be signaled to halt execution. If a program executes without throwing this exception, then
drf
x
guarantees that the execution is SC. If a program throws an MM exception during an execution, then
drf
x
guarantees that the program has a data race. We observe that SC violations can be detected in hardware through a lightweight form of conflict detection. Furthermore, our model safely allows aggressive compiler and hardware optimizations within compiler-designated program regions. We formalize our memory model, prove several properties of this model, describe a compiler and hardware design suitable for
drf
x
, and evaluate the performance overhead due to our compiler and hardware requirements.