/nixos-rk3588

Minimal NixOS running on RK3588/RK3588s based SBC(Orange Pi 5 Plus, Orange Pi 5, Rock 5A, etc)

Primary LanguageNixMIT LicenseMIT

NixOS running on RK3588/RK3588s

⚠️ Work in progress, use at your own risk...

A minimal flake to run NixOS on RK3588/RK3588s based SBCs, support both UEFI & U-Boot.

Default user: rk, default password: rk3588

Boards

UEFI support:

Singal Board Computer Boot from SD card Boot from SSD
Orange Pi 5 ✔️ ✔️
Orange Pi 5 Plus ✔️ ✔️
Rock 5A 🚫 🚫

U-Boot support:

Singal Board Computer Boot from SD card Boot from SSD
Orange Pi 5 ✔️ ✔️
Orange Pi 5 Plus ✔️ 🚫
Rock 5A ✔️ 🚫

TODO

  • UEFI support for Rock 5A, Rock 5B, Orange Pi 5B, NanoPI R6C, NanoPi R6S.
  • verify all the hardware features available by RK3588/RK3588s
    • ethernet (rj45)
    • m.2 interface(pcie & sata)
    • wifi/bluetooth
    • audio
    • gpio
    • uart/ttl
    • gpu(mali-g610-firmware + panfork/mesa)
    • npu
    • ...

Flash & Boot NixOS

For UEFI, see UEFI.md.

For U-Boot, see U-Boot.md.

Debug via serial port(UART)

See Debug.md

Custom Deployment

You can use this flake as an input to build your own configuration. Here is an example configuration that you can use as a starting point: Demo - Deployment

How this flake works

A complete Linux system typically consists of five components:

  1. Bootloader (typically U-Boot or EDKII)
  2. Linux kernel
  3. Device trees
  4. Firmwares
  5. Root file system (rootfs)

Among these, the bootloader, the kernel, device trees, and firmwares are hardware-related and require customization for different SBCs. On the other hand, the majority of content in the rootfs is hardware-independent and can be shared across different SBCs.

Hence, the fundamental approach here is to use the hardware-specific components(bootloader, kernel, and device trees, firmwares) provided by the vendor(orangepi/rockpi/...), and combine them with the NixOS rootfs to build a comprehensive system.

Regarding RK3588/RK3588s, a significant amount of work has been done by Armbian on their kernel, and device tree. Therefore, by integrating these components from Armbian with the NixOS rootfs, we can create a complete NixOS system.

The primary steps involved are:

  1. Bootloader: Since no customization is required for U-Boot or edk2-rk3588, it's also possible to directly use the precompiled image from armbian, edk2-rk3588, or the hardware vendor.
  2. Build the NixOS rootfs using this flake, leveraging the kernel and device tree provided by armbian.
    • To make all the hardware features available, we need to add its firmwares to the rootfs. Since there is no customization required for the firmwares too, we can directly use the precompiled firmwares from Armbian & Vendor too.

Screenshots

References

And I also got a lot of help in the NixOS on ARM Matrix group!