System76 Open Firmware
An open source distribution of firmware utilizing coreboot, EDK2, and System76 firmware applications.
Please note that only the darp6 and galp4 models are officially supported - if you brick your device it will be up to you to restore the current firmware using an external programmer.
If you would like to view schematics for any supported System76 model, please send an email to firmware@system76.com with the subject line Schematics for MODEL, where MODEL is the name of a directory in the models directory, such as darp6.
Dependencies
Install toolchain
./scripts/deps.sh
Load Rust environment (or optionally reboot)
source ~/.cargo/env
Build firmware, replace qemu with your model (look in the models directory for examples)
./scripts/build.sh qemu
Emulate firmware, only available after building the qemu model
./scripts/qemu.sh
Flashing
Flashing firmware manually is not recommended for the normal user!
Internal programmer
Use this method for flashing a system already running System76 Open Firmware.
./scripts/flash.sh <model>
External programmer
Use this method for first-time flashing or flashing a bricked system.
Creating a SPI Pi
SPI Pi is a Raspberry Pi used to flash the SPI ROM. To create a SPI Pi:
- Get a Raspberry Pi 2 or 3 with Ubuntu 16.04
- Hook up a SPI clip to the SPI Pi
- The SPI Pi's SPI pinout can be found here: https://pinout.xyz/pinout/spi#
- The pinout of a SPI rom can be found here: https://www.totalphase.com/media/wysiwyg/soic8-pinout.png
- If you need more instructions, you should not be hooking up the SPI clip
- Connect the SPI Pi's SPI clip to the SPI ROM, ensuring pin 1 of the clip aligns with pin 1 on the ROM
- On the SPI Pi, run the following commands:
sudo apt install flashrom
git clone https://github.com/system76/firmware-open.git firmware
Flashing with a SPI Pi
- Turn off the computer
- Remove the bottom panel
- Attach the clip to the SPI ROM chip
- Connect to the Raspberry Pi and wait it for boot
sudo tio -b 115200 /dev/ttyUSB0
- From the RPi session, test that the chip is detected.
cd firmware
./scripts/spipi.sh -r backup.rom
- From the host, flash the firmware
SPIPI=<user@spipi> ./scripts/spipi-flash.sh <model>