build/coreboot/util: merge to update/project/build
The benefit now is that it can be cleaned. E.g. ./update project build -b coreboot utils ./update project build -b coreboot utils default ./update project build -c coreboot utils ./update project build -c coreboot utils default the update/project/build script checks when arguments are provided after the project name. if the first one is "utils", then it acts in the same way as the old build/coreboot/util script Signed-off-by: Leah Rowe <leah@libreboot.org>btrfsvols
parent
b6d9e6c18d
commit
0ed2ec294b
|
@ -1,46 +0,0 @@
|
|||
#!/usr/bin/env sh
|
||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||
# SPDX-FileCopyrightText: 2014-2016,2020,2021,2023 Leah Rowe <leah@libreboot.org>
|
||||
|
||||
[ "x${DEBUG+set}" = 'xset' ] && set -v
|
||||
set -u -e
|
||||
|
||||
. "include/err.sh"
|
||||
. "include/option.sh"
|
||||
|
||||
main()
|
||||
{
|
||||
printf "Building coreboot utils\n"
|
||||
target="${@}"
|
||||
[ $# -gt 0 ] || target=$(listitems config/coreboot) || err "!targets"
|
||||
for x in ${target}; do
|
||||
x_ build_for_mainboard ${x}
|
||||
done
|
||||
}
|
||||
|
||||
build_for_mainboard() {
|
||||
[ -f "config/coreboot/${1}/target.cfg" ] || \
|
||||
err "build_for_mainboard ${1}: target.cfg does not exist"
|
||||
tree=""
|
||||
. "config/coreboot/${1}/target.cfg" # source
|
||||
[ -z ${tree} ] && \
|
||||
err "build_for_mainboard ${1}: improper tree definition"
|
||||
buildutils "${tree}"
|
||||
}
|
||||
|
||||
buildutils() {
|
||||
[ -d "src/coreboot/${1}/" ] || \
|
||||
x_ ./update project trees coreboot ${1}
|
||||
for util in cbfstool ifdtool; do
|
||||
[ -f "cbutils/${1}/${util}" ] && continue
|
||||
[ -d "cbutils/${1}" ] || x_ mkdir -p "cbutils/${1}"
|
||||
|
||||
utildir="src/coreboot/${1}/util/${util}"
|
||||
x_ make distclean -C "${utildir}"
|
||||
x_ make -j$(nproc) -C "${utildir}"
|
||||
x_ cp "${utildir}/${util}" "cbutils/${1}"
|
||||
x_ make distclean -C "${utildir}"
|
||||
done
|
||||
}
|
||||
|
||||
main $@
|
|
@ -125,7 +125,7 @@ prepare_target()
|
|||
cbfstool="cbutils/${tree}/cbfstool"
|
||||
cbrom="${cbdir}/build/coreboot.rom"
|
||||
|
||||
x_ ./build coreboot utils ${tree}
|
||||
x_ ./update project build -b coreboot utils ${tree}
|
||||
|
||||
build_dependency_seabios
|
||||
|
||||
|
|
|
@ -13,7 +13,8 @@ set -u -e
|
|||
export LOCALVERSION="-${projectname}-${version}"
|
||||
|
||||
eval "$(setvars "" arch cfgsdir codedir config config_name crossgcc_ada mode \
|
||||
elfdir listfile project romtype target target_dir targets tree cbfstool _f)"
|
||||
elfdir listfile project romtype target target_dir targets tree cbfstool _f \
|
||||
target1)"
|
||||
|
||||
tmpclean="$(mktemp -d -t makeclean.XXXXXXXXXX)"
|
||||
|
||||
|
@ -72,6 +73,9 @@ build_targets()
|
|||
[ -f "${listfile}" ] || err "list file, ${listfile}, does not exist"
|
||||
|
||||
# Build for all targets if no argument is given
|
||||
[ $# -gt 0 ] && target1="${1}"
|
||||
[ "${target1}" = "utils" ] && [ "${project}" = "coreboot" ] && \
|
||||
shift 1
|
||||
targets=$(listitems "${cfgsdir}") || \
|
||||
err "Cannot get options for ${cfgsdir}"
|
||||
[ $# -gt 0 ] && targets=$@
|
||||
|
@ -92,6 +96,7 @@ handle_targets()
|
|||
x_ handle_defconfig
|
||||
done
|
||||
|
||||
[ "${target1}" = "utils" ] && [ "${project}" = "coreboot" ] && return 0
|
||||
[ -z ${mode} ] || return 0
|
||||
printf "Done! The files are stored under %s/\n\n" "${elfdir}"
|
||||
}
|
||||
|
@ -100,6 +105,11 @@ handle_defconfig()
|
|||
{
|
||||
handle_src_tree "${target}" || return 0
|
||||
|
||||
if [ "${target1}" = "utils" ] && [ "${project}" = "coreboot" ]; then
|
||||
handle_coreboot_utils "${tree}"
|
||||
return 0
|
||||
fi
|
||||
|
||||
for y in "${target_dir}/config"/*; do
|
||||
[ -f "${y}" ] || continue
|
||||
config="${y}"
|
||||
|
@ -114,6 +124,19 @@ handle_defconfig()
|
|||
done
|
||||
}
|
||||
|
||||
handle_coreboot_utils()
|
||||
{
|
||||
for util in cbfstool ifdtool; do
|
||||
x_ ./update project build ${_f} "src/coreboot/${1}/util/${util}"
|
||||
[ -z ${mode} ] && [ ! -f "cbutils/${1}/${util}" ] && \
|
||||
x_ mkdir -p "cbutils/${1}" && \
|
||||
x_ cp "src/coreboot/${1}/util/${util}/${util}" \
|
||||
"cbutils/${1}"
|
||||
[ -z ${mode} ] || \
|
||||
x_ rm -Rf "cbutils/${1}"
|
||||
done
|
||||
}
|
||||
|
||||
handle_src_tree()
|
||||
{
|
||||
target_dir="${cfgsdir}/${target}"
|
||||
|
@ -148,12 +171,15 @@ handle_src_tree()
|
|||
touch "${tmpclean}/${tree}"
|
||||
fi
|
||||
|
||||
[ "${target1}" = "utils" ] && [ "${project}" = "coreboot" ] && return 0
|
||||
|
||||
# u-boot and coreboot are both compiled with coreboot's crossgcc
|
||||
if [ "${project}" = "coreboot" ] || [ "${project}" = "u-boot" ]; then
|
||||
[ ! -z ${mode} ] || check_cross_compiler || \
|
||||
err "handle_src_tree ${project}/${target}: crossgcc"
|
||||
cbfstool="cbutils/${tree}/cbfstool"
|
||||
[ -f "${cbfstool}" ] || x_ ./build coreboot utils "${tree}"
|
||||
[ -f "${cbfstool}" ] || \
|
||||
x_ ./update project build -b coreboot utils "${tree}"
|
||||
fi
|
||||
}
|
||||
|
||||
|
|
|
@ -102,7 +102,7 @@ strip_archive()
|
|||
[ -d "src/coreboot/${tree}" ] || \
|
||||
x_ ./update project trees coreboot ${tree}
|
||||
|
||||
x_ ./build coreboot utils ${tree}
|
||||
x_ ./update project build -b coreboot utils ${tree}
|
||||
|
||||
if [ "${microcode_required}" = "n" ]; then
|
||||
for romfile in "${romdir}"/*.rom; do
|
||||
|
|
|
@ -50,7 +50,7 @@ build_dependencies()
|
|||
x_ ./update project build -b uefitool
|
||||
[ -f "${kbc1126_ec_dump}" ] || \
|
||||
x_ make -C "${cbdir}/util/kbc1126"
|
||||
x_ ./build coreboot utils default
|
||||
x_ ./update project build -b coreboot utils default
|
||||
}
|
||||
|
||||
download_vendorfiles()
|
||||
|
|
|
@ -88,7 +88,7 @@ detect_board()
|
|||
build_dependencies()
|
||||
{
|
||||
[ -d "${cbdir}" ] || x_ ./update project trees coreboot default
|
||||
x_ ./build coreboot utils default
|
||||
x_ ./update project build -b coreboot utils default
|
||||
x_ ./update vendor download ${board}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue