Skip to content
This repository has been archived by the owner on Nov 23, 2024. It is now read-only.

Unofficial builds of CheriBSD, a system that support ARM Morello in emulation and on hardware.

License

Notifications You must be signed in to change notification settings

cocoa-xu/unofficial-cheribuild

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

90 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Logo

Unofficial builds of CheriBSD, a system that support ARM Morello in emulation and on hardware.

CheriBSD is a Capability Enabled, Unix-like Operating System which takes advantage of Capability Hardware on Arm's Morello and CHERI-RISC-V platforms.

This repo currently uses CTSRD-CHERI/cheribuild to build CheriBSD purecap and hybrid system images for ARM Morello biweekly.

Prebuilt CheriBSD system images can be found at https://cheri.build.

Docker Image

This repo also builds Docker images that can be run prebuilt CheriBSD system images. Prebuilt Docker images includes:

The tag of the Docker image is the same as the tag of the releases in this repo. For example, v2024.01.05-f8b62f01 is the Docker image built based on CTSRD-CHERI/cheribuild@f8b62f01, which was commited on 05 Jan 2024.

Also, these Docker images are built on both linux/amd64 and linux/arm64 platforms. Therefore, you can run these Docker images on either x86_64 and ARM64 machines without performing cost by emulation.

Usage

For example, to run the Docker image, you can use the following command:

docker run --rm -it cocoaxu/cheribsd-purecap

And it will automatically start the CheriBSD purecap system image in QEMU.

You can also run the Docker image with the following command to start the CheriBSD purecap system image in QEMU with a shell:

# on host machine
docker run --rm -it --entrypoint /bin/bash cocoaxu/cheribsd-purecap

# and inside the container
#
# using the following command to start 
# the CheriBSD system image in QEMU with default settings
/usr/bin/start_cheribsd

# alternatively, you can use the following command inside the container
# to start the CheriBSD system image in QEMU with custom settings
#
# set number of CPUs
NCPUS=4
# set memory size
MEMORY=4096
# start QEMU
/usr/local/bin/qemu-system-morello \
    -M virt,gic-version=3 \
    -cpu morello \
    -smp "${NCPUS}" \
    -bios edk2-aarch64-code.fd \
    -m "${MEMORY}" \
    -nographic \
    -drive if=none,file="/cheribsd.img",id=drv,format=raw \
    -device virtio-blk-pci,drive=drv \
    -device virtio-net-pci,netdev=net0 \
    -netdev 'user,id=net0,hostfwd=tcp::2222-:22' \
    -device virtio-rng-pci

About

Unofficial builds of CheriBSD, a system that support ARM Morello in emulation and on hardware.

Topics

Resources

License

Stars

Watchers

Forks

Languages