coreboot™: fast, flexible and reproducible Open Source firmware!

Reproducible Coreboot

Reproducible builds enable anyone to reproduce bit by bit identical binary packages from a given source, so that anyone can verify that a given binary derived from the source it was said to be derived. There is more information about reproducible builds on the Debian wiki and on These pages explain in more depth why this is useful, what common issues exist and which workarounds and solutions are known.

Reproducible Coreboot is an effort to apply this to coreboot. Thus each coreboot.rom is build twice (without payloads), with a few variations added and then those two ROMs are compared using diffoscope. Please note that the toolchain is not varied at all as the rebuild happens on exactly the same system. More variations are expected to be seen in the wild.

There is a weekly run jenkins job to test the master branch of coreboot.git. The jenkins job is running in a Debian environment and this script is solely responsible for creating this page. Feel invited to join #debian-reproducible (on to request job runs whenever sensible. Patches and other feedback are very much appreciated - if you want to help, please start by looking at the ToDo list for coreboot, you might find something easy to contribute.
Thanks to Profitbricks for donating the virtual machines this is running on!

336 (100.0%) out of 336 built coreboot images were reproducible in our test setup ! These tests were last run on 2017-10-16 for version 4.6-1792-ge200c1cf6f using diffoscope 87.

variationfirst buildsecond build
hostname is not yet varied between rebuilds of coreboot.
domainname is not yet varied between rebuilds of coreboot.
env CAPTURE_ENVIRONMENTnot setCAPTURE_ENVIRONMENT="I capture the environment"
env TZTZ="/usr/share/zoneinfo/Etc/GMT+12"TZ="/usr/share/zoneinfo/Etc/GMT-14"
env LANGLANG="en_GB.UTF-8"LANG="fr_CH.UTF-8"
env LC_ALLnot setLC_ALL="fr_CH.UTF-8"
env PATHPATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:"PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path"
env USER is not yet varied between rebuilds of coreboot.
uid is not yet varied between rebuilds of coreboot.
gid is not yet varied between rebuilds of coreboot.
UTS namespace is not yet varied between rebuilds of coreboot.
kernel version, modified using /usr/bin/linux64 --uname-2.6Linux 4.9.0-4-amd64Linux 2.6.69-4-amd64
CPU type AMD Opteron 62xx class CPUsame for both builds
/bin/sh is not yet varied between rebuilds of coreboot.
year, month, datetoday (2017-10-16)same for both builds (currently, work in progress)
hour, minutehour and minute will probably vary between two builds...but this is not enforced systematically... (currently, work in progress)
Filesystemtmpfssame for both builds (currently, this could be varied using disorderfs)
everything likely the same. There will be more variations in the wild.

commit e200c1cf6f439658cc00024679b35fc46d772cad
Author: Vagiz Trakhanov 
Date:   Thu Sep 28 15:01:06 2017 +0000

    sandybridge/acpi: remove unnessary check of PCI IDs
    DRAM Controller is always 00.0. No need to check its PCI ID.
    Change-Id: I9c5f3e5658905e464491579f8da01aa6a03bd3b7
    Signed-off-by: Vagiz Tarkhanov 
    Tested-by: build bot (Jenkins) 
    Reviewed-by: Nico Huber      

cross toolchain sourcesha256sum
acpica-unix2-20161222.tar.gz bac650fd93d101a6ef2e9a30b449b32a480b0ac4f6f253c49aa80511b017b7fa
binutils-2.29.1.tar.xz e7010a46969f9d3e53b650a518663f98a5dde3c3ae21b7d71e5e6803bc36b577
elfutils-0.170.tar.bz2 1f844775576b79bdc9f9c717a50058d08620323c1e935458223a12f249c9e066
gcc-6.3.0.tar.bz2 f06ae7f3f790fbf0f018f6d40e844451e6bc3b7bc96e128e63b09825c1f8b29f
gmp-6.1.2.tar.xz 87b565e89a9a684fe4ebeeddb8399dce2599f9c9049854ca8c0dfbdea0e21912
mpc-1.0.3.tar.gz 617decc6ea09889fb08ede330917a00b16809b8db88c29c31bfbb49cbf88ecc3
mpfr-3.1.5.tar.xz 015fde82b3979fbe5f83501986d328331ba8ddf008c1ff3da3c238f49ca062bc
Debian 9.2 package on amd64installed version
gcc 4:6.3.0-4
g++ 4:6.3.0-4
make 4.1-9.1
cmake 3.7.2-1
flex 2.6.1-1.3
bison 2:3.0.4.dfsg-1+b1