mirror of
https://github.com/armbian/build.git
synced 2025-08-12 06:06:58 +02:00
97 lines
4.9 KiB
Bash
97 lines
4.9 KiB
Bash
function compile_firmware_light_and_possibly_full() {
|
|
if [[ "${INSTALL_ARMBIAN_FIRMWARE:-yes}" == "yes" ]]; then # Build firmware by default.
|
|
# Build the "light" version of firmware packages, with no conditions.
|
|
FULL="" REPLACE="-full" LOG_SECTION="compile_firmware" do_with_logging compile_firmware
|
|
|
|
# Now, we'll build the "full" version of firmware packages, if:
|
|
# 1) We've CI==true, or stdout is not a terminal, or
|
|
# 2) We've been asked to install it for the board being built, BOARD_FIRMWARE_INSTALL="-full"
|
|
if [[ "${CI}" == "true" || ! -t 1 || "${BOARD_FIRMWARE_INSTALL}" == "-full" ]]; then
|
|
# Build the full version of firmware package
|
|
FULL="-full" REPLACE="" LOG_SECTION="compile_firmware_full" do_with_logging compile_firmware
|
|
else
|
|
display_alert "Skipping full firmware package build" "" "info"
|
|
fi
|
|
fi
|
|
return 0
|
|
}
|
|
|
|
function compile_firmware() {
|
|
display_alert "Merging and packaging linux firmware" "@host --> firmware${FULL}" "info"
|
|
|
|
declare cleanup_id="" fw_temp_dir=""
|
|
prepare_temp_dir_in_workdir_and_schedule_cleanup "deb-firmware${FULL}" cleanup_id fw_temp_dir # namerefs
|
|
|
|
declare fw_dir="armbian-firmware${FULL}"
|
|
mkdir -p "${fw_temp_dir}/${fw_dir}/lib/firmware"
|
|
|
|
local ARMBIAN_FIRMWARE_GIT_SOURCE="${ARMBIAN_FIRMWARE_GIT_SOURCE:-"https://github.com/armbian/firmware"}"
|
|
local ARMBIAN_FIRMWARE_GIT_BRANCH="${ARMBIAN_FIRMWARE_GIT_BRANCH:-"master"}"
|
|
|
|
# Fetch Armbian firmware from git.
|
|
declare fetched_revision
|
|
do_checkout="no" fetch_from_repo "${ARMBIAN_FIRMWARE_GIT_SOURCE}" "armbian-firmware-git" "branch:${ARMBIAN_FIRMWARE_GIT_BRANCH}"
|
|
declare -r armbian_firmware_git_sha1="${fetched_revision}"
|
|
|
|
declare extra_conflicts_comma=""
|
|
if [[ -n $FULL ]]; then
|
|
# Fetch kernel firmware from git. This is large, but we don't have two copies of it anymore. So more manageable.
|
|
declare fetched_revision
|
|
do_checkout="no" fetch_from_repo "$MAINLINE_FIRMWARE_SOURCE" "linux-firmware-git" "branch:main"
|
|
declare -r mainline_firmware_git_sha1="${fetched_revision}"
|
|
|
|
# use git archive to export the ${mainline_firmware_git_sha1} revision into "${fw_temp_dir}/${fw_dir}/lib/firmware/"
|
|
run_host_command_logged git -C "${SRC}/cache/sources/linux-firmware-git" archive --format=tar "${mainline_firmware_git_sha1}" "|" tar -C "${fw_temp_dir}/${fw_dir}/lib/firmware/" -xf -
|
|
|
|
# Full version conflicts with more stuff, of course.
|
|
extra_conflicts_comma=",amd64-microcode,intel-microcode"
|
|
|
|
# @TODO: rpardini: disabled, this is not the place to do this; move to extension/bsp/whatever
|
|
# cp : create hardlinks for ath11k WCN685x hw2.1 firmware since they are using the same firmware with hw2.0
|
|
# run_host_command_logged cp -af --reflink=auto "${fw_temp_dir}/${fw_dir}/lib/firmware/ath11k/WCN6855/hw2.0/" "${fw_temp_dir}/${fw_dir}/lib/firmware/ath11k/WCN6855/hw2.1/"
|
|
fi
|
|
|
|
# Armbian firmware; this overwrites anything in the mainline firmware repo (if that was included, in the full version only)
|
|
run_host_command_logged git -C "${SRC}/cache/sources/armbian-firmware-git" archive --format=tar "${armbian_firmware_git_sha1}" "|" tar -C "${fw_temp_dir}/${fw_dir}/lib/firmware/" -xf -
|
|
|
|
# Show the size of the firmware directory in a tree if debugging
|
|
if [[ "${SHOW_DEBUG}" == "yes" ]]; then
|
|
run_host_command_logged tree -C --du -h -L 1 "${fw_temp_dir}/${fw_dir}"/lib/firmware "|| true" # do not fail
|
|
fi
|
|
|
|
cd "${fw_temp_dir}/${fw_dir}" || exit_with_error "can't change directory"
|
|
|
|
# set up control file
|
|
mkdir -p DEBIAN
|
|
# @TODO: rpardini: this needs Conflicts: with the standard Ubuntu/Debian linux-firmware packages and other firmware pkgs in Debian
|
|
cat <<- END > DEBIAN/control
|
|
Package: armbian-firmware${FULL}
|
|
Version: $REVISION
|
|
Architecture: all
|
|
Maintainer: $MAINTAINER <$MAINTAINERMAIL>
|
|
Installed-Size: 1
|
|
Conflicts: linux-firmware, firmware-brcm80211, firmware-ralink, firmware-samsung, firmware-realtek, armbian-firmware${REPLACE}${extra_conflicts_comma}
|
|
Provides: linux-firmware, firmware-brcm80211, firmware-ralink, firmware-samsung, firmware-realtek, armbian-firmware${REPLACE}${extra_conflicts_comma}
|
|
Section: kernel
|
|
Priority: optional
|
|
Description: Armbian - Linux firmware${FULL}
|
|
END
|
|
|
|
cd "${fw_temp_dir}" || exit_with_error "can't change directory"
|
|
|
|
# package
|
|
run_host_command_logged mv -v "armbian-firmware${FULL}" "armbian-firmware${FULL}_${REVISION}_all"
|
|
display_alert "Building firmware package" "armbian-firmware${FULL}_${REVISION}_all" "info"
|
|
|
|
if [[ -n $FULL ]]; then
|
|
display_alert "Full firmware, very big, avoiding tmpfs" "armbian-firmware${FULL}_${REVISION}_all" "info"
|
|
fakeroot_dpkg_deb_build "armbian-firmware${FULL}_${REVISION}_all" "${DEB_STORAGE}"
|
|
else
|
|
fakeroot_dpkg_deb_build "armbian-firmware${FULL}_${REVISION}_all"
|
|
run_host_command_logged mv -v "armbian-firmware${FULL}_${REVISION}_all" "armbian-firmware${FULL}"
|
|
run_host_command_logged rsync -rq "armbian-firmware${FULL}_${REVISION}_all.deb" "${DEB_STORAGE}/"
|
|
fi
|
|
|
|
done_with_temp_dir "${cleanup_id}" # changes cwd to "${SRC}" and fires the cleanup function early
|
|
}
|