This repository contain documentation and scripts that aim to help PC Engines apuX platform users and developers to customize firmware to their needs.
Since version v4.8.0.1
we changed versioning scheme skipping coreboot v4.7
release.
In recent version coreboot community introduced tag v4.8.1
this breaks our
previous versioning scheme which was v4.6.z
, where z
was PC Engines fork
patch number. Because 3rd digit was already taken by coreboot tag this breaks
our versioning scheme. As a result we start to use new versioning scheme
v4.8.0.w
, where w
will be PC Engines fork patch number as always for each
new release counted from 0.
If you take a look at coreboot tag dates:
refs/tags/4.6 Sun Apr 30 19:48:38 2017 -0600
refs/tags/4.7 Mon Jan 15 00:57:04 2018 +0000
refs/tags/4.8 Tue May 15 17:40:15 2018 +0000
refs/tags/4.8.1 Wed May 16 19:07:34 2018 +0000
After release of 4.7 we simply didn't have enough time to adjust to 4.7 before 4.8 popped up. Please note that coreboot releases are just arbitrary points in time, so trying to follow mainline in each release may make more sense, but requires decent testing.
All information about firmware releases (including changes, fixes and known issues) are available on the PC Engines Github site pcengines.github.io.
All the newest binaries can be found there.
Also please take a look at changelogs:
Since releases v4.6.10 and v4.0.17 build process has been simplified. PC Engines firmware builder is a dedicated tool to build fully featured apu firmware binaries using separated docker environment. It provides users-friendly scripts that allow to build release and custom binaries. For more information and usage details please visit: pce-fw-builder.
For releases older than v4.0.17 and v4.6.10 use the procedure described in this document
master
- keeps track of coreboot's master branchrelease
- where all releases are mergeddevelop
- where current development takes place periodically synced with coreboot masterrel_x.y.z.w
- release branches, where:x
is coreboot major versiony
is coreboot minor versionz
is coreboot patch numberw
is PC Engines firmware fork patch number counted from0
feature_branch
- sample feature branch name for workflow explanation needs
We are in favor of Test Driven Bug Fixing (TDBF).
- Create automated test that validate feature or reproduce bug - test fails at this point
- Pull
coreboot's master branch
tomaster
- Merge
master
todevelop
- Create new branch
feature_branch
fromdevelop
- Commit changes to
feature_branch
- Run regression tests and fix bugs - test written in point 1 should pass at this point
- Submit PR to
develop
- Checkout new branch
rel_x.y.z.w
from recent commit onrelease
- Merge current
develop
torel_x.y.z.w
- End of month we close merge window
- Perform automated regression testing on
rel_x.y.z.w
including all new tests - Fix all required issues and repeat point 4 until fixed - this doesn't mean all tests pass, this mean that approved set passed
- If results are accepted merge it to
release
branch - Add tag, which should trigger CI and publish binaries
- Merge release branch to develop
This option assume that your apuX is in the same networks as your PC. Your PC in this case is used as HTTP and NFS server, which will be utilized to boot apuX over iPXE.
git clone https://github.com/3mdeb/pxe-server.git
cd pxe-server
NFS_SRV_IP=<your_ip> ./init.sh
./start.sh
Please note that you may have NFS server running on host what leads to ports conflicts.
After starting NFS and HTTP you can boot apuX. Please enable network booting using sortbootorder.
iPXE> ifconf net0
iPXE> dhcp net0
iPXE> chain http://<your_ip>:8000/menu.ipxe
Choose Debian stable netboot 4.14.y
after boot login ([root:debian]
) and
for apu2/3/4/5 run:
flashrom -p internal -w apuX_x.y.z.rom
For apu1 flashrom
command line looks like that:
flashrom -p internal -w apu1_x.y.z.rom -c MX25L1605A/MX25L1606E/MX25L1608E
Some binaries may need boardmismatch=force
flashrom option because of SMBIOS
table issue we had in old releases. Please double check you flashing correct
binary before forcing.
Feel free to send pull request if you find bugs, typos or will have issues with provided procedures.