Static Memory Consistency Constraints Checking

Static Memory Consistency Constraints Checking
Article's languageEnglish
Abstract

Memory model describes the memory consistency requirements in a multithreading system. Compiler optimizations may violate the consistency requirements due to bugs, and the program behavior will differ from the required one. The bugs in compiler optimizations, like incorrect instruction reordering, are very difficult to detect, because they may occur with a very low chance in real execution on a hardware. There are different approaches of formal verification for memory consistency requirements, but the challenge is that the approaches are not scalable for industrial software. In the paper we present the MCC tool that was evaluated on the industrial virtual machine ARK VM and was able to find a real bug in a compiler optimization. The MCC is a static tool, which allows to check all possible executions of a particular test, not relying on a hardware execution. The approach also includes test suite generation and specification of memory consistency properties.

DOI10.31144/si.2307-6410.2023.n22.p1-10
UDK004
Issue # 22,
Pages1-10
File andrianovmutilin2023.pdf (399.55 KB)