Abstract
Programs written in C/C++ often include inline assembly: a snippet of architecture-specific assembly code used to access low-level functionalities that are impossible or expensive to simulate in the source language. Although inline assembly is widely used, its semantics has not yet been formally studied. In this paper, we overcome this deficiency by investigating the effect of inline assembly on the consistency semantics of C/C++ programs. We propose the first memory model of the C++ Programming Language with support for inline assembly for Intel's x86 including non-temporal stores and store fences. We argue that previous provably correct compiler optimizations and correct compiler mappings should remain correct under such an extended model and we prove that this requirement is met by our proposed model.
Original language | English |
---|---|
Article number | 309 |
Journal | Proceedings of the ACM on Programming Languages |
Volume | 8 |
Issue number | OOPSLA2 |
DOIs | |
State | Published - 8 Oct 2024 |
Keywords
- Concurrency
- Semantics of Programming Languages
- Weak Memory Models
All Science Journal Classification (ASJC) codes
- Software
- Safety, Risk, Reliability and Quality