Go to file
Kent McLeod 02a173ccf9 Create df-public release snapshot
Change-Id: I859af788d59214fe474a7bf23a43e8d60915d9ec
2020-05-22 22:30:52 +10:00
snapshots Update licenses 2018-05-25 15:27:08 +10:00
LICENSE_BSD2.txt Release snapshot 2014-07-22 15:13:55 +10:00
README.md README: add init-build instructions for capDL verification 2019-07-24 11:56:03 +10:00
default.xml Create df-public release snapshot 2020-05-22 22:30:52 +10:00
l4v-master.xml l4v-master.xml: fix isabelle revision 2019-07-24 11:56:03 +10:00
master.xml Create df-public release snapshot 2020-05-22 22:30:52 +10:00
working.xml Update licenses 2018-05-25 15:27:08 +10:00

README.md

camkes-manifest

CAmkES is a component platform that provides support for developing and building static seL4 systems as a collection of interacting components. The resulting systems are static, meaning that all the components and their connections (and thus all the kernel managed resources) are defined at design time and instantiated at system initialisation time.
It is not possible to change the system (e.g., to create or destroy components or to change the connections between components) at runtime. This CAmkES package includes various example systems that can be studied, and individually built and run.

For general instructions on how to use this repository, see sel4.systems.

For general information about CAmkES see the CAmkES pages on seL4.systems.

For detailed information about CAmkES see documentation in the camkes-tool repo.

Prerequisites, in addition to a standard build system for your target, are:

  • The Haskell compiler, ghc
  • Haskell libraries missingH, split and data-ordlist
  • Python
  • Python libraries python-tempita, pyelftools, jinja2 and ply
  • which, realpath and the libxml2 utilities.

Dependencies for verification

The toolchain can generate formal specifications and proofs about how a CAmkES spec is mapped to seL4 objects (via capDL). To run these proofs, checkout the l4v-master manifest, e.g. with:

repo init -m l4v-master.xml
repo sync

Then enable these extra init-build options:

../init-build.sh [...] -DCAmkESCapDLStaticAlloc=1 -DCAmkESCapDLVerification=1

You will also need to install additional dependencies; see the L4.verified setup instructions.

Note that the proof toolchain does not support all CAmkES features.