Kami: a platform for high-level parametric hardware specification and its modular verification
Author(s)
Choi, Joonwon; Vijayaraghavan, Muralidaran; Sherman, Benjamin; Chlipala, Adam; Arvind
DownloadPublished version (424.5Kb)
Terms of use
Metadata
Show full item recordAbstract
<jats:p>It has become fairly standard in the programming-languages research world to verify functional programs in proof assistants using induction, algebraic simplification, and rewriting. In this paper, we introduce Kami, a Coq library that enables similar expressive and modular reasoning for hardware designs expressed in the style of the Bluespec language. We can specify, implement, and verify realistic designs entirely within Coq, ending with automatic extraction into a pipeline that bottoms out in FPGAs. Our methodology, using labeled transition systems, has been evaluated in a case study verifying an infinite family of multicore systems, with cache-coherent shared memory and pipelined cores implementing (the base integer subset of) the RISC-V instruction set.</jats:p>
Date issued
2017Department
Massachusetts Institute of Technology. Computer Science and Artificial Intelligence LaboratoryJournal
Proceedings of the ACM on Programming Languages
Publisher
Association for Computing Machinery (ACM)