Verification tools
To automate the use of the reasoning techniques devised in the ADVENT project, we are contributing to the development of the following verification tools.
VeriFast
data:image/s3,"s3://crabby-images/a4d71/a4d715be6dc37c66e5080266bc888c1a38c1fef0" alt=""
VeriFast is a semi-automated verifier for C and Java programs. In the ADVENT project, we have added support for reasoning about:
- Concurrent programs under SC in the style of rely/guarantee [Read more],
- Concurrent programs under the x86-TSO memory model [Read more],
- Concurrent programs under the C/C++11 memory model, and
- Input/output [Read more].
[Website (including downloads for Windows, Linux, and MacOS)] [Tutorial]
Cave
data:image/s3,"s3://crabby-images/8a302/8a3022845ec82f011b8fc99550b4778c57a6c37f" alt=""
Cave is an automatic verification tool for concurrent libraries. During the ADVENT project, we are extending the tool to support:
- Our novel aspect-oriented approach for verifying linearizability of concurrent queues,
- Verification of C11 programs using the GPS program logic, and
- Verifying lock-freedom of concurrent libraries.
For more information about Cave, please follow this link.