summaryrefslogtreecommitdiff
path: root/resources/scripts
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2022-11-11 21:38:12 +0000
committerGogs <gogitservice@gmail.com>2022-11-11 21:38:12 +0000
commitb5c25efed46f0a9121023997c6758eda5c3f5017 (patch)
tree973bda08e84b61b8fee442a94db1bc62bd6d818a /resources/scripts
parentfbbb5bc616b08a5cd747735b0612fd0f0046c7fe (diff)
parent61ac6c3f0b26deadc2fb8355a8dd0d25b29baacd (diff)
Merge branch 'u-boot-chromebooks' of alpernebbi/lbmk into master
Diffstat (limited to 'resources/scripts')
-rwxr-xr-xresources/scripts/build/boot/roms_helper80
-rwxr-xr-xresources/scripts/build/payload/u-boot146
-rwxr-xr-xresources/scripts/build/release/u-boot-libre10
-rwxr-xr-xresources/scripts/download/coreboot33
-rwxr-xr-xresources/scripts/download/u-boot265
-rwxr-xr-xresources/scripts/modify/u-boot/configs83
-rwxr-xr-xresources/scripts/update/u-boot/configs83
7 files changed, 606 insertions, 94 deletions
diff --git a/resources/scripts/build/boot/roms_helper b/resources/scripts/build/boot/roms_helper
index a6b64316..951e19ba 100755
--- a/resources/scripts/build/boot/roms_helper
+++ b/resources/scripts/build/boot/roms_helper
@@ -4,6 +4,7 @@
#
# Copyright (C) 2020,2021 Leah Rowe <info@minifree.org>
# Copyright (C) 2021 Vitali64 <vitali64pmemail@protonmail.com>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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
@@ -63,6 +64,8 @@ payload_seabios="n"
payload_seabios_withgrub="n" # i386-coreboot grub accessible from SeaBIOS boot menu
seabios_opromloadonly="0"
payload_memtest="n"
+payload_uboot="n"
+uboot_config="undefined"
# Override the above defaults using board.cfg
source "resources/coreboot/${board}/board.cfg"
@@ -109,7 +112,7 @@ 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}" != "y" ] && [ "${payload_seabios}" != "y" ]; then
+if [ "${payload_grub}" != "y" ] && [ "${payload_seabios}" != "y" ] && [ "${payload_uboot}" != "y" ]; then
while true; do
for configfile in "resources/coreboot/${board}/config/"*; do
if [ -f "${configfile}" ]; then
@@ -121,6 +124,16 @@ if [ "${payload_grub}" != "y" ] && [ "${payload_seabios}" != "y" ]; then
done
fi
+if [ "${payload_uboot}" != "n" ] && \
+ [ "${payload_uboot}" != "y" ]; then
+ payload_uboot="n"
+fi
+
+if [ "${payload_uboot}" = "y" ] && \
+ [ "${uboot_config}" = "undefined" ]; then
+ uboot_config="default"
+fi
+
if [ "${payload_memtest}" = "y" ]; then
if [ ! -f "memtest86plus/memtest" ]; then
./build module memtest86plus
@@ -150,13 +163,17 @@ if [ "${arch}" = "x86_32" ] || [ "${arch}" = "x86_64" ]; then
)
fi
elif [ "${arch}" = "ARMv7" ]; then
- cat version > "${cbdir}/.coreboot-version"
- cd "${cbdir}"
- make crossgcc-arm CPUS=$(nproc) # This is for armv7, doesn't apply to aarch64
+ (
+ cat version > "${cbdir}/.coreboot-version"
+ cd "${cbdir}"
+ make crossgcc-arm CPUS=$(nproc) # This is for armv7, doesn't apply to aarch64
+ )
elif [ "${arch}" = "AArch64" ]; then
- cat version > "${cbdir}/.coreboot-version"
- cd "${cbdir}"
- make crossgcc-aarch64 CPUS=$(nproc) # This is for aarch64, doesn't apply to armv7
+ (
+ cat version > "${cbdir}/.coreboot-version"
+ cd "${cbdir}"
+ make crossgcc-arm crossgcc-aarch64 CPUS=$(nproc) # This is for aarch64, doesn't apply to armv7
+ )
fi
if [ ! -f "${cbfstool}" ]; then
@@ -211,6 +228,21 @@ if [ "${payload_grub}" = "y" ] || [ "${payload_seabios_withgrub}" = "y" ]; then
done
fi
+if [ "${payload_uboot}" = "y" ]; then
+ if [ "${uboot_config}" = "default" ] && \
+ [ -f "payload/u-boot/${board}/u-boot.elf" ]; then
+ ubootelf="payload/u-boot/${board}/u-boot.elf"
+ else
+ ubootelf="payload/u-boot/${board}/${uboot_config}/u-boot.elf"
+ fi
+
+ if [ ! -f "${ubootelf}" ]; then
+ printf "Required U-Boot payloads not yet built. Building now:\n"
+ rm -Rf "payload/u-boot/${board}" # just in case
+ ./build payload u-boot "${board}"
+ fi
+fi
+
# it is assumed that no other work will be done on the ROM
# after calling this function. therefore this function is "final"
moverom() {
@@ -275,6 +307,7 @@ mkCoreboot() {
make distclean
)
cp "${cbcfgpath}" "${cbdir}"/.config
+ ./build module cbutils ${cbdir#coreboot/}
(
cd "${cbdir}"
make -j$(nproc)
@@ -321,6 +354,28 @@ make_seabios_rom() {
}
# make a rom in /tmp/ and then print the path of that ROM
+make_uboot_payload_rom() {
+ target_cbrom="${1}" # rom to insert u-boot in. this rom won't be touched
+ # a tmpfile will be made instead
+ target_uboot_cbfs_path="${2}" # e.g. fallback/payload
+ target_uboot_config="${3}"
+ cbfstool_path="${4}"
+
+ if [ "${target_uboot_config}" = "default" ]; then
+ target_ubootelf="payload/u-boot/${board}/u-boot.elf"
+ else
+ target_ubootelf="payload/u-boot/${board}/${target_uboot_config}/u-boot.elf"
+ fi
+
+ tmprom=$(mktemp -t coreboot_rom.XXXXXXXXXX)
+
+ cp "${target_cbrom}" "${tmprom}"
+ "${cbfstool}" "${tmprom}" add-payload -f "${target_ubootelf}" -n ${target_uboot_cbfs_path} -c lzma
+
+ 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}"
@@ -450,6 +505,17 @@ mkRoms() {
if [ "${payload_grub}" = "y" ]; then
mkRomsWithGrub "${corebootrom}" "${initmode}" "${displaymode}" "grub"
fi
+
+ if [ "${payload_uboot}" = "y" ]; then
+ tmpubootrom="$(make_uboot_payload_rom "${corebootrom}" "fallback/payload" "${uboot_config}" "${cbfstool}")"
+ if [ "${initmode}" = "normal" ]; then
+ newrompath="${romdir}/uboot_payload_${board}_${initmode}.rom"
+ else
+ newrompath="${romdir}/uboot_payload_${board}_${initmode}_${displaymode}.rom"
+ fi
+ moverom "${tmpubootrom}" "${newrompath}" "${romtype}"
+ rm -f "${tmpubootrom}"
+ fi
}
initmode="libgfxinit"
diff --git a/resources/scripts/build/payload/u-boot b/resources/scripts/build/payload/u-boot
new file mode 100755
index 00000000..6c94a441
--- /dev/null
+++ b/resources/scripts/build/payload/u-boot
@@ -0,0 +1,146 @@
+#!/usr/bin/env bash
+
+# helper script: builds U-Boot source code
+#
+# Copyright (C) 2020, 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2021 Vitali64 <vitali64pmemail@protonmail.com>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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
+
+RET=0
+
+# Build U-Boot
+# ---------------------------------------------------------------------
+
+printf "Building U-Boot payloads\n"
+
+# Build for all boards if no argument is given
+if [ "$#" -eq 0 ]; then
+ for board_dir in resources/u-boot/*; do
+ if [ -d "${board_dir}/config/" ]; then
+ set -- "$@" "${board_dir#resources/u-boot/}"
+ fi
+ done
+fi
+
+[ ! -d "payload/" ] && mkdir -p payload/
+[ ! -d "payload/u-boot" ] && mkdir -p payload/u-boot/
+
+# Appends additional version info to U-Boot
+our_version="$(cat version)"
+projectname="$(cat projectname)"
+export LOCALVERSION="-${projectname}-${our_version}"
+
+for board in "$@"; do
+ board_dir="resources/u-boot/${board}"
+ rm -rf "payload/u-boot/${board}"
+ mkdir -p "payload/u-boot/${board}"
+
+ ubtree="undefined"
+ arch="undefined"
+
+ if [ ! -f "${board_dir}/board.cfg" ]; then
+ printf "%s: Target %s does not have a board.cfg. Skipping build.\n" \
+ "build/payload/u-boot" "${board}"
+ RET=1
+ continue
+ fi
+
+ # Override the above defaults using board.cfg
+ source "${board_dir}/board.cfg"
+
+ if [ "${ubtree}" = "undefined" ]; then
+ printf "%s: Target %s does not define a U-Boot tree. Skipping build.\n" \
+ "build/payload/u-boot" "${board}"
+ RET=1
+ continue
+ fi
+ if [ "${arch}" = "undefined" ]; then
+ printf "%s: Target %s does not define a CPU type. Skipping build.\n" \
+ "build/payload/u-boot" "${board}"
+ RET=1
+ continue
+ fi
+
+ ubdir="u-boot/${board}"
+ if [ "${board}" != "${ubtree}" ]; then
+ ubdir="u-boot/${ubtree}"
+ fi
+
+ if [ ! -d "${ubdir}" ]; then
+ ./download u-boot "$board"
+ fi
+
+ if [ ! -d "${ubdir}" ]; then
+ printf "%s: Failed to download U-Boot for target %s. Skipping build.\n" \
+ "build/payload/u-boot" "${board}"
+ RET=1
+ continue
+ fi
+
+ if [ "${arch}" = "x86_32" ] || [ "${arch}" = "x86_64" ]; then
+ export CROSS_COMPILE=x86_64-linux-
+ elif [ "${arch}" = "ARMv7" ]; then
+ export CROSS_COMPILE=arm-linux-gnueabi-
+ elif [ "${arch}" = "AArch64" ]; then
+ export CROSS_COMPILE=aarch64-linux-gnu-
+ fi
+
+ for config in "${board_dir}/config"/*; do
+ if [ ! -f "${config}" ]; then
+ printf "%s: Target %s has no configs to build for. Skipping build.\n" \
+ "build/payload/u-boot" "${board}"
+ RET=1
+ continue
+ fi
+
+ config_name="${config#$board_dir/config/}"
+ if [ "$config_name" = "default" ]; then
+ dest_dir="payload/u-boot/${board}"
+ else
+ dest_dir="payload/u-boot/${board}/${config_name}"
+ fi
+ mkdir -p "${dest_dir}"
+
+ printf "%s: Building for target %s (config %s).\n" \
+ "build/payload/u-boot" "${board}" "${config_name}"
+
+ make -C "${ubdir}" distclean
+
+ cp "${config}" "${ubdir}/.config"
+ make -C "${ubdir}" olddefconfig
+ make -C "${ubdir}" -j"$(nproc)" all
+
+ for f in "${ubdir}"/u-boot{,.bin,.dtb,.img,.itb,.elf}; do
+ if [ -f "$f" ]; then
+ mv "$f" "${dest_dir}/"
+ fi
+ done
+
+ make -C "${ubdir}" distclean
+
+ printf "%s: Built for target %s (config %s).\n" \
+ "build/payload/u-boot" "${board}" "${config_name}"
+ done
+done
+
+printf "Done! U-Boot files are in payload/u-boot/\n\n"
+exit $RET
+
+# ------------------- DONE ----------------------
diff --git a/resources/scripts/build/release/u-boot-libre b/resources/scripts/build/release/u-boot-libre
index a871aab7..8e0ce17c 100755
--- a/resources/scripts/build/release/u-boot-libre
+++ b/resources/scripts/build/release/u-boot-libre
@@ -5,6 +5,7 @@
#
# Copyright (C) 2020,2021 Leah Rowe <info@minifree.org>
# Copyright (C) 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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
@@ -23,10 +24,11 @@
[ "x${DEBUG+set}" = 'xset' ] && set -v
set -u -e
-revision="r1"
+revision="r2"
supported_uboot_versions=" \
2021.07 \
+ 2022.07 \
"
topdir="$(realpath $(dirname $(realpath $0))/../../../../)"
@@ -101,7 +103,7 @@ release_deblobbed_uboot()
"${tarball}.xz"
mkdir -p "$(dirname ${tmpdir})"
- cp -R "u-boot/u-boot/" "${tmpdir}"
+ cp -R "u-boot/v${version}/" "${tmpdir}"
rm -rf ${tmpdir}/.git ${tmpdir}/.gitignore
make -C ${tmpdir} distclean
@@ -112,7 +114,7 @@ release_deblobbed_uboot()
--format=gnu \
--sort=name \
--owner=0 --group=0 --numeric-owner \
- --mtime="1970-01-01" \
+ --mtime="@${SOURCE_DATE_EPOCH:-0}" \
lzip -9 --keep -vv "${tarball}"
xz -9 --keep -vv "${tarball}"
@@ -170,7 +172,7 @@ release_uboot_deblob_script()
"${destination}.xz"
install -m 755 -d "${release_version_dir}"
- install -m 644 -T "${blobs_list}" "${destination}"
+ install -m 644 -T "${deblob_script}" "${destination}"
lzip -9 --keep -vv "${destination}"
xz -9 --keep -vv "${destination}"
diff --git a/resources/scripts/download/coreboot b/resources/scripts/download/coreboot
index 21fe0781..80fff097 100755
--- a/resources/scripts/download/coreboot
+++ b/resources/scripts/download/coreboot
@@ -3,6 +3,7 @@
# helper script: download coreboot
#
# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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
@@ -64,8 +65,12 @@ fi
# set this when you want to modify each coreboot tree
# for example, you want to test custom patches
# NODELETE= ./download coreboot
+deletegit="true"
deleteblobs="true"
-[ "x${NODELETE+set}" = 'xset' ] && deleteblobs="false"
+if [ "x${NODELETE+set}" = 'xset' ]; then
+ [ "x${NODELETE:-all}" = "xgit" ] && deletegit="false"
+ [ "x${NODELETE:-all}" = "xall" ] && deleteblobs="false" && deletegit="false"
+fi
# Error handling is extreme in this script.
# This script handles the internet, and Git. Both are inherently unreliable.
@@ -147,21 +152,21 @@ downloadfor() {
if [ ! -d coreboot ]; then
printf "Download coreboot from upstream:\n"
- git clone https://review.coreboot.org/coreboot || rm -Rf coreboot
+ git clone --depth=1 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
+ git clone --depth=1 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
+
+ ( cd coreboot/; git fetch --depth=1 origin "${cbrevision}" || touch ../build_error )
+ if [ -f ../build_error ]; then
+ printf "ERROR: download/coreboot: Problem with git-fetch. Network issue?\n"
+ cd ../; return 1
fi
cp -R coreboot "${cbtree}" || touch ../build_error
@@ -179,7 +184,7 @@ downloadfor() {
cd ../../; return 1
fi
- git submodule update --init || touch ../../build_error
+ git submodule update --init --depth=1 || touch ../../build_error
if [ -f ../../build_error ]; then
printf "ERROR: download/coreboot: Unable to update submodules for tree '%s'\n" "${cbtree}"
cd ../../; return 1
@@ -239,9 +244,11 @@ 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*
+ if [ "${deletegit}" = "true" ]; then
+ rm -Rf coreboot/coreboot/
+ rm -Rf coreboot/.git* coreboot/*/.git* coreboot/*/3rdparty/*/.git*
+ rm -Rf coreboot/*/util/nvidia/cbootimage/.git*
+ fi
for cbdir in coreboot/*; do
if [ ! -d "${cbdir}" ]; then continue; fi
cbtree="${cbdir##coreboot/}"
diff --git a/resources/scripts/download/u-boot b/resources/scripts/download/u-boot
index bd0258c0..5fc80868 100755
--- a/resources/scripts/download/u-boot
+++ b/resources/scripts/download/u-boot
@@ -4,6 +4,7 @@
#
# Copyright (C) 2014, 2015, 2016, 2020, 2021 Leah Rowe <info@minifree.org>
# Copyright (C) 2021 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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
@@ -24,74 +25,183 @@ set -u -e
# set this when you want to modify each u-boot tree
# for example, you want to test custom patches
-# NODELETE= ./download coreboot
+# NODELETE= ./download u-boot
+deletegit="true"
deleteblobs="true"
-[ "x${NODELETE+set}" = 'xset' ] && deleteblobs="false"
+if [ "x${NODELETE+set}" = 'xset' ]; then
+ [ "x${NODELETE:-all}" = "xgit" ] && deletegit="false"
+ [ "x${NODELETE:-all}" = "xall" ] && deleteblobs="false" && deletegit="false"
+fi
# 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
-# Make sure that older revision are first as code uses that order to
-# find the latest supported revision.
-supported_uboot_revisions=" \
- v2021.07 \
-"
+list_supported_boards() {
+ for board in resources/u-boot/*; do
+ if [ -d ${board} ]; then
+ echo "${board#resources/u-boot/}"
+ fi
+ done
+}
downloadfor() {
- uboot_revision="v2021.07"
- uboot_dir="u-boot/u-boot"
- if [ -d "${uboot_dir}" ]; then
+ board="${1}"
+
+ # 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
+ ubrevision="undefined"
+ ubtree="undefined"
+
+ if [ ! -f "resources/u-boot/${board}/board.cfg" ]; then
+ printf "ERROR: %s: board.cfg does not exist for '%s'\n" \
+ "download/u-boot" "${board}"
+ return 1
+ fi
+
+ if [ -f "resources/u-boot/${board}/seen" ]; then
+ printf "ERROR: %s: logical loop; '%s' board.cfg refers to another tree, which ultimately refers back to '%s'.\n" \
+ "download/u-boot" "${board}" "${board}"
+ return 1
+ fi
+
+ # This is to override $ubrevision and $ubtree
+ source "resources/u-boot/${board}/board.cfg" || touch build_error
+ if [ -f build_error ]; then
+ printf "ERROR: %s: problem sourcing %s/board.cfg\n" \
+ "download/u-boot" "${board}"
+ return 1
+ fi
+ touch "resources/u-boot/${board}/seen"
+
+ if [ "${board}" != "${ubtree}" ]; then
+ board="${ubtree}"
+ else
+ if [ "${ubtree}" = "undefined" ]; then
+ printf "ERROR: %s: tree name undefined for '%s\n'" \
+ "download/u-boot" "${board}"
+ return 1
+ fi
+
+ if [ "${ubrevision}" = "undefined" ]; then
+ printf "ERROR: %s: commit ID undefined for '%s'\n" \
+ "download/u-boot" "${board}"
+ return 1
+ fi
+ break
+ fi
+ done
+
+ rm -f resources/u-boot/*/seen
+
+ ubtree="u-boot/${ubtree}"
+ if [ -d "${ubtree}" ]; then
printf \
"REMARK: '%s' directory already exists. Skipping setup.\n" \
- "${uboot_dir}"
+ "${ubtree}"
+ if [ "${ubtree}" != "u-boot/${board}" ]; then
+ printf "(for board: '${board}')\n"
+ fi
return 0
fi
- if [ ! -d "${uboot_dir}" ]; then
- mkdir -p "${uboot_dir}"
+ if [ ! -d "u-boot" ]; then
+ mkdir -p "u-boot"
fi
- if [ ! -d "${uboot_dir}" ]; then
- printf \
- "ERROR: '%s' directory not created. Check file system permissions\n" \
- "${uboot_dir}"
+ if [ ! -d "u-boot" ]; then
+ printf \
+ "ERROR: '%s' directory not created. Check file system permissions\n" \
+ "u-boot"
return 1
fi
+ uboot_dir="u-boot/u-boot"
if [ ! -d "${uboot_dir}/.git" ] && [ -d "${uboot_dir}" ]; then
rm -Rf "${uboot_dir}"
fi
if [ ! -d "${uboot_dir}" ]; then
printf "Download u-boot from upstream:\n"
- git clone https://source.denx.de/u-boot/u-boot.git \
+ git clone --depth=1 https://source.denx.de/u-boot/u-boot.git \
"${uboot_dir}" || \
rm -Rf "${uboot_dir}"
if [ ! -d "${uboot_dir}" ]; then
+ printf "WARNING: Upstream failed. Trying backup github repository:\n"
+ git clone --depth=1 https://github.com/u-boot/u-boot.git \
+ "${uboot_dir}" || \
+ rm -Rf coreboot
+ fi
+ if [ ! -d "${uboot_dir}" ]; then
printf \
"ERROR: %s: Problem with git-clone. Network issue?\n" \
"download/u-boot"
return 1
fi
- else
- git -C "${uboot_dir}" pull || touch build_error
- if [ -f build_error ]; then
- printf \
- "ERROR: %s: Problem with git-pull. Network issue?\n" \
+ fi
+
+ git -C "${uboot_dir}" fetch --depth=1 origin "${ubrevision}" || touch build_error
+ if [ -f build_error ]; then
+ printf \
+ "ERROR: %s: Problem with git-fetch. Network issue?\n" \
+ "download/u-boot"
+ return 1
+ fi
+
+ cp -R "${uboot_dir}" "${ubtree}" || touch build_error
+ if [ -f build_error ]; then
+ printf "ERROR: %s: Unable to copy directory. Check file system permissions or free space.\n" \
"download/u-boot"
- return 1
- fi
+ rm -Rf "${ubtree}/"
+ return 1
fi
- git -C "${uboot_dir}" reset --hard ${uboot_revision} || \
+ git -C "${ubtree}" reset --hard ${ubrevision} || \
touch build_error
if [ -f build_error ]; then
printf \
"ERROR: %s: Unable to reset to commit ID/tag '%s' for board '%s' on tree '%s'\n" \
- "download/u-boot" "${uboot_revision}" "${1}" "${uboot_dir}"
+ "download/u-boot" "${ubrevision}" "${board}" "${ubtree}"
+ return 1
+ fi
+
+ git -C "${ubtree}" submodule update --init --depth=1 || touch build_error
+ if [ -f build_error ]; then
+ printf "ERROR: %s: Unable to update submodules for tree '%s'\n" \
+ "${ubtree}"
return 1
fi
+
+ for patch in resources/u-boot/${board}/patches/*.patch; do
+ if [ ! -f "${patch}" ]; then
+ continue
+ fi
+
+ git -C "${ubtree}" am "$(pwd)/${patch}" || touch build_error
+ if [ -f build_error ]; then
+ printf "ERROR: %s: Unable to apply patch '%s' for board '%s' on tree '%s'" \
+ "download/u-boot" "${patch}" "${board}" "${ubtree}"
+ git -C "${ubtree}" am --abort
+ 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/u-boot/${board}/extra.sh" ]; then
+ "resources/u-boot/${board}/extra.sh" || touch build_error
+ if [ -f build_error ]; then
+ return 1
+ fi
+ return 0
+ else
+ return 0
+ fi
}
strip_comments()
@@ -162,53 +272,57 @@ usage()
printf "Usage:\n"
printf "\t%s # %s\n" \
"${progname}" \
- "Download latest u-boot git revision and deblob it"
- printf "\t%s [revision] # %s\n" \
+ "Download and deblob u-boot for all boards"
+ printf "\t%s [board] # %s\n" \
"${progname}" \
- "Download given u-boot git revision and deblob it"
+ "Download and deblob u-boot for the given board"
printf "\t%s --blobs-list # %s\n" \
"${progname}" \
- "Print the path of the blobs.list file for the latest supported u-boot revision"
- printf "\t%s --blobs-list [revision] # %s\n" \
+ "Print the path of the generic blobs.list file"
+ printf "\t%s --blobs-list [board] # %s\n" \
"${progname}" \
- "Print the path of the blobs.list file for the given u-boot revision"
+ "Print the path of the blobs.list file for the given board"
printf "\t%s --gen-deblob-script # %s\n" \
"${progname}" \
- "Print the path of the generated deblob script for the latest supported u-boot revision"
- printf "\t%s --gen-deblob-script [revision] # %s\n" \
+ "Print the path of a generated generic deblob script"
+ printf "\t%s --gen-deblob-script [board] # %s\n" \
"${progname}" \
- "Print the path of the generated deblob script for the given u-boot revision"
- printf "\t%s --list-revisions # %s\n" \
+ "Print the path of a generated deblob script for the given board"
+ printf "\t%s --list-boards # %s\n" \
"${progname}" \
- "List supported u-boot revisions"
+ "List supported boards"
printf "\t%s --help # %s\n" \
"${progname}" \
"Prints this help"
}
-download_uboot_revision()
+download_uboot_board()
{
- git_revision="$1"
+ board="${1}"
+ ubtree="u-boot/${board}"
printf "Downloading u-boot "
printf "and (if exist in build system) applying patches\n"
- downloadfor "${git_revision}"
+ downloadfor "${board}"
rm -f "build_error"
printf "\n\n"
if [ "${deleteblobs}" = "true" ]; then
- blobslist="resources/u-boot/default/blobs.list"
+ if [ "${deletegit}" = "true" ]; then
+ rm -rf "${ubtree}"/.git* "${ubtree}"/*/.git*
+ fi
+ blobslist="$(print_blobs_list_path "${board}")"
for blob_path in $(strip_comments "${blobslist}"); do
if echo "${blob_path}" | \
grep '/$' 2>&1 >/dev/null ; then
printf "Deleting blob directory: '%s/%s'\n" \
- "${uboot_dir}" "${blob_path}"
- rm -rf "${uboot_dir}/${blob_path}"
+ "${ubtree}" "${blob_path}"
+ rm -rf "${ubtree}/${blob_path}"
else
printf "Deleting blob file: '%s/%s'\n" \
- "${uboot_dir}" "${blob_path}"
- rm -f "${uboot_dir}/${blob_path}"
+ "${ubtree}" "${blob_path}"
+ rm -f "${ubtree}/${blob_path}"
fi
done
fi
@@ -216,72 +330,83 @@ download_uboot_revision()
print_blobs_list_path()
{
- printf "resources/u-boot/default/blobs.list\n"
+ board="$1"
+
+ if [ -f "resources/u-boot/${board}/blobs.list" ]; then
+ printf "resources/u-boot/${board}/blobs.list\n"
+ else
+ printf "resources/u-boot/default/blobs.list\n"
+ fi
}
print_deblob_script_path()
{
- version="$1"
+ board="$1"
path="$(mktemp)"
- generate_deblob_script "$(print_blobs_list_path ${version})" "${path}"
+ generate_deblob_script "$(print_blobs_list_path ${board})" "${path}"
printf "%s\n" ${path}
}
if [ $# -eq 0 ] ; then
- latest_revision="$(echo ${supported_uboot_revisions} | tail -n1)"
- download_uboot_revision "${latest_revision}"
+ for board in $(list_supported_boards); do
+ download_uboot_board "${board}"
+ done
+
+ if [ "${deletegit}" = "true" ]; then
+ rm -rf u-boot/u-boot/ u-boot/.git*
+ fi
+
exit 0
elif [ $# -eq 1 -a "$1" == "--help" ] ; then
usage
exit 0
-elif [ $# -eq 1 -a "$1" == "--list-revisions" ] ; then
- for revision in ${supported_uboot_revisions} ; do
- printf "${revision}\n"
- done
+elif [ $# -eq 1 -a "$1" == "--list-boards" ] ; then
+ list_supported_boards
exit 0
elif [ $# -eq 1 -a "$1" == "--blobs-list" ] ; then
- latest_revision="$(echo ${supported_uboot_revisions} | tail -n1)"
- print_blobs_list_path "${latest_revision}"
+ print_blobs_list_path "default"
exit 0
elif [ $# -eq 2 -a "$1" == "--blobs-list" ] ; then
found=0
- for revision in ${supported_uboot_revisions} ; do
- if [ "${revision}" = "$2" ] ; then
+ for board in $(list_supported_boards) ; do
+ if [ "${board}" = "$2" ] ; then
print_blobs_list_path "$2"
exit 0
fi
done
- printf "Error: Revision '${1}' is not supported\n"
+ printf "Error: Board '${2}' is not supported\n"
exit 1
elif [ $# -eq 1 -a "$1" == "--gen-deblob-script" ] ; then
- latest_revision="$(echo ${supported_uboot_revisions} | tail -n1)"
- print_deblob_script_path "${latest_revision}"
+ print_deblob_script_path "default"
exit 0
elif [ $# -eq 2 -a "$1" == "--gen-deblob-script" ] ; then
found=0
- for revision in ${supported_uboot_revisions} ; do
- if [ "${revision}" = "$2" ] ; then
+ for board in $(list_supported_boards) ; do
+ if [ "$board" = "$2" ] ; then
print_deblob_script_path "$2"
exit 0
fi
done
- printf "Error: Revision '${1}' is not supported\n"
+ printf "Error: Board '${2}' is not supported\n"
exit 1
elif [ $# -eq 1 ] ; then
- found=0
- for revision in ${supported_uboot_revisions} ; do
- if [ "${revision}" = "$1" ] ; then
- download_uboot_revision "$1"
+ for board in $(list_supported_boards) ; do
+ if [ "$board" = "$1" ] ; then
+ download_uboot_board "$1"
exit 0
fi
done
- printf "Error: Revision '${1}' is not supported\n"
+ if [ "${deletegit}" = "true" ]; then
+ rm -rf u-boot/u-boot/ u-boot/.git*
+ fi
+
+ printf "Error: Board '${1}' is not supported\n"
exit 1
fi
diff --git a/resources/scripts/modify/u-boot/configs b/resources/scripts/modify/u-boot/configs
new file mode 100755
index 00000000..0ae749bb
--- /dev/null
+++ b/resources/scripts/modify/u-boot/configs
@@ -0,0 +1,83 @@
+#!/usr/bin/env bash
+
+#
+# helper script: modify U-Boot configs (run make menuconfig)
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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/>.
+#
+
+# 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 "Modifying U-Boot configs\n"
+
+# Build ROM images for supported boards
+modifyconf() {
+ board="$1"
+ if [ -f "resources/u-boot/${board}/board.cfg" ]; then
+ ubtree="undefined"
+ source "resources/u-boot/${board}/board.cfg"
+ if [ "${ubtree}" = "undefined" ]; then
+ return 0
+ fi
+ if [ ! -d "u-boot/${ubtree}" ]; then
+ ./download u-boot ${ubtree}
+ fi
+ for ubcfg in resources/u-boot/${board}/config/*; do
+ if [ ! -f ${ubcfg} ]; then
+ continue
+ fi
+ (
+ cd u-boot/${ubtree}/
+ rm -f .config*
+ make distclean
+ )
+ mv $ubcfg u-boot/${ubtree}/.config
+ (
+ cd u-boot/${ubtree}/
+ make menuconfig
+ )
+ mv u-boot/${ubtree}/.config $ubcfg
+ rm -f u-boot/${ubtree}/.config*
+ (
+ cd u-boot/${ubtree}/
+ make distclean
+ )
+ done
+ else
+ printf "\nmodify/config/u-boot: no board.cfg for: %s\n" "${board}"
+ fi
+}
+
+if [ $# -gt 0 ]; then
+ for board in "${@}"; do
+ modifyconf "${board}"
+ done
+else
+ for board in resources/u-boot/*; do
+ if [ ! -d "${board}" ]; then
+ continue
+ fi
+ modifyconf "${board##*/}"
+ done
+fi
+
+printf "\n\n"
+
diff --git a/resources/scripts/update/u-boot/configs b/resources/scripts/update/u-boot/configs
new file mode 100755
index 00000000..462dc4e1
--- /dev/null
+++ b/resources/scripts/update/u-boot/configs
@@ -0,0 +1,83 @@
+#!/usr/bin/env bash
+
+#
+# helper script: update U-Boot configs (run make oldconfig)
+#
+# Copyright (C) 2021 Leah Rowe <info@minifree.org>
+# Copyright (C) 2022 Alper Nebi Yasak <alpernebiyasak@gmail.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/>.
+#
+
+# 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 U-Boot configs\n"
+
+# Build ROM images for supported boards
+updateconf() {
+ board="$1"
+ if [ -f "resources/u-boot/${board}/board.cfg" ]; then
+ ubtree="undefined"
+ source "resources/u-boot/${board}/board.cfg"
+ if [ "${ubtree}" = "undefined" ]; then
+ return 0
+ fi
+ if [ ! -d "u-boot/${ubtree}" ]; then
+ ./download u-boot ${ubtree}
+ fi
+ for ubcfg in resources/u-boot/${board}/config/*; do
+ if [ ! -f ${ubcfg} ]; then
+ continue
+ fi
+ (
+ cd u-boot/${ubtree}/
+ rm -f .config*
+ make distclean
+ )
+ mv $ubcfg u-boot/${ubtree}/.config
+ (
+ cd u-boot/${ubtree}/
+ make oldconfig
+ )
+ mv u-boot/${ubtree}/.config $ubcfg
+ rm -f u-boot/${ubtree}/.config*
+ (
+ cd u-boot/${ubtree}/
+ make distclean
+ )
+ done
+ else
+ printf "\nupdate/config/u-boot: no board.cfg for: %s\n" "${board}"
+ fi
+}
+
+if [ $# -gt 0 ]; then
+ for board in "${@}"; do
+ updateconf "${board}"
+ done
+else
+ for board in resources/u-boot/*; do
+ if [ ! -d "${board}" ]; then
+ continue
+ fi
+ updateconf "${board##*/}"
+ done
+fi
+
+printf "\n\n"
+