The details of the OSmosis model are available here and here. A wiki of CellulOS is available here
Instructions copied verbatim from sel4test.
The basic build package on Ubuntu is the build-essential package. To install run:
sudo apt-get update
sudo apt-get install build-essential
Additional base dependencies for building seL4 projects on Ubuntu include installing:
sudo apt-get install cmake ccache ninja-build cmake-curses-gui
sudo apt-get install libxml2-utils ncurses-dev
sudo apt-get install curl git doxygen device-tree-compiler
sudo apt-get install u-boot-tools
sudo apt-get install python3-dev python3-pip python-is-python3
sudo apt-get install protobuf-compiler python3-protobuf
In order to run seL4 projects on a simulator you will need QEMU:
sudo apt-get install qemu-system-arm qemu-system-x86 qemu-system-misc
To build for ARM targets you will need a cross compiler:
sudo apt-get install gcc-arm-linux-gnueabi g++-arm-linux-gnueabi
sudo apt-get install gcc-aarch64-linux-gnu g++-aarch64-linux-gnu
# (you can install the hardware floating point versions as well if you wish)
sudo apt-get install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf
# Clone OSmosis and all the submodules
git clone --recurse-submodules [email protected]:sid-agrawal/OSmosis.git
cd OSmosis
# Make sure that the cellulos branch is checked out
git submodule foreach git checkout cellulos
git status # This should show no chanages, as all the commits should be on the cellulos branch
Often something dies horribly and you only have the ESR register's hex value as hints. Going through the 7K page ARM manual is surely fun, but just in case you are in a rush, this URL can also be helpful.
mkdir build
cd build
../init-build.sh -DAARCH64=TRUE -DPLATFORM=qemu-arm-virt -DSIMULATION=TRUE -DDEBUG=TRUE
ninja
./simulate
mkdir build
cd build
../init-build.sh -DAARCH64=TRUE -DPLATFORM=odroidc4 -DDEBUG=TRUE
ninja
# Look at notion for steps on how to copy the binary to the board via TFTP
../init-build.sh -DAARCH64=TRUE -DPLATFORM=qemu-arm-virt -DSIMULATION=TRUE -DSMP=TRUE -DDEBUG=TRUE
This will enable 4 cores by default, pass in -DKernelMaxNumNodes=<CORES>
to change this
- If running on WSL, in the config files, give it at least 8GB in RAM (otherwise tests won't run at all) and at least 4 virtual processors (otherwise it will run very slowly).
- invoke
./simulate -m 8G
, with 8G as a minimum. QEMU is run with 4 cores by default, pass in-smp <CORES>
to change this.
Compile commands file is used for code navigation. This workspace's vscode settings file is configured to use it.
cd build
bear --output ../compile_commands.json -- ninja
Let's follow rules to make our lives easier:
- All the submodules are using a fork maintained by
sid-agrawal
. - All
OSmosis
commits go thecelluos
branch for every module, including the parent OSmosis repo. - Let's not push code to submodules that we do not reflect in OSmosis repo yet.
In other words let's keep them in sync.
- Using
git push --recurse-submodules=on-demand
should make enforce this. More on this below.
- Using
TLDR; Commit and push individual sub-modules first, and then do the same in the parent repo.
Set up this alias once. This alias will get added to your repo-local .git/config
git config alias.supercommit '!./supercommit.sh "$@"; #'
| Note: This will add and commit everything, which may be you do not want sometimes.
Then to commit do:
git supercommit "some message"
cat ./supercommit.sh
#!/bin/bash -e
if [ -z "$1" ]; then
echo "You need to provide a commit message"
exit
fi
git submodule foreach "
git add -A .
git update-index --refresh
commits=\$(git diff-index HEAD)
if [ ! -z \"\$commits\" ]; then
git commit -am \"$1\"
fi"
git add -A .
git commit -am "$1"
Read the Publishing submodules
section here.
It will push the files and the modules refs from OSmosis repo, and if it sees that a particular module ref is not yet pushed, it will push that too.
git push --recurse-submodules=on-demand
I am fairly certain this should be okay, but we will see.
# bring in new refs for submodules
git pull --rebase
# Update the code in the modules, if there is a conflict with local, this should complain.
# Then Resolve conflicts, supercommit
[...]
# Push
git push --recurse-submodules=on-demand
Run the following command from the root OSmosis
folder:
doxygen Doxyfile
A doxygen
directory should've been created, with the html
and latex
versions of the documentation.
Only contents of sel4gpi
have been configured for doxygen.
For configuration, see the official doxygen documentation.