Grinch is a minimalist operating systems, mainly developed for educational and testing purposes. Grinch is designed to run on RISC-V platforms. It is able to run userspace processes (ELF format), and virtual machines. Userland applications shall have basic POSIX support. Therefore, grinch comes with its own minimalist libc implementation. For compatibility reasons, the syscall interface tries to be compatible with Linux as good as possible.
Grinch contains a minimalist Virtual Machine Monitor that is able to boot itself as virtual machine.
Anyway, don't expect anything to work.
- Device Tree support
- Simple scheduler
- ELF Userland applications
- Minimalist driver model
- Minimalist VFS layer
- Virtual Machine Monitor
- GCOV support
- RISC-V base platform:
- RV64 and RV32 support
- MMU support
- SV32, SV39 and SV48 paging
- SV39x and SV48x paging for VMs
- SMP support (RV64 only)
- RISC-V platform Timers
- RISC-V PLIC interrupt controller
- RISC-V SBI console
- RISC-V H-Extension support
- SBI support
- H-Extensions
- Work in Progress
- UART
- AXI uartlite
- 8250/16550 UART
- apbuart
-
Supported RISC-V boards:
- riscv32
- Virtual Target (qemu)
- riscv64
- Virtual Target (qemu)
- Starfive VisionFive 2
- riscv32
-
ARM64
- Ongoing
It is recommended to compile everything on your local machine with a cross compiler. You will need a cross toolchain and following requirements:
- dtc
- cpio
- qemu-system-riscv64
- riscv64-linux-gnu-
- Python3
- python-pillow
To clone grinch, run:
git clone https://github.com/lfd/grinch.git
cd grinch
git submodule update --init --recursive
For compiling grinch, simply run:
make
For addition debug output, run:
make DEBUG=1
For verbose compiler output, run:
make V=1
This will create kernel.bin
and user/initrd.cpio
. kernel.bin
is the
loadable kernel image, which is directly loadable via Qemu on virtual targets,
or via U-Boot on real platforms. user/initrd.cpio
contains userland
applications, as well as grinch itself (grinch is able to recursively boot
itself as virtual machine).
For running grinch inside QEMU, simply run:
make qemu
For debugging grinch, you can attach with a debugger:
make qemudb
In a second terminal, run:
make debug
Grinch is also able to boot on Qemu via U-Boot. For booting grinch via U-Boot in Qemu, type:
make qemuu
To pass parameters to grinch on real board, you can use the bootargs
variable
in U-Boot. Grinch parses those parameters. To pass parameters in Qemu, use:
make qemu QEMU_CMDLINE='"arg1=val1 arg2=val2"'
You can also adjust the number of Qemus CPUs:
make qemu QEMU_CPUS=4
Basic features:
Parameter | Values | Description |
---|---|---|
timer_hz | int | Timer frequency |
loglevel | int | loglevel. Highest=0, Default=1 |
kheap_size | int | Kernel Heap size (e.g., 8M) |
console | str | boot console (ttyS0) |
init | str | init executable |
Development features:
Parameter | Values | Description |
---|---|---|
memtest | / | Do memory test |
malloc_fsck | / | Run sanity checker for kalloc |
ttp_maxevents | int | No of maxevents for timed TPs |
Grinch is developed by Ralf Ramsauer at OTH Regensburg. It is licensed under GPLv2. Parts of grinch are copied from Linux kernel sources. These parts involve:
- ctype implementation
- List implementation (list.h)
- Auxiliary headers (compiler_attributes.h, const.h, minmax.h)
- vsprintf support
- ELF headers
- strtox
- rwonce