The flash.sh
script from the top-level firmware-open project will use
firmware-update, the UEFI application which is used for normal system updates.
This will flash both the SBIOS and the EC after building the firmware. To
flash just the EC, delete the built firmware.rom
before running flash.sh
.
Use this method for flashing a system already running System76 EC.
This method will only work if the running firmware is not locked. Firmware is
write locked if it was built with CONFIG_SECURITY=y
. The firmware can be
unlocked using ectool for a single boot:
./scripts/ectool.sh security unlock
This method will trigger a watchdog reset causing the system to immediately power off. OS data may be lost or corrupted as a result. Save and close all applications before flashing.
make BOARD=<vendor>/<model> flash_internal
Use this method for:
- flashing from proprietary firmware to System76 EC firmware
- flashing without risking loss of OS data
- flashing a bricked controller
This requires:
- A configured Mega 2560: For programming the EC itself
- A USB cable: For creating a common ground and providing power
- USB-C is recommended, but USB-A will work as well
- A second computer: For building and flashing the firmware
The system must not have any power!
- Turn off the laptop
- Unplug the AC adapter
- Remove the bottom panel
- Disconnect the battery
- Disconnect the keyboard from its port
- Replace the bottom panel and flip the laptop back over
- Connect the USB cable from the laptop to the host machine
- Connect the Mega 2560 to the host machine
- Attach the programmer to the keyboard port
- Flash the firmware
make BOARD=<vendor>/<model> flash_external
One of the first things it does is read the EC ID and version. If working, the ID will be the EC model the machine uses.
ID: 5570 VER: 2
ID: 8587 VER: 6
Any other values means that the Mega 2560 is misconfigured or the FPC is not seated correctly. E.g., this is wrong:
ID: FF7F VER: 127