forked from openkylin/platform_build
Merge "CFI include/exclude path support (Make)" am: 61bc4f790e
am: aef48af62a
Change-Id: I601f9cce2189f384ee3263695daa5bd39895a4cb
This commit is contained in:
commit
0fc49655f6
|
@ -34,6 +34,18 @@ ifneq ($(filter integer_overflow, $(my_global_sanitize)),)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Disable global CFI in excluded paths
|
||||||
|
ifneq ($(filter cfi, $(my_global_sanitize)),)
|
||||||
|
combined_exclude_paths := $(CFI_EXCLUDE_PATHS) \
|
||||||
|
$(PRODUCT_CFI_EXCLUDE_PATHS)
|
||||||
|
|
||||||
|
ifneq ($(strip $(foreach dir,$(subst $(comma),$(space),$(combined_exclude_paths)),\
|
||||||
|
$(filter $(dir)%,$(LOCAL_PATH)))),)
|
||||||
|
my_global_sanitize := $(filter-out cfi,$(my_global_sanitize))
|
||||||
|
my_global_sanitize_diag := $(filter-out cfi,$(my_global_sanitize_diag))
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
ifneq ($(my_global_sanitize),)
|
ifneq ($(my_global_sanitize),)
|
||||||
my_sanitize := $(my_global_sanitize) $(my_sanitize)
|
my_sanitize := $(my_global_sanitize) $(my_sanitize)
|
||||||
endif
|
endif
|
||||||
|
@ -84,6 +96,18 @@ ifeq ($(LOCAL_SANITIZE),never)
|
||||||
my_sanitize_diag :=
|
my_sanitize_diag :=
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Enable CFI in included paths.
|
||||||
|
ifeq ($(filter cfi, $(my_sanitize)),)
|
||||||
|
combined_include_paths := $(CFI_INCLUDE_PATHS) \
|
||||||
|
$(PRODUCT_CFI_INCLUDE_PATHS)
|
||||||
|
|
||||||
|
ifneq ($(strip $(foreach dir,$(subst $(comma),$(space),$(combined_include_paths)),\
|
||||||
|
$(filter $(dir)%,$(LOCAL_PATH)))),)
|
||||||
|
my_sanitize := cfi $(my_sanitize)
|
||||||
|
my_sanitize_diag := cfi $(my_sanitize_diag)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
# If CFI is disabled globally, remove it from my_sanitize.
|
# If CFI is disabled globally, remove it from my_sanitize.
|
||||||
ifeq ($(strip $(ENABLE_CFI)),false)
|
ifeq ($(strip $(ENABLE_CFI)),false)
|
||||||
my_sanitize := $(filter-out cfi,$(my_sanitize))
|
my_sanitize := $(filter-out cfi,$(my_sanitize))
|
||||||
|
|
|
@ -146,8 +146,8 @@ _product_var_list := \
|
||||||
PRODUCT_MINIMIZE_JAVA_DEBUG_INFO \
|
PRODUCT_MINIMIZE_JAVA_DEBUG_INFO \
|
||||||
PRODUCT_INTEGER_OVERFLOW_EXCLUDE_PATHS \
|
PRODUCT_INTEGER_OVERFLOW_EXCLUDE_PATHS \
|
||||||
PRODUCT_ADB_KEYS \
|
PRODUCT_ADB_KEYS \
|
||||||
|
PRODUCT_CFI_INCLUDE_PATHS \
|
||||||
|
PRODUCT_CFI_EXCLUDE_PATHS \
|
||||||
|
|
||||||
define dump-product
|
define dump-product
|
||||||
$(info ==== $(1) ====)\
|
$(info ==== $(1) ====)\
|
||||||
|
|
|
@ -472,3 +472,11 @@ ifneq ($(filter-out 0 1,$(words $(PRODUCT_ADB_KEYS))),)
|
||||||
$(error Only one file may be in PRODUCT_ADB_KEYS: $(PRODUCT_ADB_KEYS))
|
$(error Only one file may be in PRODUCT_ADB_KEYS: $(PRODUCT_ADB_KEYS))
|
||||||
endif
|
endif
|
||||||
.KATI_READONLY := PRODUCT_ADB_KEYS
|
.KATI_READONLY := PRODUCT_ADB_KEYS
|
||||||
|
|
||||||
|
# Whether any paths are excluded from sanitization when SANITIZE_TARGET=cfi
|
||||||
|
PRODUCT_CFI_EXCLUDE_PATHS := \
|
||||||
|
$(strip $(PRODUCTS.$(INTERNAL_PRODUCT).PRODUCT_CFI_EXCLUDE_PATHS))
|
||||||
|
|
||||||
|
# Whether any paths should have CFI enabled for components
|
||||||
|
PRODUCT_CFI_INCLUDE_PATHS := \
|
||||||
|
$(strip $(PRODUCTS.$(INTERNAL_PRODUCT).PRODUCT_CFI_INCLUDE_PATHS))
|
||||||
|
|
|
@ -90,6 +90,8 @@ $(call add_json_list, SanitizeDeviceArch, $(SANITIZE_TARGET_ARCH)
|
||||||
|
|
||||||
$(call add_json_bool, Safestack, $(filter true,$(USE_SAFESTACK)))
|
$(call add_json_bool, Safestack, $(filter true,$(USE_SAFESTACK)))
|
||||||
$(call add_json_bool, EnableCFI, $(call invert_bool,$(filter false,$(ENABLE_CFI))))
|
$(call add_json_bool, EnableCFI, $(call invert_bool,$(filter false,$(ENABLE_CFI))))
|
||||||
|
$(call add_json_list, CFIExcludePaths, $(CFI_EXCLUDE_PATHS) $(PRODUCT_CFI_EXCLUDE_PATHS))
|
||||||
|
$(call add_json_list, CFIIncludePaths, $(CFI_INCLUDE_PATHS) $(PRODUCT_CFI_INCLUDE_PATHS))
|
||||||
$(call add_json_list, IntegerOverflowExcludePaths, $(INTEGER_OVERFLOW_EXCLUDE_PATHS) $(PRODUCT_INTEGER_OVERFLOW_EXCLUDE_PATHS))
|
$(call add_json_list, IntegerOverflowExcludePaths, $(INTEGER_OVERFLOW_EXCLUDE_PATHS) $(PRODUCT_INTEGER_OVERFLOW_EXCLUDE_PATHS))
|
||||||
|
|
||||||
$(call add_json_bool, ClangTidy, $(filter 1 true,$(WITH_TIDY)))
|
$(call add_json_bool, ClangTidy, $(filter 1 true,$(WITH_TIDY)))
|
||||||
|
|
Loading…
Reference in New Issue