Merge "Define a make target for all APEX dumps" into main
This commit is contained in:
commit
eb74e25ccb
1 changed files with 15 additions and 8 deletions
|
@ -8,7 +8,7 @@ LOCAL_PATH:= $(call my-dir)
|
|||
# Check if vndk list is changed
|
||||
droidcore: check-abi-dump-list
|
||||
|
||||
check-vndk-abi-dump-list-timestamp := $(call intermediates-dir-for,PACKAGING,vndk)/check-abi-dump-list-timestamp
|
||||
check-abi-dump-list-timestamp := $(call intermediates-dir-for,PACKAGING,vndk)/check-abi-dump-list-timestamp
|
||||
|
||||
ifneq ($(SKIP_ABI_CHECKS),true)
|
||||
check-abi-dump-list: $(check-abi-dump-list-timestamp)
|
||||
|
@ -34,6 +34,9 @@ $(patsubst $(tag_patterns),%,$(filter $(tag_patterns),$(2)))
|
|||
endef
|
||||
|
||||
# Subsets of LSDUMP_PATHS.
|
||||
.PHONY: findlsdumps_APEX
|
||||
findlsdumps_APEX: $(LSDUMP_PATHS_FILE) $(call filter-abi-dump-paths,APEX,$(LSDUMP_PATHS))
|
||||
|
||||
.PHONY: findlsdumps_LLNDK
|
||||
findlsdumps_LLNDK: $(LSDUMP_PATHS_FILE) $(call filter-abi-dump-paths,LLNDK,$(LSDUMP_PATHS))
|
||||
|
||||
|
@ -48,7 +51,7 @@ findlsdumps: $(LSDUMP_PATHS_FILE) $(foreach p,$(LSDUMP_PATHS),$(call word-colon,
|
|||
|
||||
#####################################################################
|
||||
# Check that all ABI reference dumps have corresponding
|
||||
# NDK/VNDK/PLATFORM libraries.
|
||||
# APEX/LLNDK/PLATFORM libraries.
|
||||
|
||||
# $(1): The directory containing ABI dumps.
|
||||
# Return a list of ABI dump paths ending with .so.lsdump.
|
||||
|
@ -60,9 +63,12 @@ endef
|
|||
|
||||
# $(1): A list of tags.
|
||||
# $(2): A list of tag:path.
|
||||
# Return the file names of the ABI dumps that match the tags.
|
||||
# Return the file names of the ABI dumps that match the tags, and replace the
|
||||
# file name extensions with .so.lsdump.
|
||||
define filter-abi-dump-names
|
||||
$(notdir $(call filter-abi-dump-paths,$(1),$(2)))
|
||||
$(patsubst %.so.llndk.lsdump,%.so.lsdump, \
|
||||
$(patsubst %.so.apex.lsdump,%.so.lsdump, \
|
||||
$(notdir $(call filter-abi-dump-paths,$(1),$(2)))))
|
||||
endef
|
||||
|
||||
VNDK_ABI_DUMP_DIR := prebuilts/abi-dumps/vndk/$(RELEASE_BOARD_API_LEVEL)
|
||||
|
@ -77,21 +83,22 @@ PLATFORM_ABI_DUMPS := $(call find-abi-dump-paths,$(PLATFORM_ABI_DUMP_DIR))
|
|||
# Check for superfluous lsdump files. Since LSDUMP_PATHS only covers the
|
||||
# libraries that can be built from source in the current build, and prebuilts of
|
||||
# Mainline modules may be in use, we also allow the libs in STUB_LIBRARIES for
|
||||
# NDK and platform ABIs.
|
||||
# platform ABIs.
|
||||
# In addition, libRS is allowed because it's disabled for RISC-V.
|
||||
|
||||
$(check-abi-dump-list-timestamp): PRIVATE_LSDUMP_PATHS := $(LSDUMP_PATHS)
|
||||
$(check-abi-dump-list-timestamp): PRIVATE_STUB_LIBRARIES := $(STUB_LIBRARIES)
|
||||
$(check-abi-dump-list-timestamp):
|
||||
$(eval added_vndk_abi_dumps := $(strip $(sort $(filter-out \
|
||||
$(call filter-abi-dump-names,LLNDK,$(PRIVATE_LSDUMP_PATHS)), \
|
||||
$(call filter-abi-dump-names,LLNDK,$(PRIVATE_LSDUMP_PATHS)) libRS.so.lsdump, \
|
||||
$(notdir $(VNDK_ABI_DUMPS))))))
|
||||
$(if $(added_vndk_abi_dumps), \
|
||||
echo -e "Found unexpected ABI reference dump files under $(VNDK_ABI_DUMP_DIR). It is caused by mismatch between Android.bp and the dump files. Run \`find \$${ANDROID_BUILD_TOP}/$(VNDK_ABI_DUMP_DIR) '(' -name $(subst $(space), -or -name ,$(added_vndk_abi_dumps)) ')' -delete\` to delete the dump files.")
|
||||
|
||||
# TODO(b/314010764): Remove LLNDK tag after PLATFORM_SDK_VERSION is upgraded to 35.
|
||||
$(eval added_platform_abi_dumps := $(strip $(sort $(filter-out \
|
||||
$(call filter-abi-dump-names,LLNDK PLATFORM,$(PRIVATE_LSDUMP_PATHS)) \
|
||||
$(addsuffix .lsdump,$(PRIVATE_STUB_LIBRARIES)), \
|
||||
$(call filter-abi-dump-names,APEX LLNDK PLATFORM,$(PRIVATE_LSDUMP_PATHS)) \
|
||||
$(addsuffix .lsdump,$(PRIVATE_STUB_LIBRARIES)) libRS.so.lsdump, \
|
||||
$(notdir $(PLATFORM_ABI_DUMPS))))))
|
||||
$(if $(added_platform_abi_dumps), \
|
||||
echo -e "Found unexpected ABI reference dump files under $(PLATFORM_ABI_DUMP_DIR). It is caused by mismatch between Android.bp and the dump files. Run \`find \$${ANDROID_BUILD_TOP}/$(PLATFORM_ABI_DUMP_DIR) '(' -name $(subst $(space), -or -name ,$(added_platform_abi_dumps)) ')' -delete\` to delete the dump files.")
|
||||
|
|
Loading…
Reference in a new issue