Flashing firmware manually is not recommended for the normal user!
The first boot after flashing will take a long time. This is due to coreboot initializing RAM modules for the first time. Once memory training is complete, coreboot will cache this information and subsequent boots will take significantly less time.
coreboot's cbmem
tool can be used to verify this. The call to
FspMemoryInit()
can report 20+ seconds on the first boot, and a few hundred
milliseconds on subsequent boots.
Use this method for flashing a system already running System76 Open Firmware.
./scripts/flash.sh <model> [--without-ec]
By default the script will attempt to flash the EC. If the EC is flashed, the system will immediately power off.
Use one of these methods for first-time flashing or flashing a bricked system.
The packaging and protocol can be determined by board_info.txt
in coreboot.
Pin 1 is marked by a small dot indent and a white paint mark. The silkscreen
may also indicate pin 1.
These can be purchased from many places for around 15 USD. Make sure that the one you get has a ROM clip. Here are some examples:
Then you can follow these steps to flash the ROM chip:
- Turn off the computer
- Unplug the AC adapter
- Remove the bottom panel
- Attach the clip to the SPI ROM chip
- Plug the CH341A into a computer with this repository built
- Verify that you can access the ROM chip, replacing
<model>
with your model:
./scripts/ch341a-dump.sh <model>
- Flash the firmware you built, replacing
<model>
with your model:
./scripts/ch341a-flash.sh <model>
SPI Pi is a Raspberry Pi used to flash the SPI ROM. To create a SPI Pi:
- Get a Raspberry Pi with Ubuntu LTS
- 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
Then you can follow these steps to flash the ROM chip:
- Turn off the computer
- Unplug the AC adapter
- 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>