A Practical Verification Methodology for Concurrent Programs

  • Michal Moskal ,
  • Wolfram Schulte ,
  • Ernie Cohen ,
  • Stephan Tobies

MSR-TR-2009-2019 |

We describe a methodology for reasoning about realistic concurrent programs. Our methodology allows two-state invariants that span multiple objects without sacrificing thread- or data-modularity, as well as the derived construction of first-class objects that capture knowledge about the system state. The methodology has been implemented in an automatic sound verifier for concurrent C programs being used to verify the code of the Microsoft Hypervisor, the virtualization kernel of Hyper-V.