summaryrefslogtreecommitdiff
path: root/resources/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'resources/scripts')
-rwxr-xr-xresources/scripts/build/boot/roms100
-rwxr-xr-xresources/scripts/build/boot/roms_helper454
-rwxr-xr-xresources/scripts/build/clean/cbutils47
-rwxr-xr-xresources/scripts/build/clean/crossgcc44
-rwxr-xr-xresources/scripts/build/clean/flashrom35
-rwxr-xr-xresources/scripts/build/clean/grub39
-rwxr-xr-xresources/scripts/build/clean/ich9utils40
-rwxr-xr-xresources/scripts/build/clean/memtest86plus35
-rwxr-xr-xresources/scripts/build/clean/payloads30
-rwxr-xr-xresources/scripts/build/clean/rom_images31
-rwxr-xr-xresources/scripts/build/clean/seabios37
-rwxr-xr-xresources/scripts/build/clean/tianocore30
-rwxr-xr-xresources/scripts/build/dependencies/arch90
-rwxr-xr-xresources/scripts/build/dependencies/ubuntu2004110
-rwxr-xr-xresources/scripts/build/descriptors/ich9m52
-rwxr-xr-xresources/scripts/build/module/cbutils78
-rwxr-xr-xresources/scripts/build/module/flashrom40
-rwxr-xr-xresources/scripts/build/module/grub49
-rwxr-xr-xresources/scripts/build/module/ich9utils40
-rwxr-xr-xresources/scripts/build/module/memtest86plus37
-rwxr-xr-xresources/scripts/build/payload/grub75
-rwxr-xr-xresources/scripts/build/payload/seabios63
-rwxr-xr-xresources/scripts/build/payload/tianocore77
-rwxr-xr-xresources/scripts/build/release/roms70
-rwxr-xr-xresources/scripts/build/release/src120
-rwxr-xr-xresources/scripts/download/coreboot226
-rwxr-xr-xresources/scripts/download/flashrom51
-rwxr-xr-xresources/scripts/download/grub57
-rwxr-xr-xresources/scripts/download/ich9utils49
-rwxr-xr-xresources/scripts/download/memtest86plus68
-rwxr-xr-xresources/scripts/download/seabios67
-rwxr-xr-xresources/scripts/download/tianocore33
-rwxr-xr-xresources/scripts/misc/versioncheck43
-rwxr-xr-xresources/scripts/update/coreboot/configs82
-rwxr-xr-xresources/scripts/update/seabios/configs64
-rwxr-xr-xresources/scripts/update/tianocore/configs55
36 files changed, 2618 insertions, 0 deletions
diff --git a/resources/scripts/build/boot/roms b/resources/scripts/build/boot/roms
new file mode 100755
index 00000000..fb57795c
--- /dev/null
+++ b/resources/scripts/build/boot/roms
@@ -0,0 +1,100 @@
+#!/bin/bash
+
+#
+# helper script: build coreboot images with various payloads
+#
+# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+projectname="$(cat projectname)"
+
+listboards() {
+ for boarddir in resources/coreboot/*; do
+ if [ ! -d "${boarddir}" ]; then continue; fi
+ board="${boarddir##resources/coreboot/}"
+ board="${board%/}"
+ printf '%s\n' "${board##*/}"
+ done
+}
+
+help() {
+ cat <<- EOF
+ USAGE: ./build boot roms boardname
+ To build *all* boards, do this: ./build boot roms all
+ To list *all* boards, do this: ./build boot roms list
+
+ possible values for 'options':
+ $(listboards)
+
+ Example: ./build boot roms x60
+ Example: ./build boot roms x200_8mb x60
+
+ Refer to the ${projectname} documentation for more information.
+ EOF
+}
+
+die() {
+ printf 'Error: %s\n' "${@}" 1>&2
+ exit 1
+}
+
+# Build ROM images for supported boards
+buildrom() {
+ board="$1"
+ if [ -d "resources/coreboot/${board}/" ]; then
+ ./build boot roms_helper "${board}"
+ else
+ die "\nbuild/roms: target not defined in the build system: %s\n" "${board}"
+ fi
+}
+
+if [ $# -gt 0 ]; then
+ firstoption="${1}"
+ if [ "${firstoption}" = "help" ]; then
+ help
+ exit 0
+ fi
+ if [ "${firstoption}" = "list" ]; then
+ listboards
+ exit 0
+ fi
+
+ printf "Building %s ROM images\n" "${projectname}"
+
+ if [ "${firstoption}" = "all" ]; then
+ for boardname in $(listboards); do
+ buildrom "${boardname}" || die "build/roms: something went wrong"
+ done
+ else
+ for board in ${@}; do
+ buildrom "${board}" || die "build/roms: something went wrong"
+ done
+ fi
+else
+ help
+ exit 1
+fi
+
+
+printf "\n\nDone! Your ROMs are in bin/\n\n"
+
diff --git a/resources/scripts/build/boot/roms_helper b/resources/scripts/build/boot/roms_helper
new file mode 100755
index 00000000..83db0766
--- /dev/null
+++ b/resources/scripts/build/boot/roms_helper
@@ -0,0 +1,454 @@
+#!/bin/bash
+
+# helper script: create ROM images for a given mainboard
+#
+# Copyright (C) 2020,2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+projectname="$(cat projectname)"
+
+if (( $# != 1 )); then
+ printf "Usage: ./build boot roms boardname\n"
+ printf "Example: ./build boot roms x60\n"
+ printf "Example: ./build boot roms x60 x200_8mb\n"
+ printf "Example: ./build boot roms all\n"
+ printf "You need to specify exactly 1 argument\n"
+ exit 1
+fi
+
+board="${1}"
+
+if [ ! -d "resources/coreboot/${board}" ]; then
+ printf "build/roms: Target %s does not exist in the %s build system. Skipping build.\n" "${projectname}" "${board}"
+ exit 1
+fi
+
+if [ ! -f "resources/coreboot/${board}/board.cfg" ]; then
+ printf "build/roms: Target %s does not have a board.cfg. Skipping build.\n" "${board}"
+ exit 1
+fi
+
+cbtree="undefined"
+romtype="normal" # optional parameter in board.cfg. "normal" is default
+arch="undefined"
+# Disable all payloads by default.
+# board.cfg files have to specifically enable [a] payload(s)
+payload_grub="n"
+payload_grub_withseabios="n" # seabios chainloaded from grub
+payload_grub_withtianocore="n" # tianocore chainloaded from grub
+payload_seabios="n"
+payload_seabios_withgrub="n" # i386-coreboot grub accessible from SeaBIOS boot menu
+payload_tianocore="n"
+seabios_opromloadonly="0"
+# Override the above defaults using board.cfg
+source "resources/coreboot/${board}/board.cfg"
+if [ "${cbtree}" = "undefined" ]; then
+ printf "build/roms: Target %s does not define a coreboot tree. Skipping build.\n" "${board}"
+ exit 1
+fi
+if [ "${arch}" = "undefined" ]; then
+ printf "build/roms: Target %s does not define a CPU type. Skipping build.\n" "${board}"
+ exit 1
+fi
+
+if [ "${seabios_opromloadonly}" != "0" ] && \
+ [ "${seabios_opromloadonly}" != "1" ]; then
+ seabios_opromloadonly="0"
+fi
+if [ "${payload_grub_withseabios}" = "y" ] \
+ || [ "${payload_grub_withtianocore}" = "y" ]; then
+ payload_grub="y"
+fi
+if [ "${payload_grub_withseabios}" = "y" ]; then
+ payload_seabios="y"
+ payload_seabios_withgrub="y" # if grub-first works, then seabios-with-grub will also work
+fi
+if [ "${payload_seabios_withgrub}" = "y" ]; then
+ payload_seabios="y" # if seabios-with-grub works, then SeaBIOS-alone should also work
+fi
+# NOTE: reverse logic must not be applied. If SeaBIOS-with-GRUB works, that doesn't
+# necessarily mean GRUB-with-SeaBIOS will work nicely. for example, the board might
+# only have an add-on GPU available, where it's recommended to boot SeaBIOS first
+if [ "${payload_grub_withtianocore}" = "y" ]; then
+ payload_tianocore="y"
+fi
+if [ "${payload_grub}" != "y" ] && [ "${payload_seabios}" != "y" ] \
+ && [ "${payload_tianocore}" != "y" ]; then
+ while true; do
+ for configfile in "resources/coreboot/${board}/config/"*; do
+ if [ -f "${configfile}" ]; then
+ printf "ERROR build/roms: Target '%s' does not define a payload. Exiting.\n" "${board}"
+ exit 1
+ fi
+ done
+ break
+ done
+fi
+
+if [ ! -f "memtest86plus/memtest" ]; then
+ ./build module memtest86plus
+fi
+
+romdir="bin/${board}"
+cbdir="coreboot/${board}"
+if [ "${board}" != "${cbtree}" ]; then
+ cbdir="coreboot/${cbtree}"
+fi
+cbfstool="${cbdir}/util/cbfstool/cbfstool"
+corebootrom="${cbdir}/build/coreboot.rom"
+seavgabiosrom="payload/seabios/seavgabios.bin"
+tianocoreelf="payload/tianocore/tianocore.elf"
+
+if [ ! -d "${cbdir}" ]; then
+ ./download coreboot ${cbtree}
+fi
+
+if [ "${arch}" = "x86_32" ] || [ "${arch}" = "x86_64" ]; then
+ if [ ! -d "${cbdir}/util/crossgcc/xgcc/i386-elf/" ]; then
+ (
+ cd "${cbdir}"
+ make crossgcc-i386 CPUS=$(nproc) # even for 64-bit machines, coreboot builds
+ # 32-bit ROM images, so we only need to worry about i386-elf
+ )
+ fi
+fi
+
+if [ "${arch}" != "x86_64" ]; then
+ payload_tianocore="n"
+ payload_grub_withtianocore="n"
+fi
+
+if [ ! -f "${cbfstool}" ]; then
+ ./build module cbutils ${cbtree}
+fi
+
+if [ ! -f "${tianocoreelf}" ]; then
+ if [ "${payload_tianocore}" = "y" ]; then
+ ./build payload tianocore
+ elif [ "${payload_grub}" = "y" ] \
+ && [ "${payload_grub_withtianocore}" = "y" ]; then
+ ./build payload tianocore
+ fi
+fi
+
+if [ ! -f "${seavgabiosrom}" ] \
+ || [ ! -f payload/seabios/seabios_libgfxinit.elf ] \
+ || [ ! -f payload/seabios/seabios_vgarom.elf ]; then
+ if [ "${payload_seabios}" = "y" ]; then
+ ./build payload seabios
+ elif [ "${payload_grub}" = "y" ] \
+ && [ "${payload_grub_withseabios}" = "y" ]; then
+ ./build payload seabios
+ fi
+fi
+
+[ -d "${romdir}/" ] || mkdir -p "${romdir}/"
+rm -f "${romdir}"/*
+
+if [ "${payload_grub}" = "y" ] || [ "${payload_seabios_withgrub}" = "y" ]; then
+ if [ -f "payload/grub/grub_usqwerty.cfg" ]; then
+ grubrefchecksum="$(sha1sum resources/grub/config/grub.cfg)"
+ grubrefchecksum="${grubrefchecksum% resources/grub/config/grub.cfg}"
+ grubbuildchecksum="$(sha1sum payload/grub/grub_usqwerty.cfg)"
+ grubbuildchecksum="${grubbuildchecksum% payload/grub/grub_usqwerty.cfg}"
+ if [ "${grubrefchecksum}" != "${grubbuildchecksum}" ]; then
+ rm -Rf payload/grub/
+ printf "Changes detected to GRUB. Re-building now:\n"
+ fi
+ else
+ printf "Required GRUB payloads not yet built. Building now:\n"
+ rm -Rf payload/grub/ # just in case
+ fi
+ for keymapfile in resources/grub/keymap/*; do
+
+ if [ ! -f "${keymapfile}" ]; then
+ continue
+ fi
+
+ keymap="${keymapfile##*/}"
+ keymap="${keymap%.gkb}"
+
+ grubelf="payload/grub/grub_${keymap}.elf"
+ grubcfg="payload/grub/grub_${keymap}.cfg"
+ grubtestcfg="payload/grub/grub_${keymap}_test.cfg"
+
+ if [ ! -f "${grubelf}" ] || [ ! -f "${grubcfg}" ] || \
+ [ ! -f "${grubtestcfg}" ]; then
+ ./build payload grub
+ fi
+ done
+fi
+
+# it is assumed that no other work will be done on the ROM
+# after calling this function. therefore this function is "final"
+moverom() {
+ rompath="$1"
+ newrompath="$2"
+ cuttype="$3"
+
+ printf "\nCreating new ROM image: %s\n" "${newrompath}"
+
+ if [ "${cuttype}" = "4MiB IFD BIOS region" ]; then
+ dd if=${rompath} of=${newrompath} bs=1 skip=$[$(stat -c %s ${rompath}) - 0x400000] count=4194304
+ else
+ cp ${rompath} ${newrompath}
+ fi
+
+ for romsize in 4 8 16; do
+ if [ "${cuttype}" = "${romsize}MiB ICH9 IFD NOR flash" ]; then
+ if [ ! -f "descriptors/ich9m/ich9fdgbe_${romsize}m.bin" ]; then
+ ./build descriptors ich9m
+ fi
+ dd if=descriptors/ich9m/ich9fdgbe_${romsize}m.bin of=${newrompath} bs=1 count=12k conv=notrunc
+ fi
+ if [ "${cuttype}" = "${romsize}MiB ICH9 IFD NOGBE NOR flash" ]; then
+ if [ ! -f "descriptors/ich9m/ich9fdnogbe_${romsize}m.bin" ]; then
+ ./build descriptors ich9m
+ fi
+ dd if=descriptors/ich9m/ich9fdnogbe_${romsize}m.bin of=${newrompath} bs=1 count=4k conv=notrunc
+ fi
+ done
+
+ if [ "${cuttype}" = "i945 laptop" ]; then
+ dd if=${newrompath} of=top64k.bin bs=1 skip=$[$(stat -c %s ${newrompath}) - 0x10000] count=64k
+ dd if=top64k.bin of=${newrompath} bs=1 seek=$[$(stat -c %s ${newrompath}) - 0x20000] count=64k conv=notrunc
+ rm -f top64k.bin
+ fi
+}
+
+# expected: configs must not specify a payload
+mkCoreboot() {
+ cbdir="${1}" # e.g. coreboot/default
+ cbcfgpath="${2}" # e.g. resources/coreboot/x200_8mb/config/libgfxinit_txtmode
+ if [ ! -f "${cbcfgpath}" ]; then
+ printf "\nmkCoreboot: Coreboot config '%s' does not exist. Skipping build.\n" \
+ "${cbcfgpath}"
+ return 0
+ fi
+ printf "%s-%s\n" "$(cat projectname)" "$(cat version)" > "${cbdir}/.coreboot-version"
+ (
+ cd "${cbdir}"
+ make distclean
+ )
+ cp "${cbcfgpath}" "${cbdir}"/.config
+ (
+ cd "${cbdir}"
+ make -j$(nproc)
+ )
+}
+
+mkRomWithTianocoreOnly() {
+ rompath="${1}"
+ initmode="${2}"
+ if [ "${payload_tianocore}" = "y" ] && [ "${arch}" = "x86_64" ]; then
+ # do not include on 32-bit-only machines. this is 64-bit tianocore
+
+ tmprom=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+ cp "${corebootrom}" "${tmprom}"
+ "${cbfstool}" "${tmprom}" add-payload -f ${tianocoreelf} -n fallback/payload -c lzma
+ moverom "${tmprom}" "${romdir}/tianocore_${board}_${initmode}.rom" "${romtype}"
+ rm -f "${tmprom}"
+ fi
+}
+
+# make a rom in /tmp/ and then print the path of that ROM
+make_seabios_rom() {
+ target_cbrom="${1}" # rom to insert seabios in. this rom won't be touched
+ # a tmpfile will be made instead
+ target_seabios_cbfs_path="${2}" # e.g. fallback/payload
+ target_opromloadonly="${3}" # 0 or 1. if 1, only load but don't execute oproms
+ target_initmode="${4}" # e.g. libgfxinit
+ cbfstool_path="${5}"
+
+ if [ "${target_initmode}" = "normal" ]; then
+ target_seabioself="payload/seabios/seabios_vgarom.elf"
+ # if normal, etc/pci-optionrom-exec will be set to 2
+ else
+ target_seabioself="payload/seabios/seabios_${target_initmode}.elf"
+ # if libgfxinit, etc/pci-optionrom-exec will be set to 2
+ # if vgarom, etc/pci-optionrom-exec will be set to 0
+ fi
+ target_seavgabios_rom="payload/seabios/seavgabios.bin"
+
+ tmprom=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+
+ cp "${target_cbrom}" "${tmprom}"
+ "${cbfstool}" "${tmprom}" add-payload -f "${target_seabioself}" -n ${target_seabios_cbfs_path} -c lzma
+ "${cbfstool}" "${tmprom}" add-int -i 3000 -n etc/ps2-keyboard-spinup
+ if [ "${target_initmode}" = "normal" ] || [ "${target_initmode}" = "libgfxinit" ]; then
+ "${cbfstool}" "${tmprom}" add-int -i 2 -n etc/pci-optionrom-exec
+ elif [ "${target_initmode}" = "vgarom" ]; then
+ "${cbfstool}" "${tmprom}" add-int -i 0 -n etc/pci-optionrom-exec
+ fi # for undefined modes, don't add this integer. rely on SeaBIOS defaults
+ "${cbfstool}" "${tmprom}" add-int -i 0 -n etc/optionroms-checksum
+ "${cbfstool}" "${tmprom}" add-int -i ${target_opromloadonly} -n etc/only-load-option-roms
+
+ if [ "${target_initmode}" = "libgfxinit" ]; then
+ "${cbfstool_path}" "${tmprom}" add -f "${target_seavgabios_rom}" -n vgaroms/seavgabios.bin -t raw
+ fi
+
+ printf "%s\n" "${tmprom}"
+}
+
+# make a rom in /tmp/ and then print the path of that ROM
+make_grubrom_from_keymap() {
+ target_keymap="${1}"
+ target_cbrom="${2}"
+ cbfstool_path="${3}"
+ target_grubelf_cbfs_path="${4}" # e.g. fallback/payload
+
+ grubelf="payload/grub/grub_${target_keymap}.elf"
+ grubcfg="payload/grub/grub_${target_keymap}.cfg"
+ grubtestcfg="payload/grub/grub_${target_keymap}_test.cfg"
+
+ tmprom=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+ cp "${target_cbrom}" "${tmprom}"
+
+ "${cbfstool_path}" "${tmprom}" add-payload -f "${grubelf}" -n ${target_grubelf_cbfs_path} -c lzma
+ "${cbfstool_path}" "${tmprom}" add -f "${grubcfg}" -n grub.cfg -t raw
+ "${cbfstool_path}" "${tmprom}" add -f "${grubtestcfg}" -n grubtest.cfg -t raw
+
+ printf "%s\n" "${tmprom}"
+}
+
+# Make separate ROM images with GRUB payload, for each supported keymap
+mkRomsWithGrub() {
+ tmprompath="${1}"
+ initmode="${2}"
+ displaymode="${3}"
+ firstpayloadname="${4}" # allow values: grub, seabios, seabios_withgrub, seabios_grubfirst
+
+ if [ "${payload_grub_withtianocore}" = "y" ] && [ "${firstpayloadname}" = "grub" ]; then
+ "${cbfstool}" "${tmprompath}" add-payload -f ${tianocoreelf} -n tianocore.elf -c lzma
+ fi
+
+ if [ "${payload_grub_withseabios}" = "y" ] && [ "${firstpayloadname}" = "grub" ]; then
+ mv "$(make_seabios_rom "${tmprompath}" "seabios.elf" "${seabios_opromloadonly}" "${initmode}" "${cbfstool}")" "${tmprompath}"
+ elif [ "${payload_seabios_withgrub}" ] && [ "${firstpayloadname}" != "grub" ]; then
+ mv "$(make_seabios_rom "${tmprompath}" "fallback/payload" "${seabios_opromloadonly}" "${initmode}" "${cbfstool}")" "${tmprompath}"
+ if [ "${firstpayloadname}" = "seabios_grubfirst" ]; then
+ tmpbootorder=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+ printf "/rom@img/grub2\n" > "${tmpbootorder}"
+ "${cbfstool}" "${tmprompath}" add -f "${tmpbootorder}" -n bootorder -t raw
+ rm -f "${tmpbootorder}"
+ "${cbfstool}" "${tmprompath}" add-int -i 0 -n etc/show-boot-menu
+ fi
+ fi
+
+ for keymapfile in resources/grub/keymap/*; do
+
+ if [ ! -f "${keymapfile}" ]; then
+ continue
+ fi
+
+ keymap="${keymapfile##*/}"
+ keymap="${keymap%.gkb}"
+
+ grub_path_in_cbfs="fallback/payload"
+ if [ "${firstpayloadname}" != "grub" ]; then
+ grub_path_in_cbfs="img/grub2"
+ fi
+
+ tmpgrubrom="$(make_grubrom_from_keymap "${keymap}" "${tmprompath}" "${cbfstool}" "${grub_path_in_cbfs}")"
+ if [ "${initmode}" = "normal" ]; then
+ newrompath="${romdir}/${firstpayloadname}_${board}_${initmode}_${keymap}.rom"
+ else
+ newrompath="${romdir}/${firstpayloadname}_${board}_${initmode}_${displaymode}_${keymap}.rom"
+ fi
+ moverom "${tmpgrubrom}" "${newrompath}" "${romtype}"
+ rm -f "${tmpgrubrom}"
+ done
+}
+
+# Main ROM building function. This calls all other functions
+mkRoms() {
+ tianocoreRequiredDisplayMode="${1}"
+ cbcfgpath="${2}"
+ displaymode="${3}"
+ initmode="${4}"
+
+ if [ ! -f "${cbcfgpath}" ]; then
+ printf "'%s' does not exist. Skipping build for %s %s %s\n" \
+ "${cbcfgpath}" "${board}" "${displaymode}" "${initmode}"
+ return 0
+ fi
+
+ mkCoreboot "${cbdir}" "${cbcfgpath}"
+
+ if [ "${displaymode}" = "${tianocoreRequiredDisplayMode}" ]; then
+ mkRomWithTianocoreOnly "${corebootrom}" "${initmode}"
+ fi
+
+ if [ "${displaymode}" = "txtmode" ]; then
+ "${cbfstool}" "${corebootrom}" add-payload -f memtest86plus/memtest -n img/memtest -c lzma
+ fi
+
+ if [ "${payload_seabios}" = "y" ]; then
+ if [ "${payload_seabios_withgrub}" = "n" ]; then
+ tmpseabiosrom="$(make_seabios_rom "${corebootrom}" "fallback/payload" "${seabios_opromloadonly}" "${initmode}" "${cbfstool}")"
+ if [ "${initmode}" = "normal" ]; then
+ newrompath="${romdir}/seabios_${board}_${initmode}.rom"
+ else
+ newrompath="${romdir}/seabios_${board}_${initmode}_${displaymode}.rom"
+ fi
+
+ moverom "${tmpseabiosrom}" "${newrompath}" "${romtype}"
+ rm -f "${tmpseabiosrom}"
+ else
+ tmprom=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+ cp "${corebootrom}" "${tmprom}"
+ mkRomsWithGrub "${tmprom}" "${initmode}" "${displaymode}" "seabios_withgrub"
+ cp "${corebootrom}" "${tmprom}"
+ mkRomsWithGrub "${tmprom}" "${initmode}" "${displaymode}" "seabios_grubfirst"
+ rm -f "${tmprom}"
+ fi
+ fi
+
+ if [ "${payload_grub}" = "y" ]; then
+ mkRomsWithGrub "${corebootrom}" "${initmode}" "${displaymode}" "grub"
+ fi
+}
+
+initmode="libgfxinit"
+tianocoreRequiredDisplayMode="corebootfb"
+for displaymode in corebootfb txtmode; do
+ cbcfgpath="resources/coreboot/${board}/config/${initmode}_${displaymode}"
+ mkRoms "${tianocoreRequiredDisplayMode}" "${cbcfgpath}" "${displaymode}" "${initmode}"
+done
+
+initmode="vgarom"
+tianocoreRequiredDisplayMode="vesafb"
+for displaymode in vesafb txtmode; do
+ cbcfgpath="resources/coreboot/${board}/config/${initmode}_${displaymode}"
+ mkRoms "${tianocoreRequiredDisplayMode}" "${cbcfgpath}" "${displaymode}" "${initmode}"
+done
+
+initmode="normal"
+displaymode="txtmode"
+tianocoreRequiredDisplayMode="unsupported"
+cbcfgpath="resources/coreboot/${board}/config/${initmode}"
+mkRoms "${tianocoreRequiredDisplayMode}" "${cbcfgpath}" "${displaymode}" "${initmode}"
+
+(
+cd "${cbdir}"
+make distclean
+)
diff --git a/resources/scripts/build/clean/cbutils b/resources/scripts/build/clean/cbutils
new file mode 100755
index 00000000..b908e1bf
--- /dev/null
+++ b/resources/scripts/build/clean/cbutils
@@ -0,0 +1,47 @@
+#!/bin/bash
+
+# helper script: clean the dependencies that were built in coreboot
+#
+# Copyright (C) 2014, 2015, 2016, 2020 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# clean coreboot utilities (dependencies for 'build'):
+
+printf "Cleaning the previous build of coreboot and its utilities\n"
+
+[ ! -d "coreboot/" ] && exit 0
+
+for board in coreboot/*; do
+ if [ "${board##*/}" = "coreboot" ]; then
+ continue
+ fi
+ # Clean coreboot, of course
+ make -C "${board}/" distclean
+
+ # Clean its utilities as well
+ for util in {cbfs,ifd,nvram}tool cbmem; do
+ make -C "${board}/util/${util}/" clean
+ done
+ make -C "${board}/payloads/libpayload/" distclean
+done
+
+printf "\n\n"
diff --git a/resources/scripts/build/clean/crossgcc b/resources/scripts/build/clean/crossgcc
new file mode 100755
index 00000000..a855d203
--- /dev/null
+++ b/resources/scripts/build/clean/crossgcc
@@ -0,0 +1,44 @@
+#!/bin/bash
+
+# helper script: clean the crossgcc builds
+#
+# Copyright (C) 2014, 2015, 2016, 2020 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# clean coreboot utilities (dependencies for 'build'):
+
+printf "Cleaning crossgcc builds in all coreboot archives\n"
+
+[ ! -d "coreboot/" ] && exit 0
+
+# clean coreboot and crossgcc (source archives preserved)
+for board in coreboot/*; do
+ if [ "${board##*/}" = "coreboot" ]; then
+ continue
+ fi
+ if [ ! -d "${board}" ]; then
+ continue
+ fi
+ make -C "${board}/" crossgcc-clean
+done
+
+printf "\n\n"
diff --git a/resources/scripts/build/clean/flashrom b/resources/scripts/build/clean/flashrom
new file mode 100755
index 00000000..2a13bdb2
--- /dev/null
+++ b/resources/scripts/build/clean/flashrom
@@ -0,0 +1,35 @@
+#!/bin/bash
+
+# helper script: clean the dependencies that were built in flashrom
+#
+# Copyright (C) 2014, 2015 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Cleaning the previous build of flashrom\n"
+
+[ ! -d "flashrom/" ] && exit 0
+
+# clean flashrom
+make -C flashrom clean
+
+printf "\n\n"
diff --git a/resources/scripts/build/clean/grub b/resources/scripts/build/clean/grub
new file mode 100755
index 00000000..ec6cab13
--- /dev/null
+++ b/resources/scripts/build/clean/grub
@@ -0,0 +1,39 @@
+#!/bin/bash
+
+# helper script: clean the dependencies that were built in GRUB
+#
+# Copyright (C) 2014, 2015, 2016 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Cleaning the previous build of GRUB\n"
+
+[ ! -d "grub/" ] && exit 0
+
+(
+ cd grub/
+ if [ -f Makefile ]; then
+ make distclean
+ fi
+)
+
+printf "\n\n"
diff --git a/resources/scripts/build/clean/ich9utils b/resources/scripts/build/clean/ich9utils
new file mode 100755
index 00000000..c2c0aede
--- /dev/null
+++ b/resources/scripts/build/clean/ich9utils
@@ -0,0 +1,40 @@
+#!/usr/bin/env bash
+
+# helper script: clean the previous build of ich9utils
+#
+# Copyright (C) 2014, 2015, 2020 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of libreboot_src or libreboot git
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# clean ich9deblob utility
+# --------------------------------------------------------------------
+
+if [ ! -d ich9utils ]; then
+ exit 0
+fi
+
+printf "Cleaning the previous build of ich9utils\n"
+(
+cd "ich9utils/"
+make clean
+)
+rm -Rf descriptors/
+printf "\n\n"
diff --git a/resources/scripts/build/clean/memtest86plus b/resources/scripts/build/clean/memtest86plus
new file mode 100755
index 00000000..13155496
--- /dev/null
+++ b/resources/scripts/build/clean/memtest86plus
@@ -0,0 +1,35 @@
+#!/bin/bash
+
+# helper script: clean the dependencies that were built in memtest86+
+#
+# Copyright (C) 2014, 2015 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Cleaning the previous build of MemTest86+\n"
+
+[ ! -d "memtest86plus" ] && exit 0
+
+# clean MemTest86+
+make -C memtest86plus clean
+
+printf "\n\n"
diff --git a/resources/scripts/build/clean/payloads b/resources/scripts/build/clean/payloads
new file mode 100755
index 00000000..a2abe195
--- /dev/null
+++ b/resources/scripts/build/clean/payloads
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+# helper script: nothing to see here, forks!
+#
+# Copyright (C) 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# clean bucts
+# --------------------------------------------------------
+
+printf "Cleaning up payloads\n"
+
+rm -Rf payload/
+
diff --git a/resources/scripts/build/clean/rom_images b/resources/scripts/build/clean/rom_images
new file mode 100755
index 00000000..abf352d0
--- /dev/null
+++ b/resources/scripts/build/clean/rom_images
@@ -0,0 +1,31 @@
+#!/bin/bash
+
+# helper script: delete the ROM images
+#
+# Copyright (C) 2014, 2015 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Delete the ROM images
+rm -Rf "bin/"
+
+printf "Deleted the bin/ directory containing the ROM images.\n\n"
diff --git a/resources/scripts/build/clean/seabios b/resources/scripts/build/clean/seabios
new file mode 100755
index 00000000..eef72a89
--- /dev/null
+++ b/resources/scripts/build/clean/seabios
@@ -0,0 +1,37 @@
+#!/bin/bash
+
+# helper script: clean the dependencies that were built in seabios
+#
+# Copyright (C) 2015, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# clean bucts
+# --------------------------------------------------------
+
+printf "Cleaning the previous build of seabios\n"
+
+rm -f seabios_libgfxinit.elf seavgabios.bin seabios_vgarom.elf
+
+[ ! -d "seabios/" ] && exit 0
+
+(
+cd "seabios/"
+make distclean
+)
+
diff --git a/resources/scripts/build/clean/tianocore b/resources/scripts/build/clean/tianocore
new file mode 100755
index 00000000..a57d986e
--- /dev/null
+++ b/resources/scripts/build/clean/tianocore
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+# Copyright (C) 2020 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+if [ -d "coreboot/default/payloads/external/tianocore/tianocore" ]; then
+ (
+ cd "coreboot/default/payloads/external/tianocore/"
+ make clean
+ )
+fi
diff --git a/resources/scripts/build/dependencies/arch b/resources/scripts/build/dependencies/arch
new file mode 100755
index 00000000..0a09b75a
--- /dev/null
+++ b/resources/scripts/build/dependencies/arch
@@ -0,0 +1,90 @@
+#!/bin/bash
+
+# arch script: installs build dependencies for Arch Linux
+#
+# Copyright (C) 2021 Melissa Goad <mszoopers@protonmail.com>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+if [ $EUID -ne 0 ]; then
+ printf "This script must be run as root\n"
+ exit 1
+fi
+
+# Duplications are intentional. Please do not re-factor.
+#
+# This is so that they can moved to separate scripts.
+#
+
+pacman -S --needed --noconfirm wget
+
+# For downloading source code
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm git
+
+# For building the documentation
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm pandoc
+
+# For Tianocore and iPXE
+# TODO: check whether this is the full list
+
+pacman -S --needed --noconfirm nasm perl-libwww python2 subversion
+
+# For building source code:
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm base-devel
+
+# for running the crostool script (to get mrc.bin file for t440p)
+pacman -S --needed --noconfirm sharutils curl parted e2fsprogs unzip
+
+# for cross-compiling ARM binaries
+pacman -S --needed --noconfirm arm-none-eabi-gcc
+
+# Memtest86+ build dependencies
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm base-devel python2
+
+# i945-pwm build dependencies
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm base-devel perl
+
+# Coreboot build dependencies (also requires build-essential and git)
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm ncurses doxygen acpica gdb flex bison base-devel git openssl gcc-ada
+
+# GRUB build dependencies (also requires build-essential, bison and flex)
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm bdf-unifont autogen help2man base-devel bison flex ttf-dejavu texinfo rsync python libusb xz gawk device-mapper fuse2 gettext freetype2
+
+# BucTS build dependencies (external script)
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm base-devel
+
+# Flashrom build dependencies (also requires build-essential)
+# ------------------------------------------------------------
+
+pacman -S --needed --noconfirm libpciaccess pciutils zlib libftdi base-devel libusb
diff --git a/resources/scripts/build/dependencies/ubuntu2004 b/resources/scripts/build/dependencies/ubuntu2004
new file mode 100755
index 00000000..df11b313
--- /dev/null
+++ b/resources/scripts/build/dependencies/ubuntu2004
@@ -0,0 +1,110 @@
+#!/bin/bash
+
+# ubuntu2004 script: installs build dependencies for Ubuntu 20.04
+#
+# Copyright (C) 2014, 2015 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+if [ $EUID -ne 0 ]; then
+ printf "This script must be run as root\n"
+ exit 1
+fi
+
+# Duplications are intentional. Please do not re-factor.
+#
+# This is so that they can moved to separate scripts.
+#
+
+apt-get -y install wget
+
+# For downloading source code
+# ------------------------------------------------------------
+
+apt-get -y install git
+
+# For building the documentation
+# ------------------------------------------------------------
+
+apt-get -y install pandoc
+
+# For Tianocore and iPXE
+# TODO: check whether this is the full list
+
+apt-get -y install uuid-dev nasm
+
+# For building source code:
+# ------------------------------------------------------------
+
+apt-get -y install build-essential
+
+# for running the crostool script (to get mrc.bin file for t440p)
+apt-get -y install sharutils curl parted e2fsprogs unzip
+
+# to use the right software versions and links for compiling
+apt-get -y install pkg-config
+
+# for cross-compiling ARM binaries
+apt-get -y install gcc-arm-linux-gnueabi
+
+[ "$(uname -i)" = x86_64 ] || [ "$(uname -m)" = x86_64 ]
+arch=${?}
+
+# For cross-compiling i686 target on x86_64 host.
+if [ "${arch}" -eq 0 ]; then
+ apt-get -y install gcc-multilib libc6-i386 libc6-dev-i386
+ apt-get -y install lib32stdc++6 g++-multilib dh-autoreconf
+ # recommended, but not sure what for:
+ apt-get -y install lib32tinfo-dev
+fi
+
+# Memtest86+ build dependencies
+# ------------------------------------------------------------
+
+apt-get -y install build-essential python2.7
+
+# i945-pwm build dependencies
+# ------------------------------------------------------------
+
+apt-get -y install build-essential perl
+
+# Coreboot build dependencies (also requires build-essential and git)
+# ------------------------------------------------------------
+
+apt-get -y install libncurses5-dev doxygen iasl gdb flex bison build-essential git libssl-dev gnat
+
+# For cross-compiling i686 target on x86_64 host.
+[ "${arch}" -eq 0 ] && apt-get -y install lib32ncurses5-dev
+
+# GRUB build dependencies (also requires build-essential, bison and flex)
+# ------------------------------------------------------------
+
+apt-get -y install ttf-unifont libopts25 libselinux1-dev autogen m4 autoconf help2man libopts25-dev libfont-freetype-perl automake autotools-dev build-essential bison flex libfuse-dev liblzma-dev gawk libdevmapper-dev libtool libfreetype6-dev
+
+# BucTS build dependencies (external script)
+# ------------------------------------------------------------
+
+apt-get -y install build-essential
+
+# Flashrom build dependencies (also requires build-essential)
+# ------------------------------------------------------------
+
+apt-get -y install libpci-dev pciutils zlib1g-dev libftdi-dev build-essential libusb-1.0-0-dev libusb-1.0 libusb-1.0-0-dev libusb-dev
+
+# For cross-compiling i686 target on x86_64 host.
+[ "${arch}" -eq 0 ] && apt-get -y install lib32z1-dev
diff --git a/resources/scripts/build/descriptors/ich9m b/resources/scripts/build/descriptors/ich9m
new file mode 100755
index 00000000..69359988
--- /dev/null
+++ b/resources/scripts/build/descriptors/ich9m
@@ -0,0 +1,52 @@
+#!/usr/bin/env bash
+
+# Copyright (C) 2020 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of libreboot_src or libreboot git
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+if [ ! -d ich9utils ]; then
+ ./download ich9utils
+fi
+if [ ! -d ich9utils ]; then
+ printf "build/descriptors/ich9m: no ich9utils directory. Exiting\n"
+ exit 1
+fi
+
+if [ ! -f "ich9utils/ich9gen" ]; then
+ (
+ cd ich9utils/
+ make clean
+ make -j$(nproc)
+ )
+fi
+if [ ! -f "ich9utils/ich9gen" ]; then
+ printf "build/descriptors/ich9m: ich9gen wasn't compiled. Exiting\n"
+ exit 1
+fi
+
+[ -d "descriptors/" ] || mkdir -p "descriptors/"
+[ -d "descriptors/ich9m/" ] || mkdir -p "descriptors/ich9m/"
+rm -f descriptors/ich9m/*
+
+(
+ cd descriptors/ich9m/
+ ../../ich9utils/ich9gen
+)
diff --git a/resources/scripts/build/module/cbutils b/resources/scripts/build/module/cbutils
new file mode 100755
index 00000000..5198656c
--- /dev/null
+++ b/resources/scripts/build/module/cbutils
@@ -0,0 +1,78 @@
+#!/bin/bash
+
+# helper script: build various coreboot utilities
+#
+# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Building coreboot utils\n"
+
+buildutils() {
+ cbtree="${1}"
+ if [ ! -d "coreboot/${cbtree}/" ]; then
+ ./download coreboot $cbtree || return 1
+ fi
+ if [ ! -d "coreboot/${cbtree}/" ]; then
+ printf "build/cbutils: coreboot/%s not found. Exiting\n" "${cbtree}"
+ return 1
+ fi
+ for util in {cbfs,ifd}tool; do
+ (
+ cd "coreboot/${cbtree}/util/${util}/"
+ make -j$(nproc) || return 1
+ )
+ done
+ return 0
+}
+
+buildfromboardconfig() {
+ board="${1}"
+ if [ ! -d "resources/coreboot/${board}" ]; then
+ continue
+ fi
+ if [ ! -f "resources/coreboot/${board}/board.cfg" ]; then
+ continue
+ fi
+ cbtree="undefined"
+ source "resources/coreboot/${board}/board.cfg"
+ if [ "${cbtree}" = "undefined" ]; then
+ printf "build/cbutils: improper cbtree definition for '%s'" "${board}"
+ return 1
+ fi
+ buildutils "${cbtree}" || return 1
+ return 0
+}
+
+if [ $# -gt 0 ]; then
+ for board in "${@}"; do
+ buildfromboardconfig ${board} || exit 1
+ done
+else
+ for boarddir in resources/coreboot/*; do
+ if [ ! -d "${boarddir}" ]; then
+ continue
+ fi
+ buildfromboardconfig ${boarddir##*/} || exit 1
+ done
+fi
+
+printf "\n\n"
+exit 0
diff --git a/resources/scripts/build/module/flashrom b/resources/scripts/build/module/flashrom
new file mode 100755
index 00000000..807be1b2
--- /dev/null
+++ b/resources/scripts/build/module/flashrom
@@ -0,0 +1,40 @@
+#!/bin/bash
+
+# helper script: builds flashrom source code
+#
+# Copyright (C) 2014, 2015 <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Build "flashrom" (utility for flashing/dumping ROMs)
+# --------------------------------------------------------------------
+
+if [ ! -d "flashrom/" ]; then
+ ./download flashrom
+fi
+
+printf "Building flashrom\n"
+(
+cd "flashrom/"
+make clean
+make -j$(nproc)
+)
diff --git a/resources/scripts/build/module/grub b/resources/scripts/build/module/grub
new file mode 100755
index 00000000..54696cb4
--- /dev/null
+++ b/resources/scripts/build/module/grub
@@ -0,0 +1,49 @@
+#!/bin/bash
+
+# helper script: builds GRUB2 source code
+#
+# Copyright (C) 2014, 2015, 2020 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015, 2016 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Build GRUB2 as coreboot payload
+
+printf "Building GRUB\n"
+
+if [ ! -d "grub/" ]; then
+ ./download grub
+fi
+
+# use a subshell to not end up in grub/ in case of build issues
+(
+cd grub/
+
+# clean up first
+[ -d Makefile ] && make distclean
+
+./bootstrap --gnulib-srcdir=gnulib/ --no-git
+
+# build
+./autogen.sh
+./configure --with-platform=coreboot
+make -j$(nproc)
+)
diff --git a/resources/scripts/build/module/ich9utils b/resources/scripts/build/module/ich9utils
new file mode 100755
index 00000000..40e1c8e6
--- /dev/null
+++ b/resources/scripts/build/module/ich9utils
@@ -0,0 +1,40 @@
+#!/usr/bin/env bash
+
+# helper script: build ich9utils
+#
+# Copyright (C) 2014, 2015, 2020 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the current working directory is the root
+# of libreboot_src or libreboot git
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+if [ ! -d ich9utils ]; then
+ ./download ich9utils
+fi
+if [ ! -d ich9utils ]; then
+ printf "build/module/ich9utils: ich9utils not found. Exiting\n"
+ exit 1
+fi
+
+printf "Build ich9utils\n"
+(
+cd "ich9utils/"
+make -j$(nproc)
+)
+printf "\n\n"
diff --git a/resources/scripts/build/module/memtest86plus b/resources/scripts/build/module/memtest86plus
new file mode 100755
index 00000000..50f130e9
--- /dev/null
+++ b/resources/scripts/build/module/memtest86plus
@@ -0,0 +1,37 @@
+#!/bin/bash
+
+# helper script: builds memtest86+ source code
+#
+# Copyright (C) 2014, 2015, 2020 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Build MemTest86+ payload
+# --------------------------------------------------------------------
+
+printf "Building MemTest86+\n"
+
+if [ ! -d "memtest86plus/" ]; then
+ ./download memtest86plus
+fi
+
+make -j$(nproc) -BC memtest86plus
diff --git a/resources/scripts/build/payload/grub b/resources/scripts/build/payload/grub
new file mode 100755
index 00000000..2a782bec
--- /dev/null
+++ b/resources/scripts/build/payload/grub
@@ -0,0 +1,75 @@
+#!/bin/bash
+
+# generate GRUB ELF files (coreboot payload) and configuration files
+#
+# Copyright (C) 2014, 2015, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# This is where GRUB is expected to be (outside of the grub-assemble, instead in main checkout)
+source "resources/grub/modules.list"
+
+printf "Creating GRUB payloads and configuration files\n"
+
+if [ ! -d "grub/" ]; then
+ ./download grub
+fi
+
+if [ ! -f "grub/grub-mkstandalone" ]; then
+ ./build module grub
+fi
+
+[ ! -d "payload/" ] && mkdir -p payload/
+[ ! -d "payload/grub" ] && mkdir -p payload/grub/
+
+rm -f payload/grub/*
+
+# Separate GRUB payload per keymap. This saves space in the ROM, otherwise
+# a lot of space would be used if every keymap was stored in a single image
+
+for keylayoutfile in resources/grub/keymap/*.gkb; do
+ if [ ! -f "${keylayoutfile}" ]; then
+ continue
+ fi
+ keymap="${keylayoutfile##resources/grub/keymap/}"
+ keymap="${keymap%.gkb}"
+
+ grub/grub-mkstandalone \
+ --grub-mkimage="grub/grub-mkimage" \
+ -O i386-coreboot \
+ -o payload/grub/grub_${keymap}.elf \
+ -d grub/grub-core/ \
+ --fonts= --themes= --locales= \
+ --modules="${grub_modules}" \
+ --install-modules="${grub_install_modules}" \
+ /boot/grub/grub.cfg=resources/grub/config/grub_memdisk.cfg \
+ /boot/grub/layouts/${keymap}.gkb=${keylayoutfile}
+
+
+ if [ "${keymap}" = "usqwerty" ]; then
+ cp resources/grub/config/grub.cfg payload/grub/grub_usqwerty.cfg
+ else
+ sed "s/usqwerty/${keymap}/" < resources/grub/config/grub.cfg > payload/grub/grub_${keymap}.cfg
+ fi
+
+ sed "s/grubtest.cfg/grub.cfg/" < payload/grub/grub_${keymap}.cfg > payload/grub/grub_${keymap}_test.cfg
+
+ printf "Generated: 'payload/grub/grub_%s.elf' and configs.'\n" "${keymap}"
+done
+
+printf "Done! Check payload/grub/ to see the files.\n\n"
diff --git a/resources/scripts/build/payload/seabios b/resources/scripts/build/payload/seabios
new file mode 100755
index 00000000..df7ec6f5
--- /dev/null
+++ b/resources/scripts/build/payload/seabios
@@ -0,0 +1,63 @@
+#!/bin/bash
+
+# helper script: builds SeaBIOS source code
+#
+# Copyright (C) 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Build SeaBIOS
+# ---------------------------------------------------------------------
+
+printf "Building SeaBIOS payloads and SeaVGABIOS\n"
+
+[ ! -d "payload/" ] && mkdir -p payload/
+[ ! -d "payload/seabios" ] && mkdir -p payload/seabios/
+
+rm -f payload/seabios/*
+
+if [ ! -d "seabios/" ]; then
+ ./download seabios
+fi
+
+cd seabios/
+
+# for libgfxinit setup:
+[[ -f Makefile ]] && make distclean
+cp ../resources/seabios/config/libgfxinit .config
+make -j$(nproc)
+mv out/bios.bin.elf ../payload/seabios/seabios_libgfxinit.elf
+mv out/vgabios.bin ../payload/seabios/seavgabios.bin
+rm .config
+
+# for vgarom setup:
+[[ -f Makefile ]] && make distclean
+cp ../resources/seabios/config/vgarom .config
+make -j$(nproc)
+mv out/bios.bin.elf ../payload/seabios/seabios_vgarom.elf
+rm .config
+
+# clean it again. gotta keep it clean!
+[[ -f Makefile ]] && make distclean
+
+printf "Done! SeaBIOS files are in payload/seabios/\n\n"
+
+# done. go back to main directory
+cd ../
+
+# ------------------- DONE ----------------------
diff --git a/resources/scripts/build/payload/tianocore b/resources/scripts/build/payload/tianocore
new file mode 100755
index 00000000..30786216
--- /dev/null
+++ b/resources/scripts/build/payload/tianocore
@@ -0,0 +1,77 @@
+#!/bin/bash
+
+# helper script: builds Tianocore source code
+#
+# Copyright (C) 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Building Tianocore\n"
+
+[ ! -d "payload/" ] && mkdir -p payload/
+[ ! -d "payload/tianocore/" ] && mkdir -p payload/tianocore/
+
+rm -f payload/tianocore/*
+
+if [ ! -d "coreboot/default/" ]; then
+ ./download coreboot default
+ ./build module cbutils default
+fi
+
+if [ ! -d "coreboot/default/util/crossgcc/xgcc/i386-elf" ]; then
+ (
+ cd coreboot/default/
+ make crossgcc-i386 CPUS=$(nproc) # tianocore actually uses host gcc, which means
+ # right now you should be building this on a 64-bit x86 host.
+ # It does not currently use coreboot crossgcc. However, a dummy coreboot
+ # ROM is compiled using Tianocore in order to derive tianocore.elf
+
+ # and of course, that implies crossgcc. tianocore is only really use
+ # on x86, so we only care about i386 crossgcc here
+ )
+fi
+
+if [ ! -d "coreboot/default/payloads/external/tianocore/tianocore/" ]; then
+ ./download tianocore
+fi
+
+(
+cd coreboot/default/payloads/external/tianocore/
+make clean
+)
+
+(
+cd coreboot/default/
+make distclean
+cp ../../resources/tianocore/dummy.coreboot.config .config
+make -j$(nproc)
+)
+
+cp coreboot/default/payloads/external/tianocore/tianocore/Build/UEFIPAYLOAD.fd \
+ payload/tianocore/tianocore.elf
+
+(
+cd coreboot/default/
+make distclean
+)
+
+(
+cd coreboot/default/payloads/external/tianocore/
+make clean
+)
+
diff --git a/resources/scripts/build/release/roms b/resources/scripts/build/release/roms
new file mode 100755
index 00000000..a4458f30
--- /dev/null
+++ b/resources/scripts/build/release/roms
@@ -0,0 +1,70 @@
+#!/bin/bash
+
+#
+# helper script: generate release archive (ROM images)
+#
+# Copyright (C) 2020,2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+projectname="$(cat projectname)"
+
+version="version-unknown"
+if [ -f version ]; then
+ version="$(cat version)"
+fi
+versiondate="version-date-unknown"
+if [ -f versiondate ]; then
+ versiondate="$(cat versiondate)"
+fi
+
+if [ ! -d "bin/" ]; then
+ ./build boot roms all
+fi
+
+[ ! -d "release/" ] && \
+ mkdir -p release/
+[ ! -d "release/${version}/" ] && \
+ mkdir -p "release/${version}/"
+[ -d "release/${version}/roms/" ] && \
+ rm -Rf "release/${version}/roms/"
+[ ! -d "release/${version}/roms/" ] && \
+ mkdir -p "release/${version}/roms/"
+
+printf "Building ROM image archives for version %s\n" "${version}"
+
+(
+ cd bin/
+ for target in *; do
+ if [ ! -d "${target}/" ]; then
+ continue
+ fi
+
+ printf "Generating release/%s/roms/%s-%s_%s.tar.xz\n" "${projectname}" "${version}" "${version}" "${target##*/}"
+ printf "%s\n" "${version}" > "${target}/version"
+ printf "%s\n" "${versiondate}" > "${target}/versiondate"
+ printf "%s\n" "${projectname}" > "${target}/projectname"
+ tar -c "${target}/" | xz -9e >"../release/${version}/roms/${projectname}-${version}_${target##*/}.tar.xz"
+ done
+)
+
+printf "\nROM image release archives available at release/%s/roms/\n\n" "${version}"
+
diff --git a/resources/scripts/build/release/src b/resources/scripts/build/release/src
new file mode 100755
index 00000000..dc8bc75f
--- /dev/null
+++ b/resources/scripts/build/release/src
@@ -0,0 +1,120 @@
+#!/bin/bash
+
+#
+# helper script: generate release archive (source code)
+#
+# Copyright (C) 2020,2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+projectname="$(cat projectname)"
+
+version="version-unknown"
+if [ -f version ]; then
+ version="$(cat version)"
+fi
+versiondate="version-date-unknown"
+if [ -f versiondate ]; then
+ versiondate="$(cat versiondate)"
+fi
+
+reldir="release/${version}"
+dirname="${projectname}-${version}_src"
+srcdir="${reldir}/${dirname}"
+
+printf "Building source code archive, version %s\n" "${version}"
+
+[ ! -d "release/" ] && mkdir -p release/
+[ ! -d "${reldir}/" ] && mkdir -p "${reldir}/"
+[ -d "${srcdir}/" ] && \
+ rm -Rf "${srcdir}/"
+[ -f "${srcdir}.tar.xz" ] && \
+ rm -f "${srcdir}.tar.xz/"
+
+mkdir -p "${srcdir}/"
+
+printf "%s" "${version}" > "${srcdir}"/version
+
+modlist="coreboot flashrom grub memtest86plus seabios ich9utils"
+dirlist="resources"
+filelist="download build README COPYING Makefile"
+
+if [ ! -d "coreboot/default/payloads/external/tianocore/tianocore" ]; then
+ ./download tianocore
+fi
+
+for modname in ${modlist}; do
+ if [ ! -d "${modname}/" ]; then
+ ./download ${modname}
+ fi
+done
+
+for dir in ${modlist} ${dirlist}; do
+ cp -R "${dir}/" "${srcdir}/"
+done
+
+for i in ${filelist}; do
+ if [ ! -f "${i}" ]; then
+ printf "build/release/src: ERROR: file '%s' does not exist.\n" "${i}"
+ rm -Rf "${srcdir}"
+ exit 1
+ fi
+ cp ${i} "${srcdir}/"
+done
+
+(
+ cd "${srcdir}/coreboot/"
+ for i in *; do
+ [ ! -d "${i}" ] && continue
+ (
+ cd "${i}/"
+ make distclean
+ )
+ done
+)
+
+(
+ cd "${srcdir}/"
+ ./build clean all
+
+ rm -Rf coreboot/coreboot/
+ rm -Rf .git* */.git* coreboot/*/.git* coreboot/*/3rdparty/*/.git*
+ rm -Rf coreboot/*/util/nvidia/cbootimage/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/CryptoPkg/Library/OpensslLib/openssl/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/ArmPkg/Library/ArmSoftFloatLib/"berkeley-softfloat-3"/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/UnitTestFrameworkPkg/Library/CmockaLib/cmocka/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/MdeModulePkg/Universal/RegularExpressionDxe/oniguruma/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/MdeModulePkg/Library/BrotliCustomDecompressLib/brotli/.git*
+ rm -Rf coreboot/*/payloads/external/tianocore/tianocore/BaseTools/Source/C/BrotliCompress/brotli/.git*
+)
+
+(
+cd "${reldir}/"
+printf "%s\n" "${version}" > "${dirname}/version"
+printf "%s\n" "${versiondate}" > "${dirname}/versiondate"
+printf "%s\n" "${projectname}" > "${dirname}/projectname"
+tar -c "${dirname}/" | xz -9e >"${dirname}.tar.xz"
+rm -Rf "${dirname}/"
+)
+
+printf "Source code archive available at %s.tar.xz\n\n" "${srcdir}"
+
diff --git a/resources/scripts/download/coreboot b/resources/scripts/download/coreboot
new file mode 100755
index 00000000..781c54ca
--- /dev/null
+++ b/resources/scripts/download/coreboot
@@ -0,0 +1,226 @@
+#!/bin/bash
+
+# helper script: download coreboot
+#
+# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# set this when you want to modify each coreboot tree
+# for example, you want to test custom patches
+# NODELETE= ./download coreboot
+deleteblobs="true"
+[ "x${NODELETE+set}" = 'xset' ] && deleteblobs="false"
+
+# Error handling is extreme in this script.
+# This script handles the internet, and Git. Both are inherently unreliable.
+
+[[ -f build_error ]] && rm -f build_error
+
+rm -f resources/coreboot/*/seen
+
+downloadfor() {
+
+ board="${1}"
+ cbtree="undefined"
+ cbrevision="undefined"
+
+ # The loop will always exit, but this while loop is crafted
+ # such that a tree referencing a tree that references another tree is possible
+ # (and so on)
+ while true; do
+ cbrevision="undefined"
+ cbtree="undefined"
+
+ if [ ! -f "resources/coreboot/${board}/board.cfg" ]; then
+ printf "ERROR: download/coreboot: board.cfg does not exist for '%s'\n" "${board}"
+ return 1
+ fi
+
+ if [ -f "resources/coreboot/${board}/seen" ]; then
+ printf "ERROR: download/coreboot: logical loop; '%s' board.cfg refers to another tree, which ultimately refers back to '%s'.\n" "${board}" "${board}"
+ return 1
+ fi
+
+ # This is to override $cbrevision and $cbtree
+ source "resources/coreboot/${board}/board.cfg" || touch ../build_error
+ if [ -f build_error ]; then
+ printf "ERROR: download/coreboot: problem sourcing %s/board.cfg\n" "${board}"
+ return 1
+ fi
+ touch "resources/coreboot/${board}/seen"
+
+ if [ "${board}" != "${cbtree}" ]; then
+ board="${cbtree}"
+ else
+ if [ "${cbtree}" = "undefined" ]; then
+ printf "ERROR: download/coreboot: tree name undefined for '%s\n'" "${board}"
+ return 1
+ fi
+
+ if [ "${cbrevision}" = "undefined" ]; then
+ printf "ERROR: download/coreboot: commit ID undefined for '%s'\n" "${board}"
+ return 1
+ fi
+ break
+ fi
+ done
+
+ rm -f resources/coreboot/*/seen
+
+ if [ -d "coreboot/${cbtree}" ]; then
+ printf "REMARK: download/coreboot: directory for '%s' already exists. Skipping setup.\n" "${cbtree}"
+ if [ "${cbtree}" != "${1}" ]; then
+ printf "(for board: '${1}')\n"
+ fi
+ return 0
+ fi
+
+ if [ ! -d coreboot ]; then
+ mkdir "coreboot/"
+ fi
+ if [ ! -d coreboot ]; then
+ printf "ERROR: download/coreboot: directory not created. Check file system permissions\n"
+ return 1
+ fi
+
+ cd "coreboot/"
+
+ if [ ! -d coreboot/.git ] && [ -d coreboot ]; then
+ rm -Rf coreboot/
+ fi
+
+ if [ ! -d coreboot ]; then
+ printf "Download coreboot from upstream:\n"
+ git clone https://review.coreboot.org/coreboot || rm -Rf coreboot
+ if [ ! -d coreboot ]; then
+ printf "WARNING: Upstream failed. Trying backup github repository:\n"
+ git clone https://github.com/coreboot/coreboot.git || rm -Rf coreboot
+ fi
+ if [ ! -d coreboot ]; then
+ printf "ERROR: download/coreboot: Problem with git-clone. Network issue?\n"
+ cd ../; return 1
+ fi
+ else
+ ( cd coreboot/; git pull || touch ../build_error )
+ if [ -f ../build_error ]; then
+ printf "ERROR: download/coreboot: Problem with git-pull. Network issue?\n"
+ cd ../; return 1
+ fi
+ fi
+
+ cp -R coreboot "${cbtree}" || touch ../build_error
+ if [ -d ../build_error ]; then
+ printf "ERROR: download/coreboot: Unable to copy directory. Check file system permissions or free space.\n"
+ rm -Rf "${cbtree}/"
+ cd ../; return 1
+ fi
+
+ cd ${cbtree}/
+
+ git reset --hard ${cbrevision} || touch ../../build_error
+ if [ -f ../../build_error ]; then
+ printf "ERROR: download/coreboot: Unable to reset to commit ID/tag '%s' for board '%s' on tree '%s'\n" "${cbrevision}" "${1}" "${cbtree}"
+ cd ../../; return 1
+ fi
+
+ git submodule update --init || touch ../../build_error
+ if [ -f ../../build_error ]; then
+ printf "ERROR: download/coreboot: Unable to update submodules for tree '%s'\n" "${cbtree}"
+ cd ../../; return 1
+ fi
+
+ for patch in ../../resources/coreboot/${cbtree}/patches/*.patch; do
+ if [ ! -f "${patch}" ]; then
+ continue
+ fi
+
+ git am "${patch}" || touch ../../build_error
+ if [ -f ../../build_error ]; then
+ printf "ERROR: download/coreboot: Unable to apply patch '%s' for board '%s' on tree '%s'" "${patch}" "${1}" "${cbtree}"
+ git am --abort
+ cd ../../; return 1
+ fi
+ done
+
+ # extra.sh could be used to patch submodules, if you wanted to
+ # It's impossible to predict what submodules will be available, and
+ # it's rare that you'd want to patch them, so this is handled by
+ # extra.sh on a per-board basis
+ # In fact, extra.sh can be used for anything you want.
+ if [ -f "../../resources/coreboot/${board}/extra.sh" ]; then
+ "../../resources/coreboot/${board}/extra.sh" || touch ../../build_error
+ if [ -f ../../build_error ]; then
+ cd ../../; return 1
+ fi
+ return 0
+ else
+ cd ../../
+ return 0
+ fi
+}
+
+printf "Downloading coreboot and (if exist in build system) applying patches\n"
+
+if [ $# -gt 0 ]; then
+ for board in "${@}"; do
+ rm -f resources/coreboot/*/seen
+ downloadfor "${board}"
+ if [ -f build_error ]; then break; fi
+ done
+else
+ for board in resources/coreboot/*; do
+ rm -f resources/coreboot/*/seen
+ if [ ! -d "${board}/" ]; then
+ continue
+ fi
+ downloadfor "${board##*/}"
+ if [ -f build_error ]; then break; fi
+ done
+fi
+
+rm -f resources/coreboot/*/seen
+
+rm -f "build_error"
+printf "\n\n"
+if [ "${deleteblobs}" = "true" ]; then
+ rm -Rf coreboot/coreboot/
+ rm -Rf coreboot/.git* coreboot/*/.git* coreboot/*/3rdparty/*/.git*
+ rm -Rf coreboot/*/util/nvidia/cbootimage/.git*
+ for cbdir in coreboot/*; do
+ if [ ! -d "${cbdir}" ]; then continue; fi
+ cbtree="${cbdir##coreboot/}"
+ cbtree="${cbtree%/}"
+ if [ ! -d "coreboot/${cbtree}" ]; then continue; fi
+ bloblist="resources/coreboot/${cbtree}/blobs.list"
+ if [ -f "${bloblist}" ]; then
+ for blobfile in $(cat "${bloblist}"); do
+ printf "Deleting blob: 'coreboot/%s/%s'\n" "${cbtree}" "${blobfile}"
+ rm -f "coreboot/${cbtree}/${blobfile}"
+ done
+ fi
+ rmlist="resources/coreboot/${cbtree}/rm.list"
+ if [ -f "${rmlist}" ]; then
+ for rmentry in $(cat "${rmlist}"); do
+ printf "Deleting directory to save space: 'coreboot/%s/%s'\n" "${cbtree}" "${rmentry}"
+ rm -Rf "coreboot/${cbtree}/${rmentry}"
+ done
+ fi
+ done
+fi
+exit 0
diff --git a/resources/scripts/download/flashrom b/resources/scripts/download/flashrom
new file mode 100755
index 00000000..66afe585
--- /dev/null
+++ b/resources/scripts/download/flashrom
@@ -0,0 +1,51 @@
+#!/bin/bash
+
+# helper script: downloads flashrom and patches it
+#
+# Copyright (C) 2014, 2015, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Get flashrom at the last previously tested revision
+
+# Remove the old version that may still exist:
+# ------------------------------------------------------------------------------
+
+printf "Downloading flashrom\n"
+
+rm -Rf "flashrom/"
+
+# Get flashrom
+# ------------------------------------------------------------------------------
+
+# download it using git
+git clone https://review.coreboot.org/flashrom.git
+
+if [ ! -d "flashrom" ]; then
+ printf "flashrom not downloaded; check network connection?\n\n"
+ exit 1
+fi
+
+(
+cd "flashrom/"
+
+# reset to known revision
+git reset --hard v1.2
+)
+
+printf "\n\n"
diff --git a/resources/scripts/download/grub b/resources/scripts/download/grub
new file mode 100755
index 00000000..9d74c568
--- /dev/null
+++ b/resources/scripts/download/grub
@@ -0,0 +1,57 @@
+#!/bin/bash
+
+# helper script: Downloads GRUB and patches it.
+#
+# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Remove the old version that may still exist
+# ------------------------------------------------------------------------------
+
+printf "Downloading GRUB\n"
+
+rm -Rf "grub/"
+
+# Get latest GRUB
+# ------------------------------------------------------------------------------
+
+# download it using git
+git clone git://git.savannah.gnu.org/grub.git || git clone http://git.savannah.gnu.org/r/grub.git
+
+if [ ! -d "grub" ]; then
+ printf "grub not downloaded; check network connection?\n\n"
+ exit 1
+fi
+
+(
+# modifications are required
+cd "grub/"
+# reset to known revision
+git reset --hard c0e647eb0e2bd09315612446cb4d90f7f75cb44c
+
+git clone git://git.sv.gnu.org/gnulib gnulib
+cd gnulib/
+
+# NOTE: when updating this, make sure it's the version specified
+# in bootstrap.conf on that version of GRUB, as specified above
+git reset --hard d271f868a8df9bbec29049d01e056481b7a1a263
+rm -Rf .git*
+)
+
+printf "\n\n"
diff --git a/resources/scripts/download/ich9utils b/resources/scripts/download/ich9utils
new file mode 100755
index 00000000..34f02685
--- /dev/null
+++ b/resources/scripts/download/ich9utils
@@ -0,0 +1,49 @@
+#!/bin/bash
+
+# helper script: downloads ich9utils
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Downloading ich9utils\n"
+
+if [ -d ich9utils ]; then
+ printf "ich9utils already downloaded. skipping\n"
+ exit 0
+fi
+
+# Get flashrom
+# ------------------------------------------------------------------------------
+
+# download it using git
+git clone https://notabug.org/osboot/ich9utils.git
+
+if [ ! -d "ich9utils" ]; then
+ printf "ich9utils not downloaded; check network connection?\n\n"
+ exit 1
+fi
+
+(
+cd "ich9utils/"
+
+# reset to known revision
+git reset --hard 53749b0c6f7c5778bdd1ec2b91cd230626752579
+)
+
+printf "\n\n"
diff --git a/resources/scripts/download/memtest86plus b/resources/scripts/download/memtest86plus
new file mode 100755
index 00000000..df06f68e
--- /dev/null
+++ b/resources/scripts/download/memtest86plus
@@ -0,0 +1,68 @@
+#!/bin/bash
+
+# helper script: Downloads MemTest86+ and patches it
+#
+# Copyright (C) 2014, 2015, 2020, 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2015 Joseph Michael Thompson <jmt@josepht.me>
+# Copyright (C) 2015 Klemens Nanni <contact@autoboot.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Get the last version of MemTest86+ used, apply patches, build it.
+
+# Remove the old version that may exist
+# ------------------------------------------------------------------------------
+
+printf "Downloading MemTest86+\n"
+
+rm -Rf "memtest86plus/"
+
+# Get latest memtest86+:
+# ------------------------------------------------------------------------------
+
+# download it using wget
+wget http://memtest.org/download/5.31b/memtest86+-5.31b.tar.gz
+
+if [ "$(sha512sum memtest86+-5.31b.tar.gz | cut -c1-128)" = "ad5891fd0c430ce7a5d0cde2d10dee20b66ad8060d47c3e70e038461d9cde3a78dfc13442b5b09da7c662741945a670353c72dbc08fd5ee8bae82256001a9541" ]; then
+ printf "Valid checksum for memtest86plus\n"
+else
+ rm -f "memtest86+-5.31b.tar.gz"
+ printf "Invalid checksum for memtest86plus, or memtest86plus not downloaded\n"
+ exit 1
+fi
+
+# extract it
+tar -xzf "memtest86+-5.31b.tar.gz"
+
+# delete the tar file (no longer needed)
+rm -f "memtest86+-5.31b.tar.gz"
+
+# make direcotory name consistent
+mv "memtest86+-5.31b/" "memtest86plus/"
+
+# Apply necessary patches
+# ------------------------------------------------------------------------------
+
+(
+cd "memtest86plus/"
+for patch in ../resources/memtest86plus/patch/*; do
+ patch < "${patch}"
+done
+)
+
+printf "\n\n"
diff --git a/resources/scripts/download/seabios b/resources/scripts/download/seabios
new file mode 100755
index 00000000..f6fc2070
--- /dev/null
+++ b/resources/scripts/download/seabios
@@ -0,0 +1,67 @@
+#!/bin/bash
+#
+# Copyright (C) 2015, 2016, 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+# Get SeaBIOS, revert to commit last used and apply patches.
+
+# Remove the old version that may still exist
+# ------------------------------------------------------------------------------
+
+printf "Downloading SeaBIOS\n"
+
+rm -f build_error
+
+rm -rf "seabios/"
+
+# Get latest SeaBIOS
+# ------------------------------------------------------------------------------
+
+# download it using git
+git clone https://git.seabios.org/seabios.git
+
+if [ ! -d "seabios" ]; then
+ printf "seabios not downloaded; check network connection?\n\n"
+ exit 1
+fi
+
+(
+# modifications are required
+cd "seabios/"
+
+# Reset to the last commit that was tested (we use stable releases for seabios)
+# ------------------------------------------------------------------------------
+
+git reset --hard b0d61ecef66eb05bd7a4eb7ada88ec5dab06dfee
+
+for patchfile in ../resources/seabios/patches/*.patch; do
+ git am "${patchfile}" || touch ../build_error
+ if [ -f ../build_error ]; then
+ git am --abort
+ break
+ fi
+done
+)
+
+if [ -f build_error ]; then
+ rm -f build_error
+ exit 1
+fi
+
+exit 0
diff --git a/resources/scripts/download/tianocore b/resources/scripts/download/tianocore
new file mode 100755
index 00000000..3a84dcf1
--- /dev/null
+++ b/resources/scripts/download/tianocore
@@ -0,0 +1,33 @@
+#!/bin/bash
+#
+# Copyright (C) 2020 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Downloading Tianocore\n"
+
+if [ ! -d "coreboot/default/" ]; then
+ ./download coreboot default
+fi
+
+(
+ cd "coreboot/default/payloads/external/tianocore/"
+ rm -Rf tianocore
+ make download && make update
+)
+
diff --git a/resources/scripts/misc/versioncheck b/resources/scripts/misc/versioncheck
new file mode 100755
index 00000000..930bfcdb
--- /dev/null
+++ b/resources/scripts/misc/versioncheck
@@ -0,0 +1,43 @@
+#!/bin/bash
+
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+version="version-unknown"
+if [ -f version ]; then
+ version="$(cat version)"
+fi
+version_="${version}"
+if [ -d ".git/" ]; then
+ version="$(git describe --tags HEAD 2>&1)" \
+ || version="git-$(git rev-parse HEAD 2>&1)" \
+ || version="${version_}"
+ printf "%s\n" "${version}" > version
+fi
+
+versiondate="version-date-unknown"
+if [ -f versiondate ]; then
+ versiondate="$(cat versiondate)"
+fi
+versiondate_="${versiondate}"
+if [ -d ".git/" ]; then
+ versiondate="$(git show --no-patch --no-notes --pretty='%ct' HEAD)" \
+ || versiondate="${versiondate_}"
+ printf "%s\n" "${versiondate}" > versiondate
+fi
diff --git a/resources/scripts/update/coreboot/configs b/resources/scripts/update/coreboot/configs
new file mode 100755
index 00000000..639a255d
--- /dev/null
+++ b/resources/scripts/update/coreboot/configs
@@ -0,0 +1,82 @@
+#!/bin/bash
+
+#
+# helper script: update coreboot configs (run make oldconfig)
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Updating coreboot configs\n"
+
+# Build ROM images for supported boards
+updateconf() {
+ board="$1"
+ if [ -f "resources/coreboot/${board}/board.cfg" ]; then
+ cbtree="undefined"
+ source "resources/coreboot/${board}/board.cfg"
+ if [ "${cbtree}" = "undefined" ]; then
+ return 0
+ fi
+ if [ ! -d "coreboot/${cbtree}" ]; then
+ ./download coreboot ${cbtree}
+ fi
+ for cbcfg in resources/coreboot/${board}/config/*; do
+ if [ ! -f ${cbcfg} ]; then
+ continue
+ fi
+ (
+ cd coreboot/${cbtree}/
+ rm -f .config*
+ make distclean
+ )
+ mv $cbcfg coreboot/${cbtree}/.config
+ (
+ cd coreboot/${cbtree}/
+ make oldconfig
+ )
+ mv coreboot/${cbtree}/.config $cbcfg
+ rm -f coreboot/${cbtree}/.config*
+ (
+ cd coreboot/${cbtree}/
+ make distclean
+ )
+ done
+ else
+ printf "\nupdate/config/coreboot: no board.cfg for: %s\n" "${board}"
+ fi
+}
+
+if [ $# -gt 0 ]; then
+ for board in "${@}"; do
+ updateconf "${board}"
+ done
+else
+ for board in resources/coreboot/*; do
+ if [ ! -d "${board}" ]; then
+ continue
+ fi
+ updateconf "${board##*/}"
+ done
+fi
+
+printf "\n\n"
+
diff --git a/resources/scripts/update/seabios/configs b/resources/scripts/update/seabios/configs
new file mode 100755
index 00000000..312e6f68
--- /dev/null
+++ b/resources/scripts/update/seabios/configs
@@ -0,0 +1,64 @@
+#!/bin/bash
+
+#
+# helper script: update coreboot configs (run make oldconfig)
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Updating seabios configs\n"
+
+if [ ! -d "seabios" ]; then
+ ./download seabios
+fi
+
+if [ ! -d "seabios" ]; then
+ printf "error: Failed to download SeaBIOS. check internet connection?\n"
+ exit 1
+fi
+
+for config in resources/seabios/config/*; do
+
+ if [ ! -f "${config}" ]; then continue; fi
+
+ (
+ cd seabios
+ make distclean
+ )
+
+ mv "${config}" seabios/.config
+ (
+ cd seabios
+ make oldconfig
+ )
+
+ cp seabios/.config "${config}"
+
+ (
+ cd seabios
+ make distclean
+ )
+
+done
+
+printf "\n\n"
+
diff --git a/resources/scripts/update/tianocore/configs b/resources/scripts/update/tianocore/configs
new file mode 100755
index 00000000..cd30db03
--- /dev/null
+++ b/resources/scripts/update/tianocore/configs
@@ -0,0 +1,55 @@
+#!/bin/bash
+
+#
+# helper script: update coreboot configs (run make oldconfig)
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+# This script assumes that the working directory is the root
+# of git or release archive
+
+[ "x${DEBUG+set}" = 'xset' ] && set -v
+set -u -e
+
+printf "Updating tianocore dummy config\n"
+
+# Build ROM images for supported boards
+cbtree="default"
+
+if [ ! -d coreboot/${cbtree} ]; then
+ ./download coreboot ${cbtree}
+fi
+
+(
+cd coreboot/${cbtree}/
+rm -f .config*
+make distclean
+)
+mv resources/tianocore/dummy.coreboot.config coreboot/${cbtree}/.config
+(
+cd coreboot/${cbtree}/
+make oldconfig
+)
+mv coreboot/${cbtree}/.config resources/tianocore/dummy.coreboot.config
+rm -f coreboot/${cbtree}/.config*
+(
+cd coreboot/${cbtree}/
+make distclean
+)
+
+printf "\n\n"
+