Copilot-Bluespec implements a Bluespec backend for Copilot, producing code that is suitable for FPGAs.
Copilot is a runtime verification framework written in Haskell. It allows the user to write programs in a simple but powerful way using a stream-based approach.
Programs can be interpreted for testing, or translated Bluespec code to be incorporated in a project, or as a standalone application. The Bluespec backend ensures us that the output is constant in memory and time, making it suitable for systems with hard realtime requirements.
Copilot-Bluespec can be found on Hackage. It is intended to be installed alongside a Copilot distribution by running the following commands:
$ cabal update
$ cabal install copilot
$ cabal install copilot-bluespec
For more detailed instructions on how to install Copilot, please refer to the Copilot website.
The generated Bluespec code requires bsc
(the Bluespec compiler) in order to
be compiled. bsc
can be downloaded
here.
We also provide a Dockerfile which automates the process of
installing Copilot, Copilot-Bluespec, and bsc
. The Dockerfile can be built and
run using the following commands:
$ docker build -t <tag> .
$ docker run -it <tag>
Where <tag>
is a unique name for the Docker image.
For further information, install instructions and documentation, please visit the Copilot website: https://copilot-language.github.io
There is also an implementation-focused design document here.
Copilot is distributed under the BSD-3-Clause license, which can be found here.