This experience report describes a style of applying symbolic model checking developed over the course of four years at Amazon Web Services (AWS). Lessons learned are drawn from proving properties of numerous C-based systems, e.g., custom hypervisors, encryption code, boot loaders, and an IoT operating system. Using our methodology, we find that we can prove the correctness of industrial low-level C-based systems with reasonable effort and predictability. Furthermore, AWS developers are increasingly writing their own formal specifications. All proofs discussed in this paper are publicly available on GitHub.
CITATION STYLE
Chong, N., Cook, B., Kallas, K., Khazem, K., Monteiro, F. R., Schwartz-Narbonne, D., … Tuttle, M. R. (2020). Code-level model checking in the software development workflow. In Proceedings - International Conference on Software Engineering (pp. 11–20). IEEE Computer Society. https://doi.org/10.1145/3377813.3381347
Mendeley helps you to discover research relevant for your work.