Skip to content

TRENT-OS/trentos

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TRENTOS

Welcome to the TRENTOS project.

TRENTOS (Trusted Entity Operating System) is an embedded OS build upon the seL4 microkernel and CAmkES

Requirements

  • Linux (We recommend Ubuntu 20.04 or newer)
  • Docker or Podman

Getting Started

Get started with TRENTOS in 5 simple steps:

# 1. Create a new folder for TRENTOS
mkdir trentos && cd trentos

# 2. Clone the TRENTOS repository
git clone --recursive [email protected]:TRENT-OS/trentos.git src

# 3. Pull the TRENTOS Test & Build Docker container from Docker Hub
docker pull hensoldtcyber/trentos_build:latest
docker pull hensoldtcyber/trentos_test:latest

# 4. Prepare the test environment (only needs to be done once)
src/build.sh test-prepare

# 5. Build & execute demo_hello_world
src/build.sh build-and-test demo_hello_world

TRENTOS Getting Started

Documentation

Please refer to our TRENTOS Docs.

Supported Platforms

Currently TRENTOS

  • zynq7000
  • sabre
  • nitrogen6sx
  • zynqmp
  • rpi3
  • rpi4
  • hikey
  • odroidc2
  • odroidc4
  • fvp
  • hifive
  • polarfire
  • spike32
  • spike64
  • qemu-arm-virt
  • qemu-arm-virt-a15
  • qemu-arm-virt-a53
  • qemu-arm-virt-a57
  • qemu-arm-virt-a72
  • qemu-riscv-virt32
  • qemu-riscv-virt64
  • ia32
  • x86_64
  • jetson-nano-2gb-dev-kit
  • jetson-tx2-nx-a206
  • jetson-xavier-nx-dev-kit
  • aetina-an110-xnx

TRENTOS Demos

Current demonstrators included in the standard TRENTOS source tree:

  • demo_iot_app
  • demo_iot_app_hw
  • demo_network_filter
  • demo_raspi_ethernet
  • demo_tls_api
  • demo_i2c
  • demo_tls_server
  • demo_mailbox_rpi
  • demo_vm_minimal
  • demo_vm_serialserver
  • demo_vm_virtio_net
src/build.sh build-and-test <name of demo>

Even more demos are available as submodules.

Please ensure that the selected DEFAULT_BUILD_PLATFORM in trentos/build.sh is compatible with the selected demonstrator.

Contributing

Contributions are always welcome.

To get started please read our CONTRIBUTING.md.

Docker Images

Our Docker images are hosted on DockerHub.
Dockerfiles are hosted in Docker Images.

Licensing

TRENTOS is available under the OSS GPLv2-or-later license. Upon request commercial licensing options are available. Please contact: [email protected] for more information.

A select few components are only available under different licensing terms. Due to the microkernel concept this may not be an issue as long as these are used as a distinct TRENTOS components.

Testing

TRENTOS comes with a testframework built with pytest and can be found at trentos/ta/tests/.

Tests exists for all tests and for most demos.

Examle usage: Building and testing demo_hello_world:

src/build.sh build-and-test demo_hello_world

Dependencies

TRENTOS builds upon varies open source libraries and projects:

  • sel4
  • muslc
  • utils
  • sel4muslcsys
  • sel4platsupport
  • sel4utils
  • sel4debug
  • sel4allocman
  • camkes
  • capdl
  • And more...