seL4

Performance

This page displays the latest benchmark numbers for seL4 from the publicly available sel4bench repository. The following times are reported as mean and standard deviation in the format mean (std dev), both rounded to the nearest integer.

  • IRQ invoke: Time in cycles to invoke a user-level interrupt handler running in the same address space as the interrupted thread.
  • IPC call: Time in cycles for invoking a server in a different address space on the same core.
  • IPC reply: Time in cycles for a server replying to a client in a different address space on the same core.
  • Notify: Time in cycles to send a signal from a process with priority 1 to a higher priority (255) process in a different address space

Default

ISA Mode Core/SoC/Board Clock IRQ Invoke IPC call IPC reply Notify
Armv7a 32 A9/i.MX6/Sabre 1.0 GHz 584 (13) 317 (2) 337 (4) 825 (10)
x86_64 64 i7-4770/Haswell 3.4 GHz 1587 (262) 586 (15) 596 (16) 1252 (76)
x86_64 64 i7-6700/Skylake (without meltdown mitigation) 3.4 GHz 1303 (202) 379 (3) 385 (2) 752 (83)
Armv8a 64 A57/Tx1/Jetson 1.9 GHz 664 (30) 425 (8) 414 (13) 931 (9)
RV64IMAC 64 U54-MC/SiFive Freedom U540/Hifive 1.5 GHz 973 (78) 470 (9) 658 (106) 1340 (65)

MCS

ISA Mode Core/SoC/Board Clock IRQ Invoke IPC call IPC reply Notify
Armv7a 32 A9/i.MX6/Sabre 1.0 GHz 852 (35) 324 (2) 363 (3) 1213 (14)
x86_64 64 i7-4770/Haswell 3.4 GHz 2077 (418) 583 (12) 603 (13) 1592 (14)
x86_64 64 i7-6700/Skylake (without meltdown mitigation) 3.4 GHz 1669 (338) 379 (2) 407 (8) 1058 (12)
Armv8a 64 A57/Tx1/Jetson 1.9 GHz 754 (19) 418 (6) 432 (11) 1051 (8)
RV64IMAC 64 U54-MC/SiFive Freedom U540/Hifive 1.5 GHz 2994 (180) 687 (33) 916 (119) 3790 (147)

Compilation Details

All benchmarks were built using the trustworthy-systems/sel4 docker image from the seL4 docker file repository

Default

ISA Mode Core/SoC/Board Clock Compiler Build command
Armv7a 32 A9/i.MX6/Sabre 1.0 GHz arm-linux-gnueabi-gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DAARCH32=TRUE -DPLATFORM=sabre
x86_64 64 i7-4770/Haswell 3.4 GHz gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DPLATFORM=x86_64
x86_64 64 i7-6700/Skylake 3.4 GHz gcc GNU 10.2.1 init-build.sh -DKernelSkimWindow=FALSE -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DPLATFORM=x86_64
Armv8a 64 A57/Tx1/Jetson 1.9 GHz aarch64-linux-gnu-gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DAARCH64=TRUE -DPLATFORM=tx1
RV64IMAC 64 U54-MC/SiFive Freedom U540/Hifive 1.5 GHz riscv64-unknown-elf-gcc GNU 8.3.0 init-build.sh -DFASTPATH=TRUE -DHARDWARE=FALSE -DFAULT=FALSE -DRISCV64=TRUE -DPLATFORM=hifive

MCS

ISA Mode Core/SoC/Board Clock Compiler Build command
Armv7a 32 A9/i.MX6/Sabre 1.0 GHz arm-linux-gnueabi-gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DAARCH32=TRUE -DPLATFORM=sabre -DMCS=TRUE
x86_64 64 i7-4770/Haswell 3.4 GHz gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DPLATFORM=x86_64 -DMCS=TRUE
x86_64 64 i7-6700/Skylake 3.4 GHz gcc GNU 10.2.1 init-build.sh -DKernelSkimWindow=FALSE -DMCS=TRUE -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DPLATFORM=x86_64
Armv8a 64 A57/Tx1/Jetson 1.9 GHz aarch64-linux-gnu-gcc GNU 10.2.1 init-build.sh -DFASTPATH=TRUE -DHARDWARE=TRUE -DFAULT=TRUE -DAARCH64=TRUE -DPLATFORM=tx1 -DMCS=TRUE
RV64IMAC 64 U54-MC/SiFive Freedom U540/Hifive 1.5 GHz riscv64-unknown-elf-gcc GNU 8.3.0 init-build.sh -DFASTPATH=TRUE -DHARDWARE=FALSE -DFAULT=FALSE -DRISCV64=TRUE -DPLATFORM=hifive -DMCS=TRUE

Source Code

This page was generated on 2024-12-19 for sel4bench-manifest f0cd4d62.