Abstract
Message passing is the standard paradigm of programming in highperformance computing. However, verifying Message Passing Interface (MPI) programs is challenging, due to the complex program features (such as non-determinism and non-blocking operations). In this work, we present MPI symbolic verifier (MPI-SV), the first symbolic execution based tool for automatically verifying MPI programs with non-blocking operations. MPI-SV combines symbolic execution and model checking in a synergistic way to tackle the challenges in MPI program verification. The synergy improves the scalability and enlarges the scope of verifiable properties. We have implemented MPI-SV1 and evaluated it with 111 real-world MPI verification tasks. The pure symbolic execution-based technique successfully verifies 61 out of the 111 tasks (55%) within one hour, while in comparison, MPI-SV verifies 100 tasks (90%). On average, compared with pure symbolic execution, MPI-SV achieves 19x speedups on verifying the satisfaction of the critical property and 5x speedups on finding violations. Show more
Publication status
publishedExternal links
Book title
Proceedings of the ACM/IEEE 42nd International Conference on Software EngineeringPages / Article No.
Publisher
Association for Computing MachineryEvent
Subject
Symbolic verification; Symbolic execution; Model checking; Message passing interface; SynergyOrganisational unit
09628 - Su, Zhendong / Su, Zhendong
Notes
Due to the Coronavirus (COVID-19) the conference was conducted virtually.More
Show all metadata