| # |
| # Copyright (C) 2019 The Android Open Source Project |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| |
| # ############################################################### |
| # This file includes BoardConfig.mk for the device being built, |
| # and checks the variable defined therein. |
| # ############################################################### |
| |
| _board_strip_readonly_list := |
| _board_strip_readonly_list += BOARD_BOOTLOADER_IN_UPDATE_PACKAGE |
| _board_strip_readonly_list += BOARD_EGL_CFG |
| _board_strip_readonly_list += BOARD_HAVE_BLUETOOTH |
| _board_strip_readonly_list += BOARD_INSTALLER_CMDLINE |
| _board_strip_readonly_list += BOARD_KERNEL_CMDLINE |
| _board_strip_readonly_list += BOARD_BOOT_HEADER_VERSION |
| _board_strip_readonly_list += BOARD_BOOTCONFIG |
| _board_strip_readonly_list += BOARD_KERNEL_BASE |
| _board_strip_readonly_list += BOARD_USES_GENERIC_AUDIO |
| _board_strip_readonly_list += BOARD_USES_RECOVERY_AS_BOOT |
| _board_strip_readonly_list += BOARD_VENDOR_USE_AKMD |
| _board_strip_readonly_list += BOARD_WPA_SUPPLICANT_DRIVER |
| _board_strip_readonly_list += BOARD_WLAN_DEVICE |
| _board_strip_readonly_list += TARGET_BOARD_PLATFORM |
| _board_strip_readonly_list += TARGET_BOARD_PLATFORM_GPU |
| _board_strip_readonly_list += TARGET_BOOTLOADER_BOARD_NAME |
| _board_strip_readonly_list += TARGET_FS_CONFIG_GEN |
| _board_strip_readonly_list += TARGET_NO_BOOTLOADER |
| _board_strip_readonly_list += TARGET_NO_KERNEL |
| _board_strip_readonly_list += TARGET_NO_RECOVERY |
| _board_strip_readonly_list += TARGET_NO_RADIOIMAGE |
| _board_strip_readonly_list += TARGET_HARDWARE_3D |
| _board_strip_readonly_list += WITH_DEXPREOPT |
| |
| # Arch variables |
| _board_strip_readonly_list += TARGET_ARCH |
| _board_strip_readonly_list += TARGET_ARCH_VARIANT |
| _board_strip_readonly_list += TARGET_CPU_ABI |
| _board_strip_readonly_list += TARGET_CPU_ABI2 |
| _board_strip_readonly_list += TARGET_CPU_VARIANT |
| _board_strip_readonly_list += TARGET_CPU_VARIANT_RUNTIME |
| _board_strip_readonly_list += TARGET_2ND_ARCH |
| _board_strip_readonly_list += TARGET_2ND_ARCH_VARIANT |
| _board_strip_readonly_list += TARGET_2ND_CPU_ABI |
| _board_strip_readonly_list += TARGET_2ND_CPU_ABI2 |
| _board_strip_readonly_list += TARGET_2ND_CPU_VARIANT |
| _board_strip_readonly_list += TARGET_2ND_CPU_VARIANT_RUNTIME |
| # TARGET_ARCH_SUITE is an alternative arch configuration to TARGET_ARCH (and related variables), |
| # that can be used for soong-only builds to build for several architectures at once. |
| # Allowed values currently are "ndk" and "mainline_sdk". |
| _board_strip_readonly_list += TARGET_ARCH_SUITE |
| |
| # File system variables |
| _board_strip_readonly_list += BOARD_FLASH_BLOCK_SIZE |
| _board_strip_readonly_list += BOARD_BOOTIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_INIT_BOOT_IMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_RECOVERYIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEMIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEMIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_USERDATAIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_USERDATAIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_CACHEIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_VENDORIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_PRODUCTIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_SYSTEM_EXTIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_ODMIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_ODMIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_VENDOR_DLKMIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_ODM_DLKMIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_ODM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_SYSTEM_DLKMIMAGE_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| _board_strip_readonly_list += BOARD_PVMFWIMAGE_PARTITION_SIZE |
| |
| # Logical partitions related variables. |
| _board_strip_readonly_list += BOARD_SYSTEMIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_VENDORIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_ODMIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_VENDOR_DLKMIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_ODM_DLKMIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEM_DLKMIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_PRODUCTIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_SYSTEM_EXTIMAGE_PARTITION_RESERVED_SIZE |
| _board_strip_readonly_list += BOARD_SUPER_PARTITION_SIZE |
| _board_strip_readonly_list += BOARD_SUPER_PARTITION_GROUPS |
| |
| # Kernel related variables |
| _board_strip_readonly_list += BOARD_KERNEL_BINARIES |
| _board_strip_readonly_list += BOARD_KERNEL_MODULE_INTERFACE_VERSIONS |
| |
| # Variables related to generic kernel image (GKI) and generic boot image |
| # - BOARD_USES_GENERIC_KERNEL_IMAGE is the global variable that defines if the |
| # board uses GKI and generic boot image. |
| # Update mechanism of the boot image is not enforced by this variable. |
| # - BOARD_EXCLUDE_KERNEL_FROM_RECOVERY_IMAGE controls whether the recovery image |
| # contains a kernel or not. |
| # - BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT controls whether ramdisk |
| # recovery resources are built to vendor_boot. |
| # - BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT controls whether recovery |
| # resources are built as a standalone recovery ramdisk in vendor_boot. |
| # - BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT controls whether GSI AVB keys are |
| # built to vendor_boot. |
| # - BOARD_COPY_BOOT_IMAGE_TO_TARGET_FILES controls whether boot images in $OUT are added |
| # to target files package directly. |
| _board_strip_readonly_list += BOARD_USES_GENERIC_KERNEL_IMAGE |
| _board_strip_readonly_list += BOARD_EXCLUDE_KERNEL_FROM_RECOVERY_IMAGE |
| _board_strip_readonly_list += BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT |
| _board_strip_readonly_list += BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT |
| _board_strip_readonly_list += BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT |
| _board_strip_readonly_list += BOARD_COPY_BOOT_IMAGE_TO_TARGET_FILES |
| |
| # Prebuilt image variables |
| _board_strip_readonly_list += BOARD_PREBUILT_INIT_BOOT_IMAGE |
| |
| # Defines the list of logical vendor ramdisk names to build or include in vendor_boot. |
| _board_strip_readonly_list += BOARD_VENDOR_RAMDISK_FRAGMENTS |
| |
| # These are all variables used to build $(INSTALLED_MISC_INFO_TARGET) |
| # in build/make/core/Makefile. Their values get used in command line |
| # arguments, so they have to be stripped to make the ninja files stable. |
| _board_strip_list := |
| _board_strip_list += BOARD_DTBOIMG_PARTITION_SIZE |
| _board_strip_list += BOARD_AVB_DTBO_KEY_PATH |
| _board_strip_list += BOARD_AVB_DTBO_ALGORITHM |
| _board_strip_list += BOARD_AVB_DTBO_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_AVB_PVMFW_KEY_PATH |
| _board_strip_list += BOARD_AVB_PVMFW_ALGORITHM |
| _board_strip_list += BOARD_AVB_PVMFW_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_PARTIAL_OTA_UPDATE_PARTITIONS_LIST |
| _board_strip_list += BOARD_AVB_VBMETA_VENDOR_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_AVB_VBMETA_VENDOR_ALGORITHM |
| _board_strip_list += BOARD_AVB_VBMETA_VENDOR_KEY_PATH |
| _board_strip_list += BOARD_AVB_VBMETA_VENDOR |
| _board_strip_list += BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_AVB_VBMETA_SYSTEM_ALGORITHM |
| _board_strip_list += BOARD_AVB_VBMETA_SYSTEM_KEY_PATH |
| _board_strip_list += BOARD_AVB_VBMETA_SYSTEM |
| _board_strip_list += BOARD_AVB_RECOVERY_KEY_PATH |
| _board_strip_list += BOARD_AVB_RECOVERY_ALGORITHM |
| _board_strip_list += BOARD_AVB_RECOVERY_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_AVB_VENDOR_BOOT_KEY_PATH |
| _board_strip_list += BOARD_AVB_VENDOR_BOOT_ALGORITHM |
| _board_strip_list += BOARD_AVB_VENDOR_BOOT_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_AVB_VENDOR_KERNEL_BOOT_KEY_PATH |
| _board_strip_list += BOARD_AVB_VENDOR_KERNEL_BOOT_ALGORITHM |
| _board_strip_list += BOARD_AVB_VENDOR_KERNEL_BOOT_ROLLBACK_INDEX_LOCATION |
| _board_strip_list += BOARD_MKBOOTIMG_ARGS |
| _board_strip_list += BOARD_VENDOR_BOOTIMAGE_PARTITION_SIZE |
| _board_strip_list += BOARD_VENDOR_KERNEL_BOOTIMAGE_PARTITION_SIZE |
| _board_strip_list += ODM_MANIFEST_SKUS |
| |
| |
| _build_broken_var_list := \ |
| BUILD_BROKEN_CLANG_PROPERTY \ |
| BUILD_BROKEN_CLANG_ASFLAGS \ |
| BUILD_BROKEN_CLANG_CFLAGS \ |
| BUILD_BROKEN_DEPFILE \ |
| BUILD_BROKEN_DUP_RULES \ |
| BUILD_BROKEN_DUP_SYSPROP \ |
| BUILD_BROKEN_ELF_PREBUILT_PRODUCT_COPY_FILES \ |
| BUILD_BROKEN_ENFORCE_SYSPROP_OWNER \ |
| BUILD_BROKEN_INPUT_DIR_MODULES \ |
| BUILD_BROKEN_MISSING_REQUIRED_MODULES \ |
| BUILD_BROKEN_OUTSIDE_INCLUDE_DIRS \ |
| BUILD_BROKEN_PREBUILT_ELF_FILES \ |
| BUILD_BROKEN_TREBLE_SYSPROP_NEVERALLOW \ |
| BUILD_BROKEN_USES_NETWORK \ |
| BUILD_BROKEN_VENDOR_PROPERTY_NAMESPACE \ |
| BUILD_BROKEN_VINTF_PRODUCT_COPY_FILES \ |
| BUILD_BROKEN_INCORRECT_PARTITION_IMAGES \ |
| BUILD_BROKEN_GENRULE_SANDBOXING \ |
| BUILD_BROKEN_DONT_CHECK_SYSTEMSDK \ |
| |
| _build_broken_var_list += \ |
| $(foreach m,$(AVAILABLE_BUILD_MODULE_TYPES) \ |
| $(DEFAULT_WARNING_BUILD_MODULE_TYPES) \ |
| $(DEFAULT_ERROR_BUILD_MODULE_TYPES), \ |
| BUILD_BROKEN_USES_$(m)) |
| |
| _board_true_false_vars := $(_build_broken_var_list) |
| _board_strip_readonly_list += $(_build_broken_var_list) \ |
| BUILD_BROKEN_NINJA_USES_ENV_VARS |
| |
| # Conditional to building on linux, as dex2oat currently does not work on darwin. |
| ifeq ($(HOST_OS),linux) |
| WITH_DEXPREOPT ?= true |
| endif |
| |
| # ############################################################### |
| # Broken build defaults |
| # ############################################################### |
| $(foreach v,$(_build_broken_var_list),$(eval $(v) :=)) |
| BUILD_BROKEN_NINJA_USES_ENV_VARS := |
| |
| # Boards may be defined under $(SRC_TARGET_DIR)/board/$(TARGET_DEVICE) |
| # or under vendor/*/$(TARGET_DEVICE). Search in both places, but |
| # make sure only one exists. |
| # Real boards should always be associated with an OEM vendor. |
| ifdef TARGET_DEVICE_DIR |
| ifneq ($(origin TARGET_DEVICE_DIR),command line) |
| $(error TARGET_DEVICE_DIR may not be set manually) |
| endif |
| board_config_mk := $(TARGET_DEVICE_DIR)/BoardConfig.mk |
| else |
| board_config_mk := \ |
| $(strip $(sort $(wildcard \ |
| $(SRC_TARGET_DIR)/board/$(TARGET_DEVICE)/BoardConfig.mk \ |
| device/generic/goldfish/board/$(TARGET_DEVICE)/BoardConfig.mk \ |
| device/google/cuttlefish/board/$(TARGET_DEVICE)/BoardConfig.mk \ |
| $(shell test -d device && find -L device -maxdepth 4 -path '*/$(TARGET_DEVICE)/BoardConfig.mk') \ |
| $(shell test -d vendor && find -L vendor -maxdepth 4 -path '*/$(TARGET_DEVICE)/BoardConfig.mk') \ |
| ))) |
| ifeq ($(board_config_mk),) |
| $(error No config file found for TARGET_DEVICE $(TARGET_DEVICE)) |
| endif |
| ifneq ($(words $(board_config_mk)),1) |
| $(error Multiple board config files for TARGET_DEVICE $(TARGET_DEVICE): $(board_config_mk)) |
| endif |
| TARGET_DEVICE_DIR := $(patsubst %/,%,$(dir $(board_config_mk))) |
| .KATI_READONLY := TARGET_DEVICE_DIR |
| endif |
| |
| ifndef RBC_PRODUCT_CONFIG |
| include $(board_config_mk) |
| else |
| $(shell mkdir -p $(OUT_DIR)/rbc) |
| $(call dump-variables-rbc, $(OUT_DIR)/rbc/make_vars_pre_board_config.mk) |
| |
| $(shell $(OUT_DIR)/mk2rbc \ |
| --mode=write -r --outdir $(OUT_DIR)/rbc \ |
| --boardlauncher=$(OUT_DIR)/rbc/boardlauncher.rbc \ |
| --input_variables=$(OUT_DIR)/rbc/make_vars_pre_board_config.mk \ |
| --makefile_list=$(OUT_DIR)/.module_paths/configuration.list \ |
| $(board_config_mk)) |
| ifneq ($(.SHELLSTATUS),0) |
| $(error board configuration converter failed: $(.SHELLSTATUS)) |
| endif |
| |
| $(shell build/soong/scripts/update_out $(OUT_DIR)/rbc/rbc_board_config_results.mk \ |
| $(OUT_DIR)/rbcrun --mode=rbc $(OUT_DIR)/rbc/boardlauncher.rbc) |
| ifneq ($(.SHELLSTATUS),0) |
| $(error board configuration runner failed: $(.SHELLSTATUS)) |
| endif |
| |
| include $(OUT_DIR)/rbc/rbc_board_config_results.mk |
| endif |
| |
| ifneq (,$(and $(TARGET_ARCH),$(TARGET_ARCH_SUITE))) |
| $(error $(board_config_mk) erroneously sets both TARGET_ARCH and TARGET_ARCH_SUITE) |
| endif |
| ifeq ($(TARGET_ARCH)$(TARGET_ARCH_SUITE),) |
| $(error Target architectures not defined by board config: $(board_config_mk)) |
| endif |
| ifeq ($(TARGET_CPU_ABI)$(TARGET_ARCH_SUITE),) |
| $(error TARGET_CPU_ABI not defined by board config: $(board_config_mk)) |
| endif |
| |
| ifneq ($(MALLOC_IMPL),) |
| $(warning *** Unsupported option MALLOC_IMPL defined by board config: $(board_config_mk).) |
| $(error Use `MALLOC_LOW_MEMORY := true` to use low-memory allocator config) |
| endif |
| board_config_mk := |
| |
| # Clean up and verify BoardConfig variables |
| $(foreach var,$(_board_strip_readonly_list),$(eval $(var) := $$(strip $$($(var))))) |
| $(foreach var,$(_board_strip_list),$(eval $(var) := $$(strip $$($(var))))) |
| $(foreach var,$(_board_true_false_vars), \ |
| $(if $(filter-out true false,$($(var))), \ |
| $(error Valid values of $(var) are "true", "false", and "". Not "$($(var))"))) |
| |
| include $(BUILD_SYSTEM)/board_config_wifi.mk |
| |
| # Set up soong config for "soong_config_value_variable". |
| -include vendor/google/build/soong/soong_config_namespace/camera.mk |
| |
| # Default *_CPU_VARIANT_RUNTIME to CPU_VARIANT if unspecified. |
| TARGET_CPU_VARIANT_RUNTIME := $(or $(TARGET_CPU_VARIANT_RUNTIME),$(TARGET_CPU_VARIANT)) |
| TARGET_2ND_CPU_VARIANT_RUNTIME := $(or $(TARGET_2ND_CPU_VARIANT_RUNTIME),$(TARGET_2ND_CPU_VARIANT)) |
| |
| ifdef TARGET_ARCH |
| # The combo makefiles check and set defaults for various CPU configuration |
| combo_target := TARGET_ |
| combo_2nd_arch_prefix := |
| include $(BUILD_SYSTEM)/combo/select.mk |
| endif |
| |
| ifdef TARGET_2ND_ARCH |
| combo_2nd_arch_prefix := $(TARGET_2ND_ARCH_VAR_PREFIX) |
| include $(BUILD_SYSTEM)/combo/select.mk |
| endif |
| |
| .KATI_READONLY := $(_board_strip_readonly_list) |
| |
| INTERNAL_KERNEL_CMDLINE := $(BOARD_KERNEL_CMDLINE) |
| ifneq (,$(BOARD_BOOTCONFIG)) |
| INTERNAL_KERNEL_CMDLINE += bootconfig |
| INTERNAL_BOOTCONFIG := $(BOARD_BOOTCONFIG) |
| endif |
| |
| ifneq ($(filter %64,$(TARGET_ARCH)),) |
| TARGET_IS_64_BIT := true |
| endif |
| |
| ifeq (,$(filter true,$(TARGET_SUPPORTS_32_BIT_APPS) $(TARGET_SUPPORTS_64_BIT_APPS))) |
| TARGET_SUPPORTS_32_BIT_APPS := true |
| endif |
| |
| # Quick check to warn about likely cryptic errors later in the build. |
| ifeq ($(TARGET_IS_64_BIT),true) |
| ifeq (,$(filter true false,$(TARGET_SUPPORTS_64_BIT_APPS))) |
| $(error Building a 32-bit-app-only product on a 64-bit device. \ |
| If this is intentional, set TARGET_SUPPORTS_64_BIT_APPS := false) |
| endif |
| endif |
| |
| # "ro.product.cpu.abilist32" and "ro.product.cpu.abilist64" are |
| # comma separated lists of the 32 and 64 bit ABIs (in order of |
| # preference) that the target supports. If TARGET_CPU_ABI_LIST_{32,64}_BIT |
| # are defined by the board config, we use them. Else, we construct |
| # these lists based on whether TARGET_IS_64_BIT is set. |
| # |
| # Note that this assumes that the 2ND_CPU_ABI for a 64 bit target |
| # is always 32 bits. If this isn't the case, these variables should |
| # be overriden in the board configuration. |
| # |
| # Similarly, TARGET_NATIVE_BRIDGE_2ND_ABI for a 64 bit target is always |
| # 32 bits. Note that all CPU_ABIs are preferred over all NATIVE_BRIDGE_ABIs. |
| _target_native_bridge_abi_list_32_bit := |
| _target_native_bridge_abi_list_64_bit := |
| |
| ifeq (,$(TARGET_CPU_ABI_LIST_64_BIT)) |
| ifeq (true|true,$(TARGET_IS_64_BIT)|$(TARGET_SUPPORTS_64_BIT_APPS)) |
| TARGET_CPU_ABI_LIST_64_BIT := $(TARGET_CPU_ABI) $(TARGET_CPU_ABI2) |
| _target_native_bridge_abi_list_64_bit := $(TARGET_NATIVE_BRIDGE_ABI) |
| endif |
| endif |
| |
| # "arm64-v8a-hwasan", the ABI for libraries compiled with HWASAN, is supported |
| # in all builds with SANITIZE_TARGET=hwaddress. |
| ifneq ($(filter hwaddress,$(SANITIZE_TARGET)),) |
| ifneq ($(filter arm64-v8a,$(TARGET_CPU_ABI_LIST_64_BIT)),) |
| TARGET_CPU_ABI_LIST_64_BIT := arm64-v8a-hwasan $(TARGET_CPU_ABI_LIST_64_BIT) |
| endif |
| endif |
| |
| ifeq (,$(TARGET_CPU_ABI_LIST_32_BIT)) |
| ifneq (true,$(TARGET_IS_64_BIT)) |
| TARGET_CPU_ABI_LIST_32_BIT := $(TARGET_CPU_ABI) $(TARGET_CPU_ABI2) |
| _target_native_bridge_abi_list_32_bit := $(TARGET_NATIVE_BRIDGE_ABI) |
| else |
| ifeq (true,$(TARGET_SUPPORTS_32_BIT_APPS)) |
| # For a 64 bit target, assume that the 2ND_CPU_ABI |
| # is a 32 bit ABI. |
| TARGET_CPU_ABI_LIST_32_BIT := $(TARGET_2ND_CPU_ABI) $(TARGET_2ND_CPU_ABI2) |
| _target_native_bridge_abi_list_32_bit := $(TARGET_NATIVE_BRIDGE_2ND_ABI) |
| endif |
| endif |
| endif |
| |
| # "ro.product.cpu.abilist" is a comma separated list of ABIs (in order |
| # of preference) that the target supports. If a TARGET_CPU_ABI_LIST |
| # is specified by the board configuration, we use that. If not, we |
| # build a list out of the TARGET_CPU_ABIs specified by the config. |
| # Add NATIVE_BRIDGE_ABIs at the end to keep order of preference. |
| ifeq (,$(TARGET_CPU_ABI_LIST)) |
| TARGET_CPU_ABI_LIST := $(TARGET_CPU_ABI_LIST_64_BIT) $(TARGET_CPU_ABI_LIST_32_BIT) \ |
| $(_target_native_bridge_abi_list_64_bit) $(_target_native_bridge_abi_list_32_bit) |
| endif |
| |
| # Add NATIVE_BRIDGE_ABIs at the end of 32 and 64 bit CPU_ABIs to keep order of preference. |
| TARGET_CPU_ABI_LIST_32_BIT += $(_target_native_bridge_abi_list_32_bit) |
| TARGET_CPU_ABI_LIST_64_BIT += $(_target_native_bridge_abi_list_64_bit) |
| |
| # Strip whitespace from the ABI list string. |
| TARGET_CPU_ABI_LIST := $(subst $(space),$(comma),$(strip $(TARGET_CPU_ABI_LIST))) |
| TARGET_CPU_ABI_LIST_32_BIT := $(subst $(space),$(comma),$(strip $(TARGET_CPU_ABI_LIST_32_BIT))) |
| TARGET_CPU_ABI_LIST_64_BIT := $(subst $(space),$(comma),$(strip $(TARGET_CPU_ABI_LIST_64_BIT))) |
| |
| # Check if config about image building is valid or not. |
| define check_image_config |
| $(eval _uc_name := $(call to-upper,$(1))) \ |
| $(eval _lc_name := $(call to-lower,$(1))) \ |
| $(if $(filter $(_lc_name),$(TARGET_COPY_OUT_$(_uc_name))), \ |
| $(if $(BOARD_USES_$(_uc_name)IMAGE),, \ |
| $(error If TARGET_COPY_OUT_$(_uc_name) is '$(_lc_name)', either BOARD_PREBUILT_$(_uc_name)IMAGE or BOARD_$(_uc_name)IMAGE_FILE_SYSTEM_TYPE must be set)), \ |
| $(if $(BOARD_USES_$(_uc_name)IMAGE), \ |
| $(error TARGET_COPY_OUT_$(_uc_name) must be set to '$(_lc_name)' to use a $(_lc_name) image))) \ |
| $(eval _uc_name :=) \ |
| $(eval _lc_name :=) |
| endef |
| |
| ########################################### |
| # Configure whether we're building the system image |
| BUILDING_SYSTEM_IMAGE := true |
| ifeq ($(PRODUCT_BUILD_SYSTEM_IMAGE),) |
| ifndef PRODUCT_USE_DYNAMIC_PARTITION_SIZE |
| ifndef BOARD_SYSTEMIMAGE_PARTITION_SIZE |
| BUILDING_SYSTEM_IMAGE := |
| endif |
| endif |
| else ifeq ($(PRODUCT_BUILD_SYSTEM_IMAGE),false) |
| BUILDING_SYSTEM_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_SYSTEM_IMAGE |
| |
| # Are we building a system_other image |
| BUILDING_SYSTEM_OTHER_IMAGE := |
| ifeq ($(PRODUCT_BUILD_SYSTEM_OTHER_IMAGE),) |
| ifdef BUILDING_SYSTEM_IMAGE |
| ifeq ($(BOARD_USES_SYSTEM_OTHER_ODEX),true) |
| BUILDING_SYSTEM_OTHER_IMAGE := true |
| endif |
| endif |
| else ifeq ($(PRODUCT_BUILD_SYSTEM_OTHER_IMAGE),true) |
| BUILDING_SYSTEM_OTHER_IMAGE := true |
| ifndef BUILDING_SYSTEM_IMAGE |
| $(error PRODUCT_BUILD_SYSTEM_OTHER_IMAGE = true requires building the system image) |
| endif |
| endif |
| .KATI_READONLY := BUILDING_SYSTEM_OTHER_IMAGE |
| |
| # Are we building a cache image |
| BUILDING_CACHE_IMAGE := |
| ifeq ($(PRODUCT_BUILD_CACHE_IMAGE),) |
| ifdef BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_CACHE_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_CACHE_IMAGE),true) |
| BUILDING_CACHE_IMAGE := true |
| ifndef BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_CACHE_IMAGE set to true, but BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| .KATI_READONLY := BUILDING_CACHE_IMAGE |
| |
| # Are we building a boot image |
| BUILDING_BOOT_IMAGE := |
| ifeq ($(PRODUCT_BUILD_BOOT_IMAGE),) |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| BUILDING_BOOT_IMAGE := |
| else ifdef BOARD_PREBUILT_BOOTIMAGE |
| BUILDING_BOOT_IMAGE := |
| else ifdef BOARD_BOOTIMAGE_PARTITION_SIZE |
| BUILDING_BOOT_IMAGE := true |
| else ifneq (,$(foreach kernel,$(BOARD_KERNEL_BINARIES),$(BOARD_$(call to-upper,$(kernel))_BOOTIMAGE_PARTITION_SIZE))) |
| BUILDING_BOOT_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_BOOT_IMAGE),true) |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| $(warning *** PRODUCT_BUILD_BOOT_IMAGE is true, but so is BOARD_USES_RECOVERY_AS_BOOT.) |
| $(warning *** Skipping building boot image.) |
| BUILDING_BOOT_IMAGE := |
| else |
| BUILDING_BOOT_IMAGE := true |
| endif |
| endif |
| .KATI_READONLY := BUILDING_BOOT_IMAGE |
| |
| # Are we building an init boot image |
| BUILDING_INIT_BOOT_IMAGE := |
| ifeq ($(PRODUCT_BUILD_INIT_BOOT_IMAGE),) |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| BUILDING_INIT_BOOT_IMAGE := |
| else ifdef BOARD_PREBUILT_INIT_BOOT_IMAGE |
| BUILDING_INIT_BOOT_IMAGE := |
| else ifdef BOARD_INIT_BOOT_IMAGE_PARTITION_SIZE |
| BUILDING_INIT_BOOT_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_INIT_BOOT_IMAGE),true) |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| $(error PRODUCT_BUILD_INIT_BOOT_IMAGE is true, but so is BOARD_USES_RECOVERY_AS_BOOT. Use only one option.) |
| else |
| BUILDING_INIT_BOOT_IMAGE := true |
| endif |
| endif |
| .KATI_READONLY := BUILDING_INIT_BOOT_IMAGE |
| |
| # Are we building a recovery image |
| BUILDING_RECOVERY_IMAGE := |
| ifeq ($(PRODUCT_BUILD_RECOVERY_IMAGE),) |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| BUILDING_RECOVERY_IMAGE := true |
| else ifeq ($(BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT),true) |
| # Set to true to build recovery resources for vendor_boot |
| BUILDING_RECOVERY_IMAGE := true |
| else ifdef BOARD_RECOVERYIMAGE_PARTITION_SIZE |
| ifeq (,$(filter true, $(TARGET_NO_KERNEL) $(TARGET_NO_RECOVERY))) |
| BUILDING_RECOVERY_IMAGE := true |
| endif |
| endif |
| else ifeq ($(PRODUCT_BUILD_RECOVERY_IMAGE),true) |
| BUILDING_RECOVERY_IMAGE := true |
| endif |
| .KATI_READONLY := BUILDING_RECOVERY_IMAGE |
| |
| # Are we building a vendor boot image |
| BUILDING_VENDOR_BOOT_IMAGE := |
| ifdef BOARD_BOOT_HEADER_VERSION |
| ifneq ($(call math_gt_or_eq,$(BOARD_BOOT_HEADER_VERSION),3),) |
| ifeq ($(PRODUCT_BUILD_VENDOR_BOOT_IMAGE),) |
| BUILDING_VENDOR_BOOT_IMAGE := true |
| else ifeq ($(PRODUCT_BUILD_VENDOR_BOOT_IMAGE),true) |
| BUILDING_VENDOR_BOOT_IMAGE := true |
| endif |
| endif |
| endif |
| .KATI_READONLY := BUILDING_VENDOR_BOOT_IMAGE |
| |
| # Are we building a vendor kernel boot image |
| BUILDING_VENDOR_KERNEL_BOOT_IMAGE := |
| ifeq ($(PRODUCT_BUILD_VENDOR_KERNEL_BOOT_IMAGE),true) |
| ifneq ($(BUILDING_VENDOR_BOOT_IMAGE),true) |
| $(error BUILDING_VENDOR_BOOT_IMAGE is required, but BUILDING_VENDOR_BOOT_IMAGE is not true) |
| endif |
| ifndef BOARD_VENDOR_KERNEL_BOOTIMAGE_PARTITION_SIZE |
| $(error BOARD_VENDOR_KERNEL_BOOTIMAGE_PARTITION_SIZE is required when PRODUCT_BUILD_VENDOR_KERNEL_BOOT_IMAGE is true) |
| endif |
| BUILDING_VENDOR_KERNEL_BOOT_IMAGE := true |
| else ifeq ($(PRODUCT_BUILD_VENDOR_KERNEL),) |
| ifdef BOARD_VENDOR_KERNEL_BOOTIMAGE_PARTITION_SIZE |
| ifeq ($(BUILDING_VENDOR_BOOT_IMAGE),true) |
| BUILDING_VENDOR_KERNEL_BOOT_IMAGE := true |
| endif |
| endif |
| endif # end of PRODUCT_BUILD_VENDOR_KERNEL_BOOT_IMAGE |
| .KATI_READONLY := BUILDING_VENDOR_KERNEL_BOOT_IMAGE |
| |
| # Are we building a ramdisk image |
| BUILDING_RAMDISK_IMAGE := true |
| ifeq ($(PRODUCT_BUILD_RAMDISK_IMAGE),) |
| # TODO: Be smarter about this. This probably only needs to happen when one of the follow is true: |
| # BUILDING_BOOT_IMAGE |
| # BUILDING_RECOVERY_IMAGE |
| else ifeq ($(PRODUCT_BUILD_RAMDISK_IMAGE),false) |
| BUILDING_RAMDISK_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_RAMDISK_IMAGE |
| |
| # Are we building a debug vendor_boot image |
| BUILDING_DEBUG_VENDOR_BOOT_IMAGE := |
| # Can't build vendor_boot-debug.img if we're not building a ramdisk. |
| ifndef BUILDING_RAMDISK_IMAGE |
| ifeq ($(PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE),true) |
| $(warning PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE is true, but we're not building a ramdisk image. \ |
| Skip building the debug vendor_boot image.) |
| endif |
| # Can't build vendor_boot-debug.img if we're not building a vendor_boot.img. |
| else ifndef BUILDING_VENDOR_BOOT_IMAGE |
| ifeq ($(PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE),true) |
| $(warning PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE is true, but we're not building a vendor_boot image. \ |
| Skip building the debug vendor_boot image.) |
| endif |
| else |
| ifeq ($(PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE),) |
| BUILDING_DEBUG_VENDOR_BOOT_IMAGE := true |
| else ifeq ($(PRODUCT_BUILD_DEBUG_VENDOR_BOOT_IMAGE),true) |
| BUILDING_DEBUG_VENDOR_BOOT_IMAGE := true |
| endif |
| endif |
| .KATI_READONLY := BUILDING_DEBUG_VENDOR_BOOT_IMAGE |
| |
| _has_boot_img_artifact := |
| ifneq ($(strip $(TARGET_NO_KERNEL)),true) |
| ifdef BUILDING_BOOT_IMAGE |
| _has_boot_img_artifact := true |
| endif |
| # BUILDING_RECOVERY_IMAGE && BOARD_USES_RECOVERY_AS_BOOT implies that |
| # recovery is being built with the file name *boot.img*, which still counts |
| # as "building boot.img". |
| ifdef BUILDING_RECOVERY_IMAGE |
| ifeq ($(BOARD_USES_RECOVERY_AS_BOOT),true) |
| _has_boot_img_artifact := true |
| endif |
| endif |
| endif |
| |
| # Are we building a debug boot image |
| BUILDING_DEBUG_BOOT_IMAGE := |
| # Can't build boot-debug.img if we're not building a ramdisk. |
| ifndef BUILDING_RAMDISK_IMAGE |
| ifeq ($(PRODUCT_BUILD_DEBUG_BOOT_IMAGE),true) |
| $(warning PRODUCT_BUILD_DEBUG_BOOT_IMAGE is true, but we're not building a ramdisk image. \ |
| Skip building the debug boot image.) |
| endif |
| # Can't build boot-debug.img if we're not building a boot.img. |
| else ifndef _has_boot_img_artifact |
| ifeq ($(PRODUCT_BUILD_DEBUG_BOOT_IMAGE),true) |
| $(warning PRODUCT_BUILD_DEBUG_BOOT_IMAGE is true, but we're not building a boot image. \ |
| Skip building the debug boot image.) |
| endif |
| else ifdef BUILDING_INIT_BOOT_IMAGE |
| ifeq ($(PRODUCT_BUILD_DEBUG_BOOT_IMAGE),true) |
| $(warning PRODUCT_BUILD_DEBUG_BOOT_IMAGE is true, but we don't have a ramdisk in the boot image. \ |
| Skip building the debug boot image.) |
| endif |
| else |
| ifeq ($(PRODUCT_BUILD_DEBUG_BOOT_IMAGE),) |
| BUILDING_DEBUG_BOOT_IMAGE := true |
| # Don't build boot-debug.img if we're already building vendor_boot-debug.img. |
| ifdef BUILDING_DEBUG_VENDOR_BOOT_IMAGE |
| BUILDING_DEBUG_BOOT_IMAGE := |
| endif |
| else ifeq ($(PRODUCT_BUILD_DEBUG_BOOT_IMAGE),true) |
| BUILDING_DEBUG_BOOT_IMAGE := true |
| endif |
| endif |
| .KATI_READONLY := BUILDING_DEBUG_BOOT_IMAGE |
| _has_boot_img_artifact := |
| |
| # Are we building a userdata image |
| BUILDING_USERDATA_IMAGE := |
| ifeq ($(PRODUCT_BUILD_USERDATA_IMAGE),) |
| ifdef BOARD_USERDATAIMAGE_PARTITION_SIZE |
| BUILDING_USERDATA_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_USERDATA_IMAGE),true) |
| BUILDING_USERDATA_IMAGE := true |
| endif |
| .KATI_READONLY := BUILDING_USERDATA_IMAGE |
| |
| # Are we building a vbmeta image |
| BUILDING_VBMETA_IMAGE := true |
| ifeq ($(PRODUCT_BUILD_VBMETA_IMAGE),false) |
| BUILDING_VBMETA_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_VBMETA_IMAGE |
| |
| # Are we building a super_empty image |
| BUILDING_SUPER_EMPTY_IMAGE := |
| ifeq ($(PRODUCT_BUILD_SUPER_EMPTY_IMAGE),) |
| ifeq (true,$(PRODUCT_USE_DYNAMIC_PARTITIONS)) |
| ifneq ($(BOARD_SUPER_PARTITION_SIZE),) |
| BUILDING_SUPER_EMPTY_IMAGE := true |
| endif |
| endif |
| else ifeq ($(PRODUCT_BUILD_SUPER_EMPTY_IMAGE),true) |
| ifneq (true,$(PRODUCT_USE_DYNAMIC_PARTITIONS)) |
| $(error PRODUCT_BUILD_SUPER_EMPTY_IMAGE set to true, but PRODUCT_USE_DYNAMIC_PARTITIONS is not true) |
| endif |
| ifeq ($(BOARD_SUPER_PARTITION_SIZE),) |
| $(error PRODUCT_BUILD_SUPER_EMPTY_IMAGE set to true, but BOARD_SUPER_PARTITION_SIZE is not defined) |
| endif |
| BUILDING_SUPER_EMPTY_IMAGE := true |
| endif |
| .KATI_READONLY := BUILDING_SUPER_EMPTY_IMAGE |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_VENDOR |
| ifeq ($(TARGET_COPY_OUT_VENDOR),$(_vendor_path_placeholder)) |
| TARGET_COPY_OUT_VENDOR := system/vendor |
| else ifeq ($(filter vendor system/vendor,$(TARGET_COPY_OUT_VENDOR)),) |
| $(error TARGET_COPY_OUT_VENDOR must be either 'vendor' or 'system/vendor', seeing '$(TARGET_COPY_OUT_VENDOR)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_vendor_path_placeholder),$(TARGET_COPY_OUT_VENDOR),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_VENDORIMAGE := |
| ifdef BOARD_PREBUILT_VENDORIMAGE |
| BOARD_USES_VENDORIMAGE := true |
| endif |
| ifdef BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_VENDORIMAGE := true |
| endif |
| # TODO(b/137169253): For now, some AOSP targets build with prebuilt vendor image. |
| # But target's BOARD_PREBUILT_VENDORIMAGE is not filled. |
| ifeq ($(TARGET_COPY_OUT_VENDOR),vendor) |
| BOARD_USES_VENDORIMAGE := true |
| else ifdef BOARD_USES_VENDORIMAGE |
| $(error TARGET_COPY_OUT_VENDOR must be set to 'vendor' to use a vendor image) |
| endif |
| .KATI_READONLY := BOARD_USES_VENDORIMAGE |
| |
| BUILDING_VENDOR_IMAGE := |
| ifeq ($(PRODUCT_BUILD_VENDOR_IMAGE),) |
| ifdef BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_VENDOR_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_VENDOR_IMAGE),true) |
| BUILDING_VENDOR_IMAGE := true |
| ifndef BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_VENDOR_IMAGE set to true, but BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_VENDORIMAGE |
| BUILDING_VENDOR_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_VENDOR_IMAGE |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_PRODUCT |
| ifeq ($(TARGET_COPY_OUT_PRODUCT),$(_product_path_placeholder)) |
| TARGET_COPY_OUT_PRODUCT := system/product |
| else ifeq ($(filter product system/product,$(TARGET_COPY_OUT_PRODUCT)),) |
| $(error TARGET_COPY_OUT_PRODUCT must be either 'product' or 'system/product', seeing '$(TARGET_COPY_OUT_PRODUCT)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_product_path_placeholder),$(TARGET_COPY_OUT_PRODUCT),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_PRODUCTIMAGE := |
| ifdef BOARD_PREBUILT_PRODUCTIMAGE |
| BOARD_USES_PRODUCTIMAGE := true |
| endif |
| ifdef BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_PRODUCTIMAGE := true |
| endif |
| $(call check_image_config,product) |
| .KATI_READONLY := BOARD_USES_PRODUCTIMAGE |
| |
| BUILDING_PRODUCT_IMAGE := |
| ifeq ($(PRODUCT_BUILD_PRODUCT_IMAGE),) |
| ifdef BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_PRODUCT_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_PRODUCT_IMAGE),true) |
| BUILDING_PRODUCT_IMAGE := true |
| ifndef BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_PRODUCT_IMAGE set to true, but BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_PRODUCTIMAGE |
| BUILDING_PRODUCT_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_PRODUCT_IMAGE |
| |
| ########################################### |
| # TODO(b/135957588) TARGET_COPY_OUT_PRODUCT_SERVICES will be set to |
| # TARGET_COPY_OUT_PRODUCT as a workaround. |
| TARGET_COPY_OUT_PRODUCT_SERVICES := $(TARGET_COPY_OUT_PRODUCT) |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_SYSTEM_EXT |
| ifeq ($(TARGET_COPY_OUT_SYSTEM_EXT),$(_system_ext_path_placeholder)) |
| TARGET_COPY_OUT_SYSTEM_EXT := system/system_ext |
| else ifeq ($(filter system_ext system/system_ext,$(TARGET_COPY_OUT_SYSTEM_EXT)),) |
| $(error TARGET_COPY_OUT_SYSTEM_EXT must be either 'system_ext' or 'system/system_ext', seeing '$(TARGET_COPY_OUT_SYSTEM_EXT)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_system_ext_path_placeholder),$(TARGET_COPY_OUT_SYSTEM_EXT),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_SYSTEM_EXTIMAGE := |
| ifdef BOARD_PREBUILT_SYSTEM_EXTIMAGE |
| BOARD_USES_SYSTEM_EXTIMAGE := true |
| endif |
| ifdef BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_SYSTEM_EXTIMAGE := true |
| endif |
| $(call check_image_config,system_ext) |
| .KATI_READONLY := BOARD_USES_SYSTEM_EXTIMAGE |
| |
| BUILDING_SYSTEM_EXT_IMAGE := |
| ifeq ($(PRODUCT_BUILD_SYSTEM_EXT_IMAGE),) |
| ifdef BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_SYSTEM_EXT_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_SYSTEM_EXT_IMAGE),true) |
| BUILDING_SYSTEM_EXT_IMAGE := true |
| ifndef BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_SYSTEM_EXT_IMAGE set to true, but BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_SYSTEM_EXTIMAGE |
| BUILDING_SYSTEM_EXT_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_SYSTEM_EXT_IMAGE |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_VENDOR_DLKM |
| ifeq ($(TARGET_COPY_OUT_VENDOR_DLKM),$(_vendor_dlkm_path_placeholder)) |
| TARGET_COPY_OUT_VENDOR_DLKM := $(TARGET_COPY_OUT_VENDOR)/vendor_dlkm |
| else ifeq ($(filter vendor_dlkm system/vendor/vendor_dlkm vendor/vendor_dlkm,$(TARGET_COPY_OUT_VENDOR_DLKM)),) |
| $(error TARGET_COPY_OUT_VENDOR_DLKM must be either 'vendor_dlkm', 'system/vendor/vendor_dlkm' or 'vendor/vendor_dlkm', seeing '$(TARGET_COPY_OUT_VENDOR_DLKM)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_vendor_dlkm_path_placeholder),$(TARGET_COPY_OUT_VENDOR_DLKM),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_VENDOR_DLKMIMAGE := |
| ifdef BOARD_PREBUILT_VENDOR_DLKMIMAGE |
| BOARD_USES_VENDOR_DLKMIMAGE := true |
| endif |
| ifdef BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_VENDOR_DLKMIMAGE := true |
| endif |
| $(call check_image_config,vendor_dlkm) |
| |
| BUILDING_VENDOR_DLKM_IMAGE := |
| ifeq ($(PRODUCT_BUILD_VENDOR_DLKM_IMAGE),) |
| ifdef BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_VENDOR_DLKM_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_VENDOR_DLKM_IMAGE),true) |
| BUILDING_VENDOR_DLKM_IMAGE := true |
| ifndef BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_VENDOR_DLKM_IMAGE set to true, but BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_VENDOR_DLKMIMAGE |
| BUILDING_VENDOR_DLKM_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_VENDOR_DLKM_IMAGE |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_ODM |
| ifeq ($(TARGET_COPY_OUT_ODM),$(_odm_path_placeholder)) |
| TARGET_COPY_OUT_ODM := $(TARGET_COPY_OUT_VENDOR)/odm |
| else ifeq ($(filter odm system/vendor/odm vendor/odm,$(TARGET_COPY_OUT_ODM)),) |
| $(error TARGET_COPY_OUT_ODM must be either 'odm', 'system/vendor/odm' or 'vendor/odm', seeing '$(TARGET_COPY_OUT_ODM)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_odm_path_placeholder),$(TARGET_COPY_OUT_ODM),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_ODMIMAGE := |
| ifdef BOARD_PREBUILT_ODMIMAGE |
| BOARD_USES_ODMIMAGE := true |
| endif |
| ifdef BOARD_ODMIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_ODMIMAGE := true |
| endif |
| $(call check_image_config,odm) |
| |
| BUILDING_ODM_IMAGE := |
| ifeq ($(PRODUCT_BUILD_ODM_IMAGE),) |
| ifdef BOARD_ODMIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_ODM_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_ODM_IMAGE),true) |
| BUILDING_ODM_IMAGE := true |
| ifndef BOARD_ODMIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_ODM_IMAGE set to true, but BOARD_ODMIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_ODMIMAGE |
| BUILDING_ODM_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_ODM_IMAGE |
| |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_ODM_DLKM |
| ifeq ($(TARGET_COPY_OUT_ODM_DLKM),$(_odm_dlkm_path_placeholder)) |
| TARGET_COPY_OUT_ODM_DLKM := $(TARGET_COPY_OUT_VENDOR)/odm_dlkm |
| else ifeq ($(filter odm_dlkm system/vendor/odm_dlkm vendor/odm_dlkm,$(TARGET_COPY_OUT_ODM_DLKM)),) |
| $(error TARGET_COPY_OUT_ODM_DLKM must be either 'odm_dlkm', 'system/vendor/odm_dlkm' or 'vendor/odm_dlkm', seeing '$(TARGET_COPY_OUT_ODM_DLKM)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_odm_dlkm_path_placeholder),$(TARGET_COPY_OUT_ODM_DLKM),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_ODM_DLKMIMAGE := |
| ifdef BOARD_PREBUILT_ODM_DLKMIMAGE |
| BOARD_USES_ODM_DLKMIMAGE := true |
| endif |
| ifdef BOARD_ODM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_ODM_DLKMIMAGE := true |
| endif |
| $(call check_image_config,odm_dlkm) |
| |
| BUILDING_ODM_DLKM_IMAGE := |
| ifeq ($(PRODUCT_BUILD_ODM_DLKM_IMAGE),) |
| ifdef BOARD_ODM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_ODM_DLKM_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_ODM_DLKM_IMAGE),true) |
| BUILDING_ODM_DLKM_IMAGE := true |
| ifndef BOARD_ODM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_ODM_DLKM_IMAGE set to true, but BOARD_ODM_DLKMIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_ODM_DLKMIMAGE |
| BUILDING_ODM_DLKM_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_ODM_DLKM_IMAGE |
| |
| ########################################### |
| # Now we can substitute with the real value of TARGET_COPY_OUT_SYSTEM_DLKM |
| ifeq ($(TARGET_COPY_OUT_SYSTEM_DLKM),$(_system_dlkm_path_placeholder)) |
| TARGET_COPY_OUT_SYSTEM_DLKM := $(TARGET_COPY_OUT_SYSTEM)/system_dlkm |
| else ifeq ($(filter system_dlkm system/system_dlkm,$(TARGET_COPY_OUT_SYSTEM_DLKM)),) |
| $(error TARGET_COPY_OUT_SYSTEM_DLKM must be either 'system_dlkm' or 'system/system_dlkm', seeing '$(TARGET_COPY_OUT_ODM_DLKM)'.) |
| endif |
| PRODUCT_COPY_FILES := $(subst $(_system_dlkm_path_placeholder),$(TARGET_COPY_OUT_SYSTEM_DLKM),$(PRODUCT_COPY_FILES)) |
| |
| BOARD_USES_SYSTEM_DLKMIMAGE := |
| ifdef BOARD_PREBUILT_SYSTEM_DLKMIMAGE |
| BOARD_USES_SYSTEM_DLKMIMAGE := true |
| endif |
| ifdef BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BOARD_USES_SYSTEM_DLKMIMAGE := true |
| endif |
| $(call check_image_config,system_dlkm) |
| |
| BUILDING_SYSTEM_DLKM_IMAGE := |
| ifeq ($(PRODUCT_BUILD_SYSTEM_DLKM_IMAGE),) |
| ifdef BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| BUILDING_SYSTEM_DLKM_IMAGE := true |
| endif |
| else ifeq ($(PRODUCT_BUILD_SYSTEM_DLKM_IMAGE),true) |
| BUILDING_SYSTEM_DLKM_IMAGE := true |
| ifndef BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE |
| $(error PRODUCT_BUILD_SYSTEM_DLKM_IMAGE set to true, but BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE not defined) |
| endif |
| endif |
| ifdef BOARD_PREBUILT_SYSTEM_DLKMIMAGE |
| BUILDING_SYSTEM_DLKM_IMAGE := |
| endif |
| .KATI_READONLY := BUILDING_SYSTEM_DLKM_IMAGE |
| |
| BOARD_USES_PVMFWIMAGE := |
| ifeq ($(PRODUCT_BUILD_PVMFW_IMAGE),true) |
| BOARD_USES_PVMFWIMAGE := true |
| endif |
| .KATI_READONLY := BOARD_USES_PVMFWIMAGE |
| |
| ########################################### |
| # Ensure consistency among TARGET_RECOVERY_UPDATER_LIBS, AB_OTA_UPDATER, and PRODUCT_OTA_FORCE_NON_AB_PACKAGE. |
| TARGET_RECOVERY_UPDATER_LIBS ?= |
| AB_OTA_UPDATER ?= |
| .KATI_READONLY := TARGET_RECOVERY_UPDATER_LIBS AB_OTA_UPDATER |
| |
| # Ensure that if PRODUCT_OTA_FORCE_NON_AB_PACKAGE == true, then AB_OTA_UPDATER must be true |
| ifeq ($(PRODUCT_OTA_FORCE_NON_AB_PACKAGE),true) |
| ifneq ($(AB_OTA_UPDATER),true) |
| $(error AB_OTA_UPDATER must be set to true when PRODUCT_OTA_FORCE_NON_AB_PACKAGE is true) |
| endif |
| endif |
| |
| # In some configurations, A/B and non-A/B may coexist. Check TARGET_OTA_ALLOW_NON_AB |
| # to see if non-A/B is supported. |
| TARGET_OTA_ALLOW_NON_AB := false |
| ifneq ($(AB_OTA_UPDATER),true) |
| TARGET_OTA_ALLOW_NON_AB := true |
| else ifeq ($(PRODUCT_OTA_FORCE_NON_AB_PACKAGE),true) |
| TARGET_OTA_ALLOW_NON_AB := true |
| endif |
| .KATI_READONLY := TARGET_OTA_ALLOW_NON_AB |
| |
| ifneq ($(TARGET_OTA_ALLOW_NON_AB),true) |
| ifneq ($(strip $(TARGET_RECOVERY_UPDATER_LIBS)),) |
| $(error Do not use TARGET_RECOVERY_UPDATER_LIBS when using TARGET_OTA_ALLOW_NON_AB) |
| endif |
| endif |
| |
| # For Non A/B full OTA, disable brotli compression. |
| ifeq ($(TARGET_OTA_ALLOW_NON_AB),true) |
| BOARD_NON_AB_OTA_DISABLE_COMPRESSION := true |
| endif |
| |
| # Quick check for building generic OTA packages. Currently it only supports A/B OTAs. |
| ifeq ($(PRODUCT_BUILD_GENERIC_OTA_PACKAGE),true) |
| ifneq ($(AB_OTA_UPDATER),true) |
| $(error PRODUCT_BUILD_GENERIC_OTA_PACKAGE with 'AB_OTA_UPDATER != true' is not supported) |
| endif |
| endif |
| |
| ifdef BOARD_PREBUILT_DTBIMAGE_DIR |
| ifneq ($(BOARD_INCLUDE_DTB_IN_BOOTIMG),true) |
| $(error BOARD_PREBUILT_DTBIMAGE_DIR with 'BOARD_INCLUDE_DTB_IN_BOOTIMG != true' is not supported) |
| endif |
| endif |
| |
| # Check BOARD_VNDK_VERSION |
| define check_vndk_version |
| $(eval vndk_path := prebuilts/vndk/v$(1)) \ |
| $(if $(wildcard $(vndk_path)/*/Android.bp),,$(error VNDK version $(1) not found)) |
| endef |
| |
| TARGET_VENDOR_TEST_SUFFIX := /vendor |
| |
| ifeq (,$(TARGET_BUILD_UNBUNDLED)) |
| ifdef PRODUCT_EXTRA_VNDK_VERSIONS |
| $(foreach v,$(PRODUCT_EXTRA_VNDK_VERSIONS),$(call check_vndk_version,$(v))) |
| endif |
| endif |
| |
| # Ensure that BOARD_SYSTEMSDK_VERSIONS are all within PLATFORM_SYSTEMSDK_VERSIONS |
| _unsupported_systemsdk_versions := $(filter-out $(PLATFORM_SYSTEMSDK_VERSIONS),$(BOARD_SYSTEMSDK_VERSIONS)) |
| ifneq (,$(_unsupported_systemsdk_versions)) |
| $(error System SDK versions '$(_unsupported_systemsdk_versions)' in BOARD_SYSTEMSDK_VERSIONS are not supported.\ |
| Supported versions are $(PLATFORM_SYSTEMSDK_VERSIONS)) |
| endif |
| |
| ########################################### |
| # BOARD_API_LEVEL for vendor API surface |
| ifdef RELEASE_BOARD_API_LEVEL |
| ifdef BOARD_API_LEVEL |
| $(error BOARD_API_LEVEL must not be set manually. The build system automatically sets this value.) |
| endif |
| BOARD_API_LEVEL := $(RELEASE_BOARD_API_LEVEL) |
| .KATI_READONLY := BOARD_API_LEVEL |
| endif |
| |
| ########################################### |
| # Handle BUILD_BROKEN_USES_BUILD_* |
| |
| $(foreach m,$(DEFAULT_WARNING_BUILD_MODULE_TYPES),\ |
| $(if $(filter false,$(BUILD_BROKEN_USES_$(m))),\ |
| $(KATI_obsolete_var $(m),Please convert to Soong),\ |
| $(KATI_deprecated_var $(m),Please convert to Soong))) |
| |
| $(if $(filter true,$(BUILD_BROKEN_USES_BUILD_COPY_HEADERS)),\ |
| $(KATI_deprecated_var BUILD_COPY_HEADERS,See $(CHANGES_URL)\#copy_headers),\ |
| $(KATI_obsolete_var BUILD_COPY_HEADERS,See $(CHANGES_URL)\#copy_headers)) |
| |
| $(foreach m,$(filter-out BUILD_COPY_HEADERS,$(DEFAULT_ERROR_BUILD_MODULE_TYPES)),\ |
| $(if $(filter true,$(BUILD_BROKEN_USES_$(m))),\ |
| $(KATI_deprecated_var $(m),Please convert to Soong),\ |
| $(KATI_obsolete_var $(m),Please convert to Soong))) |
| |
| ifndef BUILDING_RECOVERY_IMAGE |
| ifeq (true,$(BOARD_EXCLUDE_KERNEL_FROM_RECOVERY_IMAGE)) |
| $(error Should not set BOARD_EXCLUDE_KERNEL_FROM_RECOVERY_IMAGE if not building recovery image) |
| endif |
| endif |
| |
| ifndef BUILDING_VENDOR_BOOT_IMAGE |
| ifeq (true,$(BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT)) |
| $(error Should not set BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT if not building vendor_boot image) |
| endif |
| ifdef BOARD_VENDOR_RAMDISK_FRAGMENTS |
| $(error Should not set BOARD_VENDOR_RAMDISK_FRAGMENTS if not building vendor_boot image) |
| endif |
| else # BUILDING_VENDOR_BOOT_IMAGE |
| ifneq (,$(call math_lt,$(BOARD_BOOT_HEADER_VERSION),4)) |
| ifdef BOARD_VENDOR_RAMDISK_FRAGMENTS |
| $(error Should not set BOARD_VENDOR_RAMDISK_FRAGMENTS if \ |
| BOARD_BOOT_HEADER_VERSION is less than 4) |
| endif |
| ifeq (true,$(BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT)) |
| $(error Should not set BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT if \ |
| BOARD_BOOT_HEADER_VERSION is less than 4) |
| endif |
| endif |
| endif # BUILDING_VENDOR_BOOT_IMAGE |
| |
| ifneq ($(words $(BOARD_VENDOR_RAMDISK_FRAGMENTS)),$(words $(sort $(BOARD_VENDOR_RAMDISK_FRAGMENTS)))) |
| $(error BOARD_VENDOR_RAMDISK_FRAGMENTS has duplicate entries: $(BOARD_VENDOR_RAMDISK_FRAGMENTS)) |
| endif |
| |
| ifeq (true,$(BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT)) |
| ifneq (true,$(BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT)) |
| $(error Should not set BOARD_INCLUDE_RECOVERY_RAMDISK_IN_VENDOR_BOOT if \ |
| BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT is not set) |
| endif |
| endif |
| |
| # If BOARD_USES_GENERIC_KERNEL_IMAGE is set, BOARD_USES_RECOVERY_AS_BOOT must not be set. |
| # Devices without a dedicated recovery partition uses BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT to |
| # build recovery into vendor_boot. |
| ifeq (true,$(BOARD_USES_GENERIC_KERNEL_IMAGE)) |
| ifeq (true,$(BOARD_USES_RECOVERY_AS_BOOT)) |
| $(error BOARD_USES_RECOVERY_AS_BOOT cannot be true if BOARD_USES_GENERIC_KERNEL_IMAGE is true. \ |
| Use BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT instead) |
| endif |
| endif |
| |
| ifeq (true,$(BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT)) |
| ifeq (true,$(BOARD_USES_RECOVERY_AS_BOOT)) |
| $(error BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT and BOARD_USES_RECOVERY_AS_BOOT cannot be \ |
| both true. Recovery resources should be installed to either boot or vendor_boot, but not both) |
| endif |
| endif |