diff options
author | Colin Cross <ccross@android.com> | 2014-04-11 10:02:14 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-04-11 10:02:14 +0000 |
commit | 6c277faccf37057d60526eb05a2f0d602278b533 (patch) | |
tree | cdd7051fb3396605eedd6be85122690849c1aa52 /core | |
parent | e737ca9a02658877d5cb186c019ee61640fc4a75 (diff) | |
parent | 14203772619f4b4740941de634f90b7a02231aa5 (diff) | |
download | build-6c277faccf37057d60526eb05a2f0d602278b533.zip build-6c277faccf37057d60526eb05a2f0d602278b533.tar.gz build-6c277faccf37057d60526eb05a2f0d602278b533.tar.bz2 |
am 14203772: am 3221717f: am a355ae12: Merge changes I2c10e41f,I5b5e23f1,If3f5a81c,I07520b75
* commit '14203772619f4b4740941de634f90b7a02231aa5':
build: remove packages/ from 64-bit blacklist
build: use TARGET_SUPPORTS_32_BIT_APPS and TARGET_SUPPORTS_64_BIT_APPS
build: add support for LOCAL_MULTILIB := 64
build: fix TARGET_PREFER_32_BIT
Diffstat (limited to 'core')
-rw-r--r-- | core/64_bit_blacklist.mk | 4 | ||||
-rw-r--r-- | core/executable.mk | 45 | ||||
-rw-r--r-- | core/module_arch_supported.mk | 4 | ||||
-rw-r--r-- | core/multilib.mk | 2 | ||||
-rw-r--r-- | core/package.mk | 53 |
5 files changed, 76 insertions, 32 deletions
diff --git a/core/64_bit_blacklist.mk b/core/64_bit_blacklist.mk index 75e1e33..8e5fb80 100644 --- a/core/64_bit_blacklist.mk +++ b/core/64_bit_blacklist.mk @@ -1,9 +1,5 @@ ifneq ($(TARGET_2ND_ARCH),) -# JNI - needs 64-bit VM -_64_bit_directory_blacklist += \ - packages/ - # Chromium/V8: needs 64-bit support _64_bit_directory_blacklist += \ external/chromium-libpac \ diff --git a/core/executable.mk b/core/executable.mk index 1e8d73a..b67ac36 100644 --- a/core/executable.mk +++ b/core/executable.mk @@ -8,19 +8,6 @@ include $(BUILD_SYSTEM)/multilib.mk -ifeq ($(TARGET_PREFER_32_BIT),true) -ifeq (,$(filter $(my_module_multilib),first both) -# if TARGET_PREFER_32_BIT is not explicitly set to "first" or "both" -# build only for secondary -my_module_multilib := 32 -endif -endif - -ifndef my_module_multilib -# executables default to building for the first architecture -my_module_multilib := first -endif - ifeq ($(my_module_multilib),both) ifeq ($(LOCAL_MODULE_PATH_32)$(LOCAL_MODULE_STEM_32),) $(error $(LOCAL_PATH): LOCAL_MODULE_STEM_32 or LOCAL_MODULE_PATH_32 is required for LOCAL_MULTILIB := both for module $(LOCAL_MODULE)) @@ -32,26 +19,42 @@ else #!LOCAL_MULTILIB == both LOCAL_NO_2ND_ARCH_MODULE_SUFFIX := true endif -my_skip_secondary_arch := +# if TARGET_PREFER_32_BIT is set, try to build 32-bit first +ifdef TARGET_2ND_ARCH +ifeq ($(TARGET_PREFER_32_BIT),true) +LOCAL_2ND_ARCH_VAR_PREFIX := $(TARGET_2ND_ARCH_VAR_PREFIX) +else +LOCAL_2ND_ARCH_VAR_PREFIX := +endif +endif + +my_skip_non_preferred_arch := -# check if first arch is supported +# check if preferred arch is supported include $(BUILD_SYSTEM)/module_arch_supported.mk ifeq ($(my_module_arch_supported),true) # first arch is supported include $(BUILD_SYSTEM)/executable_internal.mk ifneq ($(my_module_multilib),both) -my_skip_secondary_arch := true +my_skip_non_preferred_arch := true endif endif -# check if first arch was not supported or asked to build both -ifndef my_skip_secondary_arch +# check if preferred arch was not supported or asked to build both +ifndef my_skip_non_preferred_arch ifdef TARGET_2ND_ARCH -# check if secondary arch is supported + +# check if the non-preferred arch is the primary or secondary +ifeq ($(TARGET_PREFER_32_BIT),true) +LOCAL_2ND_ARCH_VAR_PREFIX := +else LOCAL_2ND_ARCH_VAR_PREFIX := $(TARGET_2ND_ARCH_VAR_PREFIX) +endif + +# check if non-preferred arch is supported include $(BUILD_SYSTEM)/module_arch_supported.mk ifeq ($(my_module_arch_supported),true) -# secondary arch is supported +# non-preferred arch is supported OVERRIDE_BUILT_MODULE_PATH := LOCAL_BUILT_MODULE := LOCAL_INSTALLED_MODULE := @@ -62,7 +65,7 @@ LOCAL_INTERMEDIATE_TARGETS := include $(BUILD_SYSTEM)/executable_internal.mk endif endif # TARGET_2ND_ARCH -endif # !my_skip_secondary_arch || LOCAL_MULTILIB +endif # !my_skip_non_preferred_arch || LOCAL_MULTILIB LOCAL_2ND_ARCH_VAR_PREFIX := LOCAL_NO_2ND_ARCH_MODULE_SUFFIX := diff --git a/core/module_arch_supported.mk b/core/module_arch_supported.mk index 1e03914..753a29e 100644 --- a/core/module_arch_supported.mk +++ b/core/module_arch_supported.mk @@ -25,12 +25,16 @@ endif ifeq ($(LOCAL_2ND_ARCH_VAR_PREFIX),) ifeq ($(TARGET_IS_64_BIT)|$(my_module_multilib),true|32) my_module_arch_supported := false +else ifeq ($(TARGET_IS_64_BIT)|$(my_module_multilib),|64) +my_module_arch_supported := false else ifeq ($(call directory_is_64_bit_blacklisted,$(LOCAL_PATH)),true) my_module_arch_supported := false endif else # LOCAL_2ND_ARCH_VAR_PREFIX ifeq ($(my_module_multilib),first) my_module_arch_supported := false +else ifeq ($(my_module_multilib),64) +my_module_arch_supported := false endif endif # LOCAL_2ND_ARCH_VAR_PREFIX diff --git a/core/multilib.mk b/core/multilib.mk index fa5397a..8380249 100644 --- a/core/multilib.mk +++ b/core/multilib.mk @@ -20,7 +20,7 @@ else ifeq ($(LOCAL_NO_2ND_ARCH),true) my_module_multilib := first endif else # my_module_multilib defined -ifeq (,$(filter 32 first both none,$(my_module_multilib))) +ifeq (,$(filter 32 64 first both none,$(my_module_multilib))) $(error $(LOCAL_PATH): Invalid LOCAL_MULTILIB specified for module $(LOCAL_MODULE)) endif endif # my_module_multilib defined diff --git a/core/package.mk b/core/package.mk index 337d3d0..fe4d0e4 100644 --- a/core/package.mk +++ b/core/package.mk @@ -5,23 +5,64 @@ include $(BUILD_SYSTEM)/multilib.mk -ifndef my_module_multilib -# packages default to building for either architecture, -# the first if its supported, otherwise the second. -my_module_multilib := both +ifeq ($(TARGET_SUPPORTS_32_BIT_APPS)|$(TARGET_SUPPORTS_64_BIT_APPS),true|true) + # packages default to building for either architecture, + # the preferred if its supported, otherwise the non-preferred. +else ifeq ($(TARGET_SUPPORTS_64_BIT_APPS),true) + # only 64-bit apps supported + ifeq ($(filter $(my_module_multilib),64 both first),$(my_module_multilib)) + # if my_module_multilib was 64, both, first, or unset, build for 64-bit + my_module_multilib := 64 + else + # otherwise don't build this app + my_module_multilib := none + endif +else + # only 32-bit apps supported + ifeq ($(filter $(my_module_multilib),32 both),$(my_module_multilib)) + # if my_module_multilib was 32, both, or unset, build for 32-bit + my_module_multilib := 32 + else ifeq ($(my_module_multilib),first) + ifndef TARGET_IS_64_BIT + # if my_module_multilib was first and this is a 32-bit build, build for + # 32-bit + my_module_multilib := 32 + else + # if my_module_multilib was first and this is a 64-bit build, don't build + # this app + my_module_multilib := none + endif + else + # my_module_mulitlib was 64 or none, don't build this app + my_module_multilib := none + endif endif LOCAL_NO_2ND_ARCH_MODULE_SUFFIX := true -# check if first arch is supported +# if TARGET_PREFER_32_BIT is set, try to build 32-bit first +ifdef TARGET_2ND_ARCH +ifeq ($(TARGET_PREFER_32_BIT),true) +LOCAL_2ND_ARCH_VAR_PREFIX := $(TARGET_2ND_ARCH_VAR_PREFIX) +else LOCAL_2ND_ARCH_VAR_PREFIX := +endif +endif + +# check if preferred arch is supported include $(BUILD_SYSTEM)/module_arch_supported.mk ifeq ($(my_module_arch_supported),true) # first arch is supported include $(BUILD_SYSTEM)/package_internal.mk else ifneq (,$(TARGET_2ND_ARCH)) -# check if secondary arch is supported +# check if the non-preferred arch is the primary or secondary +ifeq ($(TARGET_PREFER_32_BIT),true) +LOCAL_2ND_ARCH_VAR_PREFIX := +else LOCAL_2ND_ARCH_VAR_PREFIX := $(TARGET_2ND_ARCH_VAR_PREFIX) +endif + +# check if non-preferred arch is supported include $(BUILD_SYSTEM)/module_arch_supported.mk ifeq ($(my_module_arch_supported),true) # secondary arch is supported |