Effective stateless model checking for C/C++ concurrency

77Citations
Citations of this article
27Readers
Mendeley users who have this article in their library.

Abstract

We present a stateless model checking algorithm for verifying concurrent programs running under RC11, a repaired version of the C/C++11 memory model without dependency cycles. Unlike most previous approaches, which enumerate thread interleavings up to some partial order reduction improvements, our approach works directly on execution graphs and (in the absence of RMW instructions and SC atomics) avoids redundant exploration by construction. We have implemented a model checker, called RCMC, based on this approach and applied it to a number of challenging concurrent programs. Our experiments confirm that RCMC is significantly faster, scales better than other model checking tools, and is also more resilient to small changes in the benchmarks.

Cite

CITATION STYLE

APA

Kokologiannakis, M., Lahav, O., Sagonas, K., & Vafeiadis, V. (2018). Effective stateless model checking for C/C++ concurrency. Proceedings of the ACM on Programming Languages, 2(POPL). https://doi.org/10.1145/3158105

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free