- Vision: Updated VISION.md with Zicroui TUI/GUI Hybrid strategy - Logic Graft: Integrated microui.c directly into Rumpk kernel - HAL: Added hal/ui.zig (Zig Adapter) and hal/framebuffer.zig (Stub) - Build: Updated build.sh to compile microui with freestanding headers (libs/microui/include) - Stubs: Implemented vsnprintf, snprintf, sprint, strtod, qsort in cstubs.c for microui support - Scheduler: Added dedicated UI Fiber (The Face) to kernel.nim - Result: Immediate Mode GUI logic running on bare metal RISC-V |
||
|---|---|---|
| .. | ||
| arch | ||
| crypto | ||
| README.md | ||
| abi.zig | ||
| channel.zig | ||
| entry_riscv.zig | ||
| framebuffer.zig | ||
| hud.zig | ||
| main.zig | ||
| stubs.zig | ||
| uart.zig | ||
| ui.zig | ||
| virtio_net.zig | ||
| virtio_pci.zig | ||
README.md
Rumpk HAL (L0)
Language: Zig + Assembly
Purpose: Hardware Abstraction Layer
Module Index
| File | Purpose |
|---|---|
main.zig |
Entry point (_start), stack setup, calls Nim kmain |
stubs.zig |
Freestanding libc (memcpy, malloc, printf, etc.) |
uart.zig |
PL011 UART driver (QEMU virt) |
abi.zig |
C ABI structs shared with Nim |
Architecture Directory (arch/)
Contains per-architecture implementations:
arch/
├── aarch64/ # ARM64 (VisionFive 2, RPi, AWS Graviton)
│ ├── switch.S # Context switch (96 bytes)
│ └── constants.nim
├── x86_64/ # System V ABI (servers, trading)
│ ├── switch.S # Context switch (56 bytes)
│ └── constants.nim
└── riscv64/ # RISC-V LP64 (satellites, drones)
├── switch.S # Context switch (112 bytes)
└── constants.nim
Freestanding Doctrine
This HAL provides ALL C ABI symbols. No glibc, no musl.
Exported Symbols:
- Memory:
memcpy,memset,memmove,memcmp - Strings:
strlen,strcmp,strcpy - Heap:
malloc,free,realloc,calloc - I/O:
printf,puts,putchar - Exit:
exit,abort - Signals:
signal,raise(no-op stubs)
Build
Compiled via zig build-obj -target <arch>-freestanding-none