Tiancheng-Luo / kami

A Platform for High-Level Parametric Hardware Specification and its Modular Verification

Home Page:https://plv.csail.mit.edu/kami/

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Kami: A Platform for High-Level Parametric Hardware Specification and Its Modular Verification

Directory content

  • ./: Contains the source code for syntax, semantics, theorems/properties and proof automation for Kami.
  • Lib: Contains the generic library files that we developed for Kami, extending the standard Coq library, e.g. bit-vectors, decidable finite maps with strings as keys, etc.
  • Ex: Contains basic examples and tutorials.
  • Ext: Files needed to extract designs developed in Kami into Bluespec
    • Ocaml: Contains the files to pretty-print the OCaml code extracted from Coq.

Requirements

To Verify Kami modules

  • Coq 8.12.x with $PATH containing the standard Coq binaries

To Generate Bluespec programs

  • OCaml 4.0.4 (with $PATH containing the standard OCaml binaries)
  • Batteries Library for OCaml (2.5.2)

To Run Bluespec code (i.e. simulation)

To Run Bluespec code on FPGAs

  • Vivado 2015.4 (with $PATH containing the Bluespec binaries)
  • Xilinx Virtex-7 VC707 Evaluation Kit FPGA

About

A Platform for High-Level Parametric Hardware Specification and its Modular Verification

https://plv.csail.mit.edu/kami/

License:MIT License


Languages

Language:Coq 89.3%Language:Verilog 5.8%Language:OCaml 2.1%Language:C 1.7%Language:Bluespec 0.5%Language:Shell 0.3%Language:Makefile 0.2%Language:C++ 0.0%