Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kivikakk/daintree
[non-functional] ARMv8-A/RISC-V kernel (with UEFI bootloader)
https://github.com/kivikakk/daintree
armv8 kernel risc-v uefi zig
Last synced: 7 days ago
JSON representation
[non-functional] ARMv8-A/RISC-V kernel (with UEFI bootloader)
- Host: GitHub
- URL: https://github.com/kivikakk/daintree
- Owner: kivikakk
- License: other
- Created: 2021-02-10T05:20:34.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-07-15T14:20:42.000Z (6 months ago)
- Last Synced: 2025-01-11T20:23:19.199Z (14 days ago)
- Topics: armv8, kernel, risc-v, uefi, zig
- Language: Zig
- Homepage:
- Size: 6.55 MB
- Stars: 51
- Watchers: 4
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-zig - kivikakk/daintree - A/RISC-V kernel (with UEFI bootloader). An operating system plus a UEFI bootloader, all written in Zig. (Embedded Development / Linker)
- awesome-zig - daintree🗒️ARMv8-A/RISC-V kernel (with UEFI bootloader)
README
# daintree
An operating system plus a UEFI bootloader, all written in Zig. Currently targetting and testing on:
- QEMU (arm64 + riscv64) with U-Boot
- The U-Boot build is included in the repository, and is based on
[patch series adding QFW and QEMU ramfb support on Arm](https://git.src.kameliya.ee/~kameliya/u-boot/log/qfw-ramfb).
I'm hoping to land this in the coming weeks.
- There's the [same for riscv](https://git.src.kameliya.ee/~kameliya/u-boot/log/qfw-ramfb-riscv).
- CI runs on QEMU and currently makes sure the target can boot and be powered off by command at the serial console. (samples: [arm64](https://buildkite.com/daintree/daintree-arm64/builds/150#a0a1da6d-3764-4529-b25f-66cc605080c7/27-151), [riscv64](https://buildkite.com/daintree/daintree-riscv64/builds/50#38096c20-6e7c-4712-b7dc-7f56ccc9cffe/27-166))
- ROCKPro64 (arm64) with U-Boot
- A mainline build is okay, but it must contain this
[EFI loader fix](https://source.denx.de/u-boot/u-boot/-/commit/9d30a941cce5ed055da18398f4deba18830d00d6).
At time of writing it has not been included in any release.Planned support for:
- HiFive Unmatched with U-Boot
There's a little [dev blog](https://github.com/kivikakk/daintree/discussions/1)
I hope to maintain as I go. See also [my personal blog](https://kivikakk.ee):- 2021-02-28: [Knowing when to look past your code](https://kivikakk.ee/2021/02/28/loader/)
- 2021-02-13: [DTB parser implementing notes](https://kivikakk.ee/2021/02/13/dtb-parser-implementing-notes/)## dainboot
A gentle introduction to Zig's UEFI support. Boots like this:
- Checks loaded image options.
- You can pass `kernel 0x12345678 0x1234` to give it the location of the
kernel already loaded in RAM. Useful for TFTP boot, which itself is handy
for faster development cycles on bare metal.
- You may also pass `dtb 0x12345678 0x1234` to give information about a
DTB/FDT (device tree blob/flattened device tree) already in memory.
- Separate successive options with spaces, i.e. `kernel dtb
`.
- If DTB wasn't loaded from memory, checks to see if one was passed in via
UEFI.
- If kernel or DTB (or both) were not loaded from memory, scans filesystems the
UEFI system knows about, looking in the root directories for files named
`dainkrnl` and `dtb`.
- Picks the biggest unused slab of conventional memory and places the kernel
there.
- Clears data and instruction caches for loaded memory.
- Parses the DTB and attempts to locate the serial UART port.
- Exits UEFI boot services.
- If necessary, disables a whole lot of traps and goes to EL1.
- Jumps to the kernel, passing the memory map, UART write port, and framebuffer
prepared by UEFI.![](doc/img/dainboot-qemu.png)
![](doc/img/dainboot-rockpro64.jpg)
## dainkrnl
- Uses the UART write port to debug before the MMU is enabled.
- Sets up the MMU, mapping the kernel, stack, framebuffer, DTB, UART device,
etc. into high addresses.
- Parses the DTB to understand what kind of serial device is connected and how
to access
[PSCI](https://developer.arm.com/architectures/system-architectures/software-standards/psci).
- Implements a console using a classic VGA font.
- A shell lets you reset or poweroff the system. You can only use serial for
input, but the output is muxed to the framebuffer if one is available.![](doc/img/dainkrnl-charset-qemu.png)
![](doc/img/dainkrnl-charset-rockpro64.jpg)
![](doc/img/dainkrnl-shell-qemu.png)
## license
MIT.
Some included binaries are GPL-2+ or GPL-2.0+ -- copyright notices retained and
sources noted where so.The [`roms/`](roms/) directory contains an arm64 build of
[U-Boot](http://www.denx.de/wiki/U-Boot/WebHome), (C) Wolfgang Denk and
licensed under GPL 2. See [U-Boot's Licensing
page](https://www.denx.de/wiki/U-Boot/Licensing)
for details. The source can be found at
.It also contains a riscv64 build of same at
. It is
embedded in a build of [OpenSBI](https://github.com/riscv/opensbi), (C) 2019
Western Digital Corporation, licensed under BSD-2-Clause.