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 |
582 |
(14) |
317 |
(2) |
338 |
(6) |
837 |
(12) |
x86_64 |
64 |
i7-4770/Haswell |
3.4 GHz |
1533 |
(265) |
576 |
(12) |
590 |
(12) |
1319 |
(74) |
x86_64 |
64 |
i7-6700/Skylake (without meltdown mitigation) |
3.4 GHz |
1276 |
(206) |
382 |
(3) |
381 |
(3) |
752 |
(82) |
Armv8a |
64 |
A57/Tx1/Jetson |
1.9 GHz |
664 |
(30) |
406 |
(11) |
415 |
(1) |
926 |
(6) |
RV64IMAC |
64 |
U54-MC/SiFive Freedom U540/Hifive |
1.5 GHz |
963 |
(66) |
491 |
(100) |
659 |
(93) |
1345 |
(46) |
MCS
ISA |
Mode |
Core/SoC/Board |
Clock |
IRQ Invoke |
IPC call |
IPC reply |
Notify |
Armv7a |
32 |
A9/i.MX6/Sabre |
1.0 GHz |
800 |
(18) |
324 |
(2) |
364 |
(2) |
1189 |
(12) |
x86_64 |
64 |
i7-4770/Haswell |
3.4 GHz |
1988 |
(428) |
586 |
(13) |
605 |
(11) |
1590 |
(8) |
x86_64 |
64 |
i7-6700/Skylake (without meltdown mitigation) |
3.4 GHz |
1665 |
(332) |
382 |
(3) |
406 |
(5) |
1039 |
(6) |
Armv8a |
64 |
A57/Tx1/Jetson |
1.9 GHz |
754 |
(26) |
415 |
(7) |
434 |
(4) |
977 |
(14) |
RV64IMAC |
64 |
U54-MC/SiFive Freedom U540/Hifive |
1.5 GHz |
2927 |
(132) |
686 |
(43) |
894 |
(93) |
3856 |
(150) |
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-10-25 for sel4bench-manifest 8c799e7c.