mirror of
https://github.com/armbian/build.git
synced 2025-09-19 04:31:38 +02:00
> tl-dr: > - maximize OCI cache hit ratio across nightlies/releases/PRs/etc; > - publish simple `Version:`'s that don't include a crazy hash in repo and images > - introduce `output/packages-hashed` directory > - radically change the `output/debs` directory structure - simplify artifact's `prepare_version()` method for `deb` and `deb-tar` artifacts: - `artifact_base_dir` and `artifact_final_file` will now be auto-calculated; thus removed from each artifact (except `rootfs`) - `artifact_deb_repo` ("global", "jammy", "bookworm") is now required; "global" means common across all RELEASES - `artifact_deb_arch` is now required, "all" is arch-independent, otherwise use `${ARCH}` - `artifact_map_debs` is now auto-calculated based on the above, and shouldn't be specified manually - `artifact_final_version_reversioned` is optional, and can force the final version of the artifact (specific for the `base-files` case) - artifacts that need special handling for reversioning can add function names to `artifact_debs_reversion_functions` array (`base-files` and `bsp-cli` cases) - artifacts `prepare_version()` should set `artifact_version`, but _never_ include it in other variables; `artifact_version` is now changed by framework after `prepare_version()` returns - no longer use/refer/mention `${REVISION}` when building packages. All packages should be `${REVISION}`-agnostic. - `${REVISION}` (actually, `artifact_final_version_reversioned`) will be automatically swapped in the `control` file during reversioning - `fakeroot_dpkg_deb_build()` now takes exactly two arguments: the directory to pack, and the deb ID (key of `artifact_map_packages` dict); add this change in all the artifact's code for this - `obtain_complete_artifact()`: - automatically adds `-Rxxxx` "revisioning-hash" to `artifact_version`, by hashing the revisioning functions and any `artifact_debs_reversion_functions` set - calculates more complex subdirectory paths for both the `output/packages-hashed` and `output/debs`/`output/debs-beta` directories - with the new subdirectories we can be sure a re-version is already done correctly and can skip it (eg, for partial `download-debs` re-runs) - in the future we can automatically clean/remove old versions that are no longer relevant based on the dir structure - exports a lot more information to JSON, including the new subdirectory paths - comment-out code that implemented `skip_unpack_if_found_in_caches`, I'm very unsure why we had this in the first place - `obtain_artifact_from_remote_cache()` - for `deb` type artifacts, OCI won't preserve the subdirectory structure, so move downloaded files to the correct subdirectory manually - this is not needed for `deb-tar`, since that can preserve the dir structure itself - introduce `artifacts-reversion.sh` and its main function `artifact_reversion_for_deployment()` - this has the logic for reversioning .deb's, by `ar`-unpacking them, changing `control.tar` (and possibly `data.tar`), handling `.xz` compression, etc. - also handles hashing those functions, for consistency. Any changes in reversioning code actually change the artifact itself so we're not caught by surprise - by default, it changes `control` file only: - replace `Version:` (which is the hash-version originally) with `artifact_final_version_reversioned` (which is mostly just `${REVISION}`) - add a custom field `Armbian-Original-Hash:` with the original hash-version - `artifact_reversion_for_deployment()` is called by - new CLI wrapper `cli_obtain_complete_artifact()`, used for CLI building of specific artifact, but also for `download-artifact` - `build_artifact_for_image()` used during image build - `armbian-bsp-cli-deb.sh`: move `${REVISION}` related stuff from the main package build to new reversioning functions. - `artifact-armbian-base-files.sh`: move `${REVISION}` related stuff from the main package build to new reversioning functions. - `kernel`: - add some custom fields to `DEBIAN/control`: - `Armbian-Kernel-Version:` / `Armbian-Kernel-Version-Family:` (for future use: cleanup of usage of `Source: ` field which should be removed) - declutter the `Description:` field, moving long description out of the first line - obtain `IMAGE_INSTALLED_KERNEL_VERSION` from the reversioned deb (this is still a hack and has not been fixed) - `uboot`: - declutter the `Description:` field, moving long description out of the first line - use the reversioned .deb when deploying u-boot to the image - `main_default_build_packages()` now stores reversioned values and complete paths to reversioned .deb's - `list_installed_packages()` now compares custom field `Armbian-Original-Hash: `, and not the `Version:` to make sure debs in the image are the ones we want - `install_artifact_deb_chroot()` is a new wrapper around `install_deb_chroot()` for easy handling of reversioned debs - use it everywhere `install_deb_chroot()` was used in `distro-agnostic.sh` and `distro-specific.sh`
175 lines
7.1 KiB
Bash
175 lines
7.1 KiB
Bash
#!/usr/bin/env bash
|
|
#
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
#
|
|
# Copyright (c) 2013-2023 Igor Pecovnik, igor@armbian.com
|
|
#
|
|
# This file is a part of the Armbian Build Framework
|
|
# https://github.com/armbian/build/
|
|
|
|
function artifact_armbian-bsp-cli_config_dump() {
|
|
artifact_input_variables[BOARD]="${BOARD}"
|
|
artifact_input_variables[BRANCH]="${BRANCH}"
|
|
artifact_input_variables[EXTRA_BSP_NAME]="${EXTRA_BSP_NAME}"
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_prepare_version() {
|
|
: "${BRANCH:?BRANCH is not set}"
|
|
: "${BOARD:?BOARD is not set}"
|
|
|
|
artifact_version="undetermined" # outer scope
|
|
artifact_version_reason="undetermined" # outer scope
|
|
|
|
declare short_hash_size=4
|
|
|
|
declare fake_unchanging_base_version="1"
|
|
|
|
# hash the contents of "post_family_tweaks_bsp" extension hooks (always) - use framework helper
|
|
# hash the contents of family_tweaks_bsp old-style hooks (if it exists)
|
|
declare -a hooks_to_hash=("$(dump_extension_method_sources_functions "post_family_tweaks_bsp")")
|
|
if [[ $(type -t family_tweaks_bsp) == function ]]; then
|
|
hooks_to_hash+=("$(declare -f "family_tweaks_bsp")")
|
|
fi
|
|
declare hash_hooks="undetermined"
|
|
hash_hooks="$(echo "${hooks_to_hash[@]}" | sha256sum | cut -d' ' -f1)"
|
|
declare hash_hooks_short="${hash_hooks:0:${short_hash_size}}"
|
|
|
|
# get the bootscript info...
|
|
declare -A bootscript_info=()
|
|
get_bootscript_info # fills in bootscript_info array
|
|
|
|
# Hash variables/bootscripts that affect the contents of bsp-cli package.
|
|
# Those contain /armbian a lot, so don't normalize them.
|
|
declare -a vars_to_hash_no_normalize=(
|
|
"bootscript_file_contents: ${bootscript_info[bootscript_file_contents]}"
|
|
"bootenv_file_contents: ${bootscript_info[bootenv_file_contents]}"
|
|
)
|
|
declare hash_variables="undetermined" # will be set by calculate_hash_for_variables(), but without normalization
|
|
do_normalize_src_path="no" calculate_hash_for_variables "${vars_to_hash_no_normalize[@]}" # don't normalize
|
|
declare hash_vars_no_normalize="${hash_variables}"
|
|
|
|
declare -a vars_to_hash=(
|
|
"has_bootscript: ${bootscript_info[has_bootscript]}"
|
|
"has_extlinux: ${bootscript_info[has_extlinux]}"
|
|
"UBOOT_FW_ENV: ${UBOOT_FW_ENV}" # not included in bootscript
|
|
"KEEP_ORIGINAL_OS_RELEASE: ${KEEP_ORIGINAL_OS_RELEASE:-"no"}" # /etc/os-release
|
|
"BOARDFAMILY: ${BOARDFAMILY}" # /etc/armbian-release
|
|
"LINUXFAMILY: ${LINUXFAMILY}" # /etc/armbian-release
|
|
"IMAGE_TYPE: ${IMAGE_TYPE}" # /etc/armbian-release
|
|
"BOARD_TYPE: ${BOARD_TYPE}" # /etc/armbian-release
|
|
"INITRD_ARCH: ${INITRD_ARCH}" # /etc/armbian-release
|
|
"KERNEL_IMAGE_TYPE: ${KERNEL_IMAGE_TYPE}" # /etc/armbian-release
|
|
"VENDOR: ${VENDOR}" # /etc/armbian-release
|
|
"hash_vars_no_normalize: ${hash_vars_no_normalize}" # The non-normalized part, above
|
|
)
|
|
declare hash_variables="undetermined" # will be set by calculate_hash_for_variables(), which normalizes the input
|
|
calculate_hash_for_variables "${vars_to_hash[@]}"
|
|
declare var_config_hash_short="${hash_variables:0:${short_hash_size}}"
|
|
|
|
declare -a dirs_to_hash=(
|
|
"${SRC}/packages/bsp/common" # common stuff
|
|
"${SRC}/packages/bsp-cli"
|
|
"${SRC}/config/optional/_any_board/_packages/bsp-cli"
|
|
"${SRC}/config/optional/architectures/${ARCH}/_packages/bsp-cli"
|
|
"${SRC}/config/optional/families/${LINUXFAMILY}/_packages/bsp-cli"
|
|
"${SRC}/config/optional/boards/${BOARD}/_packages/bsp-cli"
|
|
)
|
|
declare hash_files="undetermined"
|
|
calculate_hash_for_all_files_in_dirs "${dirs_to_hash[@]}"
|
|
packages_config_hash="${hash_files}"
|
|
declare packages_config_hash_short="${packages_config_hash:0:${short_hash_size}}"
|
|
|
|
# get the hashes of the lib/ bash sources involved...
|
|
declare hash_files="undetermined"
|
|
calculate_hash_for_bash_deb_artifact "bsp/armbian-bsp-cli-deb.sh"
|
|
declare bash_hash="${hash_files}"
|
|
declare bash_hash_short="${bash_hash:0:${short_hash_size}}"
|
|
|
|
# outer scope
|
|
artifact_version="${fake_unchanging_base_version}-PC${packages_config_hash_short}-V${var_config_hash_short}-H${hash_hooks_short}-B${bash_hash_short}"
|
|
|
|
declare -a reasons=(
|
|
"Armbian package armbian-bsp-cli"
|
|
"BOARD \"${BOARD}\""
|
|
"BRANCH \"${BRANCH}\""
|
|
"EXTRA_BSP_NAME \"${EXTRA_BSP_NAME}\""
|
|
"Packages and config files hash \"${packages_config_hash}\""
|
|
"Hooks hash \"${hash_hooks}\""
|
|
"Variables/bootscripts hash \"${vars_config_hash}\""
|
|
"framework bash hash \"${bash_hash}\""
|
|
)
|
|
|
|
artifact_version_reason="${reasons[*]}" # outer scope
|
|
|
|
artifact_deb_repo="global" # "global" meaning: release-independent repo. could be '${RELEASE}' for a release-specific package.
|
|
artifact_deb_arch="${ARCH}" # arch-specific package, or 'all' for arch-independent package.
|
|
artifact_name="armbian-bsp-cli-${BOARD}-${BRANCH}${EXTRA_BSP_NAME}"
|
|
artifact_type="deb-tar"
|
|
|
|
artifact_map_packages=(["armbian-bsp-cli"]="${artifact_name}")
|
|
|
|
# Register the function used to re-version the _contents_ of the bsp-cli deb file (non-transitional)
|
|
artifact_debs_reversion_functions+=("reversion_armbian-bsp-cli_deb_contents")
|
|
|
|
if artifact_armbian-bsp-cli_needs_transitional_package; then
|
|
artifact_map_packages+=(["armbian-bsp-cli-transitional"]="armbian-bsp-cli-${BOARD}${EXTRA_BSP_NAME}")
|
|
# Register the function used to re-version the _contents_ of the bsp-cli deb file (transitional)
|
|
artifact_debs_reversion_functions+=("reversion_armbian-bsp-cli-transitional_deb_contents")
|
|
fi
|
|
|
|
return 0
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_build_from_sources() {
|
|
# Generate transitional package when needed.
|
|
if artifact_armbian-bsp-cli_needs_transitional_package; then
|
|
LOG_SECTION="compile_armbian-bsp-cli" do_with_logging compile_armbian-bsp-cli-transitional
|
|
fi
|
|
|
|
LOG_SECTION="compile_armbian-bsp-cli" do_with_logging compile_armbian-bsp-cli
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_cli_adapter_pre_run() {
|
|
declare -g ARMBIAN_COMMAND_REQUIRE_BASIC_DEPS="yes" # Require prepare_host_basic to run before the command.
|
|
|
|
# "gimme root on a Linux machine"
|
|
cli_standard_relaunch_docker_or_sudo
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_cli_adapter_config_prep() {
|
|
# there is no need for aggregation here.
|
|
use_board="yes" allow_no_family="no" skip_kernel="no" prep_conf_main_minimal_ni < /dev/null # no stdin for this, so it bombs if tries to be interactive.
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_get_default_oci_target() {
|
|
artifact_oci_target_base="${GHCR_SOURCE}/armbian/os/"
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_is_available_in_local_cache() {
|
|
is_artifact_available_in_local_cache
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_is_available_in_remote_cache() {
|
|
is_artifact_available_in_remote_cache
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_obtain_from_remote_cache() {
|
|
obtain_artifact_from_remote_cache
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_deploy_to_remote_cache() {
|
|
upload_artifact_to_oci
|
|
}
|
|
|
|
function artifact_armbian-bsp-cli_needs_transitional_package() {
|
|
if [[ "${KERNEL_TARGET}" == "${BRANCH}" ]]; then
|
|
return 0
|
|
elif [[ "${BRANCH}" == "current" ]]; then
|
|
return 0
|
|
elif [[ "${KERNEL_TARGET}" != *current* && "${BRANCH}" == "legacy" ]]; then
|
|
return 0
|
|
else
|
|
return 1
|
|
fi
|
|
}
|