| # |
| # Copyright (C) 2011 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. |
| # |
| |
| ######################################################################## |
| # Rules to build a smaller "core" image to support core libraries |
| # (that is, non-Android frameworks) testing on the host and target |
| # |
| # The main rules to build the default "boot" image are in |
| # build/core/dex_preopt_libart.mk |
| |
| include art/build/Android.common_build.mk |
| |
| LOCAL_DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := |
| ifeq ($(DEX2OAT_HOST_INSTRUCTION_SET_FEATURES),) |
| LOCAL_DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := --instruction-set-features=default |
| else |
| LOCAL_DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := --instruction-set-features=$(DEX2OAT_HOST_INSTRUCTION_SET_FEATURES) |
| endif |
| LOCAL_$(HOST_2ND_ARCH_VAR_PREFIX)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := |
| ifeq ($($(HOST_2ND_ARCH_VAR_PREFIX)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES),) |
| LOCAL_$(HOST_2ND_ARCH_VAR_PREFIX)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := --instruction-set-features=default |
| else |
| LOCAL_$(HOST_2ND_ARCH_VAR_PREFIX)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION := --instruction-set-features=$($(HOST_2ND_ARCH_VAR_PREFIX)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES) |
| endif |
| |
| # Use dex2oat debug version for better error reporting |
| # $(1): compiler - optimizing, interpreter or interpreter-access-checks. |
| # $(2): pic/no-pic |
| # $(3): 2ND_ or undefined, 2ND_ for 32-bit host builds. |
| # $(4): wrapper, e.g., valgrind. |
| # $(5): dex2oat suffix, e.g, valgrind requires 32 right now. |
| # $(6): multi-image. |
| # NB depending on HOST_CORE_DEX_LOCATIONS so we are sure to have the dex files in frameworks for |
| # run-test --no-image |
| define create-core-oat-host-rules |
| core_compile_options := |
| core_image_name := |
| core_oat_name := |
| core_infix := |
| core_pic_infix := |
| core_dex2oat_dependency := $(DEX2OAT_DEPENDENCY) |
| |
| ifeq ($(1),optimizing) |
| core_compile_options += --compiler-backend=Optimizing |
| core_dex2oat_dependency := $(DEX2OAT) |
| endif |
| ifeq ($(1),interpreter) |
| core_compile_options += --compiler-filter=interpret-only |
| core_infix := -interpreter |
| endif |
| ifeq ($(1),interp-ac) |
| core_compile_options += --compiler-filter=verify-at-runtime --runtime-arg -Xverify:softfail |
| core_infix := -interp-ac |
| endif |
| ifneq ($(filter-out interpreter interp-ac optimizing,$(1)),) |
| #Technically this test is not precise, but hopefully good enough. |
| $$(error found $(1) expected interpreter, interpreter-access-checks, or optimizing) |
| endif |
| |
| ifeq ($(2),pic) |
| core_compile_options += --compile-pic |
| endif |
| ifeq ($(2),no-pic) |
| core_pic_infix := -npic |
| endif |
| ifneq ($(filter-out pic no-pic,$(2)),) |
| # Technically this test is not precise, but hopefully good enough. |
| $$(error found $(2) expected pic or no-pic) |
| endif |
| |
| # If $(6) is true, generate a multi-image. |
| ifeq ($(6),true) |
| core_multi_infix := -multi |
| core_multi_param := --multi-image --no-inline-from=core-oj-hostdex.jar |
| core_multi_group := _multi |
| else |
| core_multi_infix := |
| core_multi_param := |
| core_multi_group := |
| endif |
| |
| core_image_name := $($(3)HOST_CORE_IMG_OUT_BASE)$$(core_infix)$$(core_pic_infix)$$(core_multi_infix)$(4)$(CORE_IMG_SUFFIX) |
| core_oat_name := $($(3)HOST_CORE_OAT_OUT_BASE)$$(core_infix)$$(core_pic_infix)$$(core_multi_infix)$(4)$(CORE_OAT_SUFFIX) |
| |
| # Using the bitness suffix makes it easier to add as a dependency for the run-test mk. |
| ifeq ($(3),) |
| $(4)HOST_CORE_IMAGE_$(1)_$(2)$$(core_multi_group)_64 := $$(core_image_name) |
| else |
| $(4)HOST_CORE_IMAGE_$(1)_$(2)$$(core_multi_group)_32 := $$(core_image_name) |
| endif |
| $(4)HOST_CORE_IMG_OUTS += $$(core_image_name) |
| $(4)HOST_CORE_OAT_OUTS += $$(core_oat_name) |
| |
| # If we have a wrapper, make the target phony. |
| ifneq ($(4),) |
| .PHONY: $$(core_image_name) |
| endif |
| $$(core_image_name): PRIVATE_CORE_COMPILE_OPTIONS := $$(core_compile_options) |
| $$(core_image_name): PRIVATE_CORE_IMG_NAME := $$(core_image_name) |
| $$(core_image_name): PRIVATE_CORE_OAT_NAME := $$(core_oat_name) |
| $$(core_image_name): PRIVATE_CORE_MULTI_PARAM := $$(core_multi_param) |
| $$(core_image_name): $$(HOST_CORE_DEX_LOCATIONS) $$(core_dex2oat_dependency) |
| @echo "host dex2oat: $$@" |
| @mkdir -p $$(dir $$@) |
| $$(hide) $(4) $$(DEX2OAT)$(5) --runtime-arg -Xms$(DEX2OAT_IMAGE_XMS) \ |
| --runtime-arg -Xmx$(DEX2OAT_IMAGE_XMX) \ |
| --image-classes=$$(PRELOADED_CLASSES) $$(addprefix --dex-file=,$$(HOST_CORE_DEX_FILES)) \ |
| $$(addprefix --dex-location=,$$(HOST_CORE_DEX_LOCATIONS)) --oat-file=$$(PRIVATE_CORE_OAT_NAME) \ |
| --oat-location=$$(PRIVATE_CORE_OAT_NAME) --image=$$(PRIVATE_CORE_IMG_NAME) \ |
| --base=$$(LIBART_IMG_HOST_BASE_ADDRESS) --instruction-set=$$($(3)ART_HOST_ARCH) \ |
| $$(LOCAL_$(3)DEX2OAT_HOST_INSTRUCTION_SET_FEATURES_OPTION) \ |
| --host --android-root=$$(HOST_OUT) --include-patch-information \ |
| --generate-debug-info --generate-build-id \ |
| $$(PRIVATE_CORE_MULTI_PARAM) $$(PRIVATE_CORE_COMPILE_OPTIONS) |
| |
| $$(core_oat_name): $$(core_image_name) |
| |
| # Clean up locally used variables. |
| core_dex2oat_dependency := |
| core_compile_options := |
| core_image_name := |
| core_oat_name := |
| core_infix := |
| core_pic_infix := |
| endef # create-core-oat-host-rules |
| |
| # $(1): compiler - optimizing, interpreter or interpreter-access-checks. |
| # $(2): wrapper. |
| # $(3): dex2oat suffix. |
| # $(4): multi-image. |
| define create-core-oat-host-rule-combination |
| $(call create-core-oat-host-rules,$(1),no-pic,,$(2),$(3),$(4)) |
| $(call create-core-oat-host-rules,$(1),pic,,$(2),$(3),$(4)) |
| |
| ifneq ($(HOST_PREFER_32_BIT),true) |
| $(call create-core-oat-host-rules,$(1),no-pic,2ND_,$(2),$(3),$(4)) |
| $(call create-core-oat-host-rules,$(1),pic,2ND_,$(2),$(3),$(4)) |
| endif |
| endef |
| |
| $(eval $(call create-core-oat-host-rule-combination,optimizing,,,false)) |
| $(eval $(call create-core-oat-host-rule-combination,interpreter,,,false)) |
| $(eval $(call create-core-oat-host-rule-combination,interp-ac,,,false)) |
| $(eval $(call create-core-oat-host-rule-combination,optimizing,,,true)) |
| $(eval $(call create-core-oat-host-rule-combination,interpreter,,,true)) |
| $(eval $(call create-core-oat-host-rule-combination,interp-ac,,,true)) |
| |
| valgrindHOST_CORE_IMG_OUTS := |
| valgrindHOST_CORE_OAT_OUTS := |
| $(eval $(call create-core-oat-host-rule-combination,optimizing,valgrind,32,false)) |
| $(eval $(call create-core-oat-host-rule-combination,interpreter,valgrind,32,false)) |
| $(eval $(call create-core-oat-host-rule-combination,interp-ac,valgrind,32,false)) |
| |
| valgrind-test-art-host-dex2oat-host: $(valgrindHOST_CORE_IMG_OUTS) |
| |
| test-art-host-dex2oat-host: $(HOST_CORE_IMG_OUTS) |
| |
| define create-core-oat-target-rules |
| core_compile_options := |
| core_image_name := |
| core_oat_name := |
| core_infix := |
| core_pic_infix := |
| core_dex2oat_dependency := $(DEX2OAT_DEPENDENCY) |
| |
| ifeq ($(1),optimizing) |
| core_compile_options += --compiler-backend=Optimizing |
| # With the optimizing compiler, we want to rerun dex2oat whenever there is |
| # a dex2oat change to catch regressions early. |
| core_dex2oat_dependency := $(DEX2OAT) |
| endif |
| ifeq ($(1),interpreter) |
| core_compile_options += --compiler-filter=interpret-only |
| core_infix := -interpreter |
| endif |
| ifeq ($(1),interp-ac) |
| core_compile_options += --compiler-filter=verify-at-runtime --runtime-arg -Xverify:softfail |
| core_infix := -interp-ac |
| endif |
| ifneq ($(filter-out interpreter interp-ac optimizing,$(1)),) |
| # Technically this test is not precise, but hopefully good enough. |
| $$(error found $(1) expected interpreter, interpreter-access-checks, or optimizing) |
| endif |
| |
| ifeq ($(2),pic) |
| core_compile_options += --compile-pic |
| endif |
| ifeq ($(2),no-pic) |
| core_pic_infix := -npic |
| endif |
| ifneq ($(filter-out pic no-pic,$(2)),) |
| #Technically this test is not precise, but hopefully good enough. |
| $$(error found $(2) expected pic or no-pic) |
| endif |
| |
| core_image_name := $($(3)TARGET_CORE_IMG_OUT_BASE)$$(core_infix)$$(core_pic_infix)$(4)$(CORE_IMG_SUFFIX) |
| core_oat_name := $($(3)TARGET_CORE_OAT_OUT_BASE)$$(core_infix)$$(core_pic_infix)$(4)$(CORE_OAT_SUFFIX) |
| |
| # Using the bitness suffix makes it easier to add as a dependency for the run-test mk. |
| ifeq ($(3),) |
| ifdef TARGET_2ND_ARCH |
| $(4)TARGET_CORE_IMAGE_$(1)_$(2)_64 := $$(core_image_name) |
| else |
| $(4)TARGET_CORE_IMAGE_$(1)_$(2)_32 := $$(core_image_name) |
| ifdef ART_USE_VIXL_ARM_BACKEND |
| ifeq ($(1),optimizing) |
| # TODO(VIXL): The ARM VIXL backend is still work in progress. Therefore for now we do not |
| # compile the core image with the Optimizing backend when ART_USE_VIXL_ARM_BACKEND is |
| # defined. |
| core_compile_options += --compiler-filter=interpret-only |
| endif |
| endif |
| endif |
| else |
| $(4)TARGET_CORE_IMAGE_$(1)_$(2)_32 := $$(core_image_name) |
| ifdef ART_USE_VIXL_ARM_BACKEND |
| ifeq ($(1),optimizing) |
| # TODO(VIXL): The ARM VIXL backend is still work in progress. Therefore for now we do not |
| # compile the core image with the Optimizing backend when ART_USE_VIXL_ARM_BACKEND is defined. |
| core_compile_options += --compiler-filter=interpret-only |
| endif |
| endif |
| endif |
| $(4)TARGET_CORE_IMG_OUTS += $$(core_image_name) |
| $(4)TARGET_CORE_OAT_OUTS += $$(core_oat_name) |
| |
| # If we have a wrapper, make the target phony. |
| ifneq ($(4),) |
| .PHONY: $$(core_image_name) |
| endif |
| $$(core_image_name): PRIVATE_CORE_COMPILE_OPTIONS := $$(core_compile_options) |
| $$(core_image_name): PRIVATE_CORE_IMG_NAME := $$(core_image_name) |
| $$(core_image_name): PRIVATE_CORE_OAT_NAME := $$(core_oat_name) |
| $$(core_image_name): $$(TARGET_CORE_DEX_FILES) $$(core_dex2oat_dependency) |
| @echo "target dex2oat: $$@" |
| @mkdir -p $$(dir $$@) |
| $$(hide) $(4) $$(DEX2OAT)$(5) --runtime-arg -Xms$(DEX2OAT_IMAGE_XMS) \ |
| --runtime-arg -Xmx$(DEX2OAT_IMAGE_XMX) \ |
| --image-classes=$$(PRELOADED_CLASSES) $$(addprefix --dex-file=,$$(TARGET_CORE_DEX_FILES)) \ |
| $$(addprefix --dex-location=,$$(TARGET_CORE_DEX_LOCATIONS)) --oat-file=$$(PRIVATE_CORE_OAT_NAME) \ |
| --oat-location=$$(PRIVATE_CORE_OAT_NAME) --image=$$(PRIVATE_CORE_IMG_NAME) \ |
| --base=$$(LIBART_IMG_TARGET_BASE_ADDRESS) --instruction-set=$$($(3)TARGET_ARCH) \ |
| --instruction-set-variant=$$($(3)DEX2OAT_TARGET_CPU_VARIANT) \ |
| --instruction-set-features=$$($(3)DEX2OAT_TARGET_INSTRUCTION_SET_FEATURES) \ |
| --android-root=$$(PRODUCT_OUT)/system --include-patch-information \ |
| --generate-debug-info --generate-build-id \ |
| $$(PRIVATE_CORE_COMPILE_OPTIONS) || (rm $$(PRIVATE_CORE_OAT_NAME); exit 1) |
| |
| $$(core_oat_name): $$(core_image_name) |
| |
| # Clean up locally used variables. |
| core_dex2oat_dependency := |
| core_compile_options := |
| core_image_name := |
| core_oat_name := |
| core_infix := |
| core_pic_infix := |
| endef # create-core-oat-target-rules |
| |
| # $(1): compiler - optimizing, interpreter or interpreter-access-checks. |
| # $(2): wrapper. |
| # $(3): dex2oat suffix. |
| define create-core-oat-target-rule-combination |
| $(call create-core-oat-target-rules,$(1),no-pic,,$(2),$(3)) |
| $(call create-core-oat-target-rules,$(1),pic,,$(2),$(3)) |
| |
| ifdef TARGET_2ND_ARCH |
| $(call create-core-oat-target-rules,$(1),no-pic,2ND_,$(2),$(3)) |
| $(call create-core-oat-target-rules,$(1),pic,2ND_,$(2),$(3)) |
| endif |
| endef |
| |
| $(eval $(call create-core-oat-target-rule-combination,optimizing,,)) |
| $(eval $(call create-core-oat-target-rule-combination,interpreter,,)) |
| $(eval $(call create-core-oat-target-rule-combination,interp-ac,,)) |
| |
| valgrindTARGET_CORE_IMG_OUTS := |
| valgrindTARGET_CORE_OAT_OUTS := |
| $(eval $(call create-core-oat-target-rule-combination,optimizing,valgrind,32)) |
| $(eval $(call create-core-oat-target-rule-combination,interpreter,valgrind,32)) |
| $(eval $(call create-core-oat-target-rule-combination,interp-ac,valgrind,32)) |
| |
| valgrind-test-art-host-dex2oat-target: $(valgrindTARGET_CORE_IMG_OUTS) |
| |
| valgrind-test-art-host-dex2oat: valgrind-test-art-host-dex2oat-host valgrind-test-art-host-dex2oat-target |