Go to file
seL4 CI c198cc7535 Updating default.xml
Change-Id: I5c300e7abe4877f85c8072aab4f97eb3ae455d19
2024-09-23 10:02:22 +00:00
.github add CoC and Contributing guidelines 2020-12-02 15:00:57 +11:00
LICENSES Convert repo to SPDX license identifiers 2020-12-02 14:59:40 +11:00
snapshots Convert repo to SPDX license identifiers 2020-12-02 14:59:40 +11:00
README.md Fix outdated link 2020-12-03 17:32:55 +11:00
default.xml Updating default.xml 2024-09-23 10:02:22 +00:00
l4v-master.xml Convert repo to SPDX license identifiers 2020-12-02 14:59:40 +11:00
master.xml drop Cogent support 2023-05-26 17:42:29 +10:00
working.xml Convert repo to SPDX license identifiers 2020-12-02 14:59:40 +11: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.