Compiling Haiku for Arm

Haiku can be compiled for devices leveraging the ARMv7 or later processor architecture.

Unstable
The state of the ARM port is extremely early. Roll up your sleeves and help out!

Create a Compiler Toolchain

Building the ARM compiler toolchain is quite easy using Haiku’s configure tool.

For a complete list of flags for the configure script, see Haiku’s Configure Options

  1. Perform a git clone haiku and buildtools
  2. Within the haiku source directory, create your workspace for ARM via mkdir generated.arm; cd generated.arm
  3. Leverage configure to build your ARM toolchain. ../configure -j2 --build-cross-tools arm ../../buildtools

Building an MMC (SD Card) Image

Once you have a complete ARM toolchain, you can build a Haiku MMC disk image via jam -j2 -q @minimum-mmc This will generate an MMC image suitable for booting Haiku on a real ARM hardware device.

Post-processing
The generated MMC image only contains Haiku software. Most ARM hardware devices will require extra binary bootloaders (including u-boot). User-run automated post-processing tools are being developed to automate these steps.

Emulating ARM Image

The ARM images can also be emulated in QEMU. In the example below, we emulate a Raspberry Pi 2.

qemu-system-arm -M raspi2 -kernel haiku_loader.ub -initrd haiku-floppyboot.tgz.ub -dtb rpi2.dtb -m 2G