Building on Arm, for Arm: OpenEmbedded Edition
With how fast Arm processors have gotten in the past few years, compiling the Linux Kernel natively on Arm is more than just bearable.
But what about an ENTIRE operating system, complete with boot-loader, init and user-space (GUI optional)?
My goal was to see what OS I can build, in a reasonable amount of time, using an Arm based SBC, so i can’t just rent a 128 thread Arm server…
So what are my choices (considering it has a decent build system with its own toolchain):
- AOSP (N): Although I am very much interested in this, but looks like its not ready yet, the prebuilt folder seems to house just the x86 compiler and cross-compiler.
- RedoxOS (N): An experimental OS based on ‘rust’, seems to be adding support for Arm, but still at a very early stage.
- OpenEmbedded (Y): OE has a neat trick, it ALWAYS cross-compiles even if its building for x86 on an x86 machine, this makes it easier to build natively on Arm, and that’s why its already supported.
The hardware requirements: To have the Poky distro built in a considerable amount of time.
- CPU: Octa-core: 2Ghz on at least 4 cores
- RAM:
- GUI: > 8GB
- CLI-only: > 4GB
- Storage: >30GB
So from in my collection of Arm SBC’s, one matched the requirement… The Hikey970
It has an octa-core CPU that does more than 2GHz, 6GB of RAM, so I can comfortably have a CLI-only build and 64GB of UFS Storage.
A couple Caveats:
- Poky distro seems to have an odd issue with building on aarch64, but a simple workaround is to remove:
INHERIT += "uninative"
from:meta-poky/conf/distro/poky.conf
- Under continuous heavy load, Hikey970 gets HOT… add a small cooling fan.
The Result:
Surprisingly, the Hikey970 did pull off a core-image-minimal build successfully and only took as long as one of the quicker crock-pot recipes. Nice!
Whats next?