| # |
| # 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. |
| # |
| |
| LOCAL_PATH := $(call my-dir) |
| |
| art_path := $(LOCAL_PATH) |
| |
| ######################################################################## |
| # clean-oat rules |
| # |
| |
| include $(art_path)/build/Android.common_path.mk |
| include $(art_path)/build/Android.oat.mk |
| |
| .PHONY: clean-oat |
| clean-oat: clean-oat-host clean-oat-target |
| |
| .PHONY: clean-oat-host |
| clean-oat-host: |
| find $(OUT_DIR) -name "*.oat" -o -name "*.odex" -o -name "*.art" -o -name '*.vdex' | xargs rm -f |
| rm -rf $(TMPDIR)/*/test-*/dalvik-cache/* |
| rm -rf $(TMPDIR)/android-data/dalvik-cache/* |
| |
| .PHONY: clean-oat-target |
| clean-oat-target: |
| $(ADB) root |
| $(ADB) wait-for-device remount |
| $(ADB) shell rm -rf $(ART_TARGET_NATIVETEST_DIR) |
| $(ADB) shell rm -rf $(ART_TARGET_TEST_DIR) |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/*/* |
| $(ADB) shell rm -rf $(ART_DEXPREOPT_BOOT_JAR_DIR)/$(DEX2OAT_TARGET_ARCH) |
| $(ADB) shell rm -rf system/app/$(DEX2OAT_TARGET_ARCH) |
| ifdef TARGET_2ND_ARCH |
| $(ADB) shell rm -rf $(ART_DEXPREOPT_BOOT_JAR_DIR)/$($(TARGET_2ND_ARCH_VAR_PREFIX)DEX2OAT_TARGET_ARCH) |
| $(ADB) shell rm -rf system/app/$($(TARGET_2ND_ARCH_VAR_PREFIX)DEX2OAT_TARGET_ARCH) |
| endif |
| $(ADB) shell rm -rf data/run-test/test-*/dalvik-cache/* |
| |
| ######################################################################## |
| # cpplint rules to style check art source files |
| |
| include $(art_path)/build/Android.cpplint.mk |
| |
| ######################################################################## |
| # product rules |
| |
| include $(art_path)/oatdump/Android.mk |
| include $(art_path)/tools/ahat/Android.mk |
| include $(art_path)/tools/dexfuzz/Android.mk |
| include $(art_path)/tools/veridex/Android.mk |
| |
| ART_HOST_DEPENDENCIES := \ |
| $(ART_HOST_EXECUTABLES) \ |
| $(ART_HOST_DEX_DEPENDENCIES) \ |
| $(ART_HOST_SHARED_LIBRARY_DEPENDENCIES) |
| |
| ifeq ($(ART_BUILD_HOST_DEBUG),true) |
| ART_HOST_DEPENDENCIES += $(ART_HOST_SHARED_LIBRARY_DEBUG_DEPENDENCIES) |
| endif |
| |
| ART_TARGET_DEPENDENCIES := \ |
| $(ART_TARGET_DEX_DEPENDENCIES) |
| |
| ######################################################################## |
| # test rules |
| |
| # All the dependencies that must be built ahead of sync-ing them onto the target device. |
| TEST_ART_TARGET_SYNC_DEPS := $(ADB_EXECUTABLE) |
| |
| include $(art_path)/build/Android.common_test.mk |
| include $(art_path)/build/Android.gtest.mk |
| include $(art_path)/test/Android.run-test.mk |
| |
| TEST_ART_TARGET_SYNC_DEPS += $(ART_TEST_TARGET_GTEST_DEPENDENCIES) $(ART_TEST_TARGET_RUN_TEST_DEPENDENCIES) |
| |
| # Make sure /system is writable on the device. |
| TEST_ART_ADB_ROOT_AND_REMOUNT := \ |
| ($(ADB) root && \ |
| $(ADB) wait-for-device remount && \ |
| (($(ADB) shell touch /system/testfile && \ |
| ($(ADB) shell rm /system/testfile || true)) || \ |
| ($(ADB) disable-verity && \ |
| $(ADB) reboot && \ |
| $(ADB) wait-for-device root && \ |
| $(ADB) wait-for-device remount))) |
| |
| # Sync test files to the target, depends upon all things that must be pushed to the target. |
| .PHONY: test-art-target-sync |
| # Check if we need to sync. In case ART_TEST_CHROOT or ART_TEST_ANDROID_ROOT |
| # is not empty, the code below uses 'adb push' instead of 'adb sync', |
| # which does not check if the files on the device have changed. |
| # TODO: Remove support for ART_TEST_ANDROID_ROOT when it is no longer needed. |
| ifneq ($(ART_TEST_NO_SYNC),true) |
| # Sync system and data partitions. |
| ifeq ($(ART_TEST_ANDROID_ROOT),) |
| ifeq ($(ART_TEST_CHROOT),) |
| test-art-target-sync: $(TEST_ART_TARGET_SYNC_DEPS) |
| $(TEST_ART_ADB_ROOT_AND_REMOUNT) |
| $(ADB) sync system && $(ADB) sync data |
| else |
| # TEST_ART_ADB_ROOT_AND_REMOUNT is not needed here, as we are only |
| # pushing things to the chroot dir, which is expected to be under |
| # /data on the device. |
| test-art-target-sync: $(TEST_ART_TARGET_SYNC_DEPS) |
| $(ADB) wait-for-device |
| $(ADB) push $(PRODUCT_OUT)/system $(ART_TEST_CHROOT)/ |
| $(ADB) push $(PRODUCT_OUT)/data $(ART_TEST_CHROOT)/ |
| endif |
| else |
| test-art-target-sync: $(TEST_ART_TARGET_SYNC_DEPS) |
| $(TEST_ART_ADB_ROOT_AND_REMOUNT) |
| $(ADB) wait-for-device |
| $(ADB) push $(PRODUCT_OUT)/system $(ART_TEST_CHROOT)$(ART_TEST_ANDROID_ROOT) |
| # Push the contents of the `data` dir into `$(ART_TEST_CHROOT)/data` on the device (note |
| # that $(ART_TEST_CHROOT) can be empty). If `$(ART_TEST_CHROOT)/data` already exists on |
| # the device, it is not overwritten, but its content is updated. |
| $(ADB) push $(PRODUCT_OUT)/data $(ART_TEST_CHROOT)/ |
| endif |
| endif |
| |
| # "mm test-art" to build and run all tests on host and device |
| .PHONY: test-art |
| test-art: test-art-host test-art-target |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-gtest |
| test-art-gtest: test-art-host-gtest test-art-target-gtest |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-run-test |
| test-art-run-test: test-art-host-run-test test-art-target-run-test |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| ######################################################################## |
| # host test rules |
| |
| VIXL_TEST_DEPENDENCY := |
| # We can only run the vixl tests on 64-bit hosts (vixl testing issue) when its a |
| # top-level build (to declare the vixl test rule). |
| ifneq ($(HOST_PREFER_32_BIT),true) |
| ifeq ($(ONE_SHOT_MAKEFILE),) |
| VIXL_TEST_DEPENDENCY := run-vixl-tests |
| endif |
| endif |
| |
| .PHONY: test-art-host-vixl |
| test-art-host-vixl: $(VIXL_TEST_DEPENDENCY) |
| |
| # "mm test-art-host" to build and run all host tests. |
| .PHONY: test-art-host |
| test-art-host: test-art-host-gtest test-art-host-run-test \ |
| test-art-host-vixl test-art-host-dexdump |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All host tests that run solely with the default compiler. |
| .PHONY: test-art-host-default |
| test-art-host-default: test-art-host-run-test-default |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All host tests that run solely with the optimizing compiler. |
| .PHONY: test-art-host-optimizing |
| test-art-host-optimizing: test-art-host-run-test-optimizing |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All host tests that run solely on the interpreter. |
| .PHONY: test-art-host-interpreter |
| test-art-host-interpreter: test-art-host-run-test-interpreter |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All host tests that run solely on the jit. |
| .PHONY: test-art-host-jit |
| test-art-host-jit: test-art-host-run-test-jit |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # Primary host architecture variants: |
| .PHONY: test-art-host$(ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host$(ART_PHONY_TEST_HOST_SUFFIX): test-art-host-gtest$(ART_PHONY_TEST_HOST_SUFFIX) \ |
| test-art-host-run-test$(ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-default$(ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-default$(ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-default$(ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-optimizing$(ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-optimizing$(ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-optimizing$(ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-interpreter$(ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-interpreter$(ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-interpreter$(ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-jit$(ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-jit$(ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-jit$(ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # Secondary host architecture variants: |
| ifneq ($(HOST_PREFER_32_BIT),true) |
| .PHONY: test-art-host$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host$(2ND_ART_PHONY_TEST_HOST_SUFFIX): test-art-host-gtest$(2ND_ART_PHONY_TEST_HOST_SUFFIX) \ |
| test-art-host-run-test$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-default$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-default$(2ND_ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-default$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-optimizing$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-optimizing$(2ND_ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-optimizing$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-interpreter$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-interpreter$(2ND_ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-interpreter$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-host-jit$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| test-art-host-jit$(2ND_ART_PHONY_TEST_HOST_SUFFIX): test-art-host-run-test-jit$(2ND_ART_PHONY_TEST_HOST_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| endif |
| |
| # Dexdump/list regression test. |
| .PHONY: test-art-host-dexdump |
| test-art-host-dexdump: $(addprefix $(HOST_OUT_EXECUTABLES)/, dexdump dexlist) |
| ANDROID_HOST_OUT=$(realpath $(HOST_OUT)) art/test/dexdump/run-all-tests |
| |
| ######################################################################## |
| # target test rules |
| |
| # "mm test-art-target" to build and run all target tests. |
| .PHONY: test-art-target |
| test-art-target: test-art-target-gtest test-art-target-run-test |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All target tests that run solely with the default compiler. |
| .PHONY: test-art-target-default |
| test-art-target-default: test-art-target-run-test-default |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All target tests that run solely with the optimizing compiler. |
| .PHONY: test-art-target-optimizing |
| test-art-target-optimizing: test-art-target-run-test-optimizing |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All target tests that run solely on the interpreter. |
| .PHONY: test-art-target-interpreter |
| test-art-target-interpreter: test-art-target-run-test-interpreter |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # All target tests that run solely on the jit. |
| .PHONY: test-art-target-jit |
| test-art-target-jit: test-art-target-run-test-jit |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # Primary target architecture variants: |
| .PHONY: test-art-target$(ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target$(ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-gtest$(ART_PHONY_TEST_TARGET_SUFFIX) \ |
| test-art-target-run-test$(ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-default$(ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-default$(ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-default$(ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-optimizing$(ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-optimizing$(ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-optimizing$(ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-interpreter$(ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-interpreter$(ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-interpreter$(ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-jit$(ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-jit$(ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-jit$(ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| # Secondary target architecture variants: |
| ifdef 2ND_ART_PHONY_TEST_TARGET_SUFFIX |
| .PHONY: test-art-target$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target$(2ND_ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-gtest$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) \ |
| test-art-target-run-test$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-default$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-default$(2ND_ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-default$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-optimizing$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-optimizing$(2ND_ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-optimizing$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-interpreter$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-interpreter$(2ND_ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-interpreter$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| |
| .PHONY: test-art-target-jit$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| test-art-target-jit$(2ND_ART_PHONY_TEST_TARGET_SUFFIX): test-art-target-run-test-jit$(2ND_ART_PHONY_TEST_TARGET_SUFFIX) |
| $(hide) $(call ART_TEST_PREREQ_FINISHED,$@) |
| endif |
| |
| |
| ####################### |
| # Android Runtime APEX. |
| |
| include $(CLEAR_VARS) |
| |
| # The Android Runtime APEX comes in two flavors: |
| # - the release module (`com.android.runtime.release`), containing |
| # only "release" artifacts; |
| # - the debug module (`com.android.runtime.debug`), containing both |
| # "release" and "debug" artifacts, as well as additional tools. |
| # |
| # The Android Runtime APEX module (`com.android.runtime`) is an |
| # "alias" for one of the previous modules. By default, "user" build |
| # variants contain the release module, while "userdebug" and "eng" |
| # build variant contain the debug module. However, if |
| # `PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD` is defined, it overrides |
| # the previous logic: |
| # - if `PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD` is set to `false`, the |
| # build will include the release module (whatever the build |
| # variant); |
| # - if `PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD` is set to `true`, the |
| # build will include the debug module (whatever the build variant). |
| |
| art_target_include_debug_build := $(PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD) |
| ifneq (false,$(art_target_include_debug_build)) |
| ifneq (,$(filter userdebug eng,$(TARGET_BUILD_VARIANT))) |
| art_target_include_debug_build := true |
| endif |
| endif |
| ifeq (true,$(art_target_include_debug_build)) |
| # Module with both release and debug variants, as well as |
| # additional tools. |
| TARGET_RUNTIME_APEX := com.android.runtime.debug |
| APEX_TEST_MODULE := art-check-debug-apex-gen-fakebin |
| else |
| # Release module (without debug variants nor tools). |
| TARGET_RUNTIME_APEX := com.android.runtime.release |
| APEX_TEST_MODULE := art-check-release-apex-gen-fakebin |
| endif |
| |
| LOCAL_MODULE := com.android.runtime |
| LOCAL_REQUIRED_MODULES := $(TARGET_RUNTIME_APEX) |
| LOCAL_REQUIRED_MODULES += art_apex_boot_integrity |
| |
| # Clear locally used variable. |
| art_target_include_debug_build := |
| |
| include $(BUILD_PHONY_PACKAGE) |
| |
| include $(CLEAR_VARS) |
| LOCAL_MODULE := com.android.runtime |
| LOCAL_IS_HOST_MODULE := true |
| ifneq ($(HOST_OS),darwin) |
| LOCAL_REQUIRED_MODULES += $(APEX_TEST_MODULE) |
| endif |
| include $(BUILD_PHONY_PACKAGE) |
| |
| # Create canonical name -> file name symlink in the symbol directory |
| # The symbol files for the debug or release variant are installed to |
| # $(TARGET_OUT_UNSTRIPPED)/$(TARGET_RUNTIME_APEX) directory. However, |
| # since they are available via /apex/com.android.runtime at runtime |
| # regardless of which variant is installed, create a symlink so that |
| # $(TARGET_OUT_UNSTRIPPED)/apex/com.android.runtime is linked to |
| # $(TARGET_OUT_UNSTRIPPED)/apex/$(TARGET_RUNTIME_APEX). |
| # Note that installation of the symlink is triggered by the apex_manifest.json |
| # file which is the file that is guaranteed to be created regardless of the |
| # value of TARGET_FLATTEN_APEX. |
| # |
| # b/132413565: Also, when TARGET_FLATTEN_APEX, an empty directory |
| # /system/apex/com.android.runtime is created. After the entire |
| # /system/apex is mounted on /apex, the flattened runtime APEX |
| # (either com.android.runtime.debug or *.release) is mounted on the empty |
| # directory so that the APEX is accessible via the canonical path |
| # /apex/com.android.runtime |
| ifeq ($(TARGET_FLATTEN_APEX),true) |
| runtime_apex_manifest_file := $(PRODUCT_OUT)/system/apex/$(TARGET_RUNTIME_APEX)/apex_manifest.json |
| else |
| runtime_apex_manifest_file := $(PRODUCT_OUT)/apex/$(TARGET_RUNTIME_APEX)/apex_manifest.json |
| endif |
| |
| runtime_apex_symlink_timestamp := $(call intermediates-dir-for,FAKE,com.android.runtime)/symlink.timestamp |
| $(runtime_apex_manifest_file): $(runtime_apex_symlink_timestamp) |
| $(runtime_apex_manifest_file): PRIVATE_LINK_NAME := $(TARGET_OUT_UNSTRIPPED)/apex/com.android.runtime |
| $(runtime_apex_symlink_timestamp): |
| $(hide) mkdir -p $(dir $(PRIVATE_LINK_NAME)) |
| $(hide) ln -sf $(TARGET_RUNTIME_APEX) $(PRIVATE_LINK_NAME) |
| ifeq ($(TARGET_FLATTEN_APEX),true) |
| $(hide) mkdir -p $(TARGET_OUT)/apex/com.android.runtime |
| endif |
| $(hide) touch $@ |
| |
| runtime_apex_manifest_file := |
| |
| ####################### |
| # Fake packages for ART |
| |
| # The art-runtime package depends on the core ART libraries and binaries. It exists so we can |
| # manipulate the set of things shipped, e.g., add debug versions and so on. |
| |
| include $(CLEAR_VARS) |
| LOCAL_MODULE := art-runtime |
| |
| # Base requirements. |
| LOCAL_REQUIRED_MODULES := \ |
| dalvikvm \ |
| dex2oat \ |
| dexoptanalyzer \ |
| libart \ |
| libart-compiler \ |
| libopenjdkjvm \ |
| libopenjdkjvmti \ |
| profman \ |
| libadbconnection \ |
| |
| # Potentially add in debug variants: |
| # |
| # * We will never add them if PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD = false. |
| # * We will always add them if PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD = true. |
| # * Otherwise, we will add them by default to userdebug and eng builds. |
| art_target_include_debug_build := $(PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD) |
| ifneq (false,$(art_target_include_debug_build)) |
| ifneq (,$(filter userdebug eng,$(TARGET_BUILD_VARIANT))) |
| art_target_include_debug_build := true |
| endif |
| ifeq (true,$(art_target_include_debug_build)) |
| LOCAL_REQUIRED_MODULES += \ |
| dex2oatd \ |
| dexoptanalyzerd \ |
| libartd \ |
| libartd-compiler \ |
| libopenjdkd \ |
| libopenjdkjvmd \ |
| libopenjdkjvmtid \ |
| profmand \ |
| libadbconnectiond \ |
| |
| endif |
| endif |
| |
| include $(BUILD_PHONY_PACKAGE) |
| |
| # The art-tools package depends on helpers and tools that are useful for developers. Similar |
| # dependencies exist for the APEX builds for these tools (see build/apex/Android.bp). |
| |
| include $(CLEAR_VARS) |
| LOCAL_MODULE := art-tools |
| LOCAL_IS_HOST_MODULE := true |
| LOCAL_REQUIRED_MODULES := \ |
| ahat \ |
| dexdump \ |
| hprof-conv \ |
| |
| # A subset of the tools are disabled when HOST_PREFER_32_BIT is defined as make reports that |
| # they are not supported on host (b/129323791). This is likely due to art_apex disabling host |
| # APEX builds when HOST_PREFER_32_BIT is set (b/120617876). |
| ifneq ($(HOST_PREFER_32_BIT),true) |
| LOCAL_REQUIRED_MODULES += \ |
| dexdiag \ |
| dexlist \ |
| oatdump \ |
| |
| endif |
| |
| include $(BUILD_PHONY_PACKAGE) |
| |
| #################################################################################################### |
| # Fake packages to ensure generation of libopenjdkd when one builds with mm/mmm/mmma. |
| # |
| # The library is required for starting a runtime in debug mode, but libartd does not depend on it |
| # (dependency cycle otherwise). |
| # |
| # Note: * As the package is phony to create a dependency the package name is irrelevant. |
| # * We make MULTILIB explicit to "both," just to state here that we want both libraries on |
| # 64-bit systems, even if it is the default. |
| |
| # ART on the host. |
| ifeq ($(ART_BUILD_HOST_DEBUG),true) |
| include $(CLEAR_VARS) |
| LOCAL_MODULE := art-libartd-libopenjdkd-host-dependency |
| LOCAL_MULTILIB := both |
| LOCAL_REQUIRED_MODULES := libopenjdkd |
| LOCAL_IS_HOST_MODULE := true |
| include $(BUILD_PHONY_PACKAGE) |
| endif |
| |
| # ART on the target. |
| ifeq ($(ART_BUILD_TARGET_DEBUG),true) |
| include $(CLEAR_VARS) |
| LOCAL_MODULE := art-libartd-libopenjdkd-target-dependency |
| LOCAL_MULTILIB := both |
| LOCAL_REQUIRED_MODULES := libopenjdkd |
| include $(BUILD_PHONY_PACKAGE) |
| endif |
| |
| ######################################################################## |
| # "m build-art" for quick minimal build |
| .PHONY: build-art |
| build-art: build-art-host build-art-target |
| |
| .PHONY: build-art-host |
| build-art-host: $(HOST_OUT_EXECUTABLES)/art $(ART_HOST_DEPENDENCIES) $(HOST_CORE_IMG_OUTS) |
| |
| .PHONY: build-art-target |
| build-art-target: $(TARGET_OUT_EXECUTABLES)/art $(ART_TARGET_DEPENDENCIES) $(TARGET_CORE_IMG_OUTS) |
| |
| ######################################################################## |
| # Workaround for not using symbolic links for linker and bionic libraries |
| # in a minimal setup (eg buildbot or golem). |
| ######################################################################## |
| |
| PRIVATE_BIONIC_FILES := \ |
| bin/bootstrap/linker \ |
| bin/bootstrap/linker64 \ |
| lib/bootstrap/libc.so \ |
| lib/bootstrap/libm.so \ |
| lib/bootstrap/libdl.so \ |
| lib64/bootstrap/libc.so \ |
| lib64/bootstrap/libm.so \ |
| lib64/bootstrap/libdl.so \ |
| |
| PRIVATE_RUNTIME_DEPENDENCY_LIBS := \ |
| lib/libnativebridge.so \ |
| lib64/libnativebridge.so \ |
| lib/libnativehelper.so \ |
| lib64/libnativehelper.so \ |
| lib/libdexfile_external.so \ |
| lib64/libdexfile_external.so \ |
| lib/libdexfiled_external.so \ |
| lib64/libdexfiled_external.so \ |
| lib/libnativeloader.so \ |
| lib64/libnativeloader.so \ |
| lib/libandroidio.so \ |
| lib64/libandroidio.so \ |
| |
| # Generate copies of Bionic bootstrap artifacts and Runtime APEX |
| # libraries in the `system` (TARGET_OUT) directory. This is dangerous |
| # as these files could inadvertently stay in this directory and be |
| # included in a system image. |
| # |
| # Copy some libraries into `$(TARGET_OUT)/lib(64)` (the |
| # `/system/lib(64)` directory to be sync'd to the target) for ART testing |
| # purposes: |
| # - Bionic bootstrap libraries, copied from |
| # `$(TARGET_OUT)/lib(64)/bootstrap` (the `/system/lib(64)/bootstrap` |
| # directory to be sync'd to the target); |
| # - Some libraries which are part of the Runtime APEX; if the product |
| # to build uses flattened APEXes, these libraries are copied from |
| # `$(TARGET_OUT)/apex/com.android.runtime.debug` (the flattened |
| # (Debug) Runtime APEX directory to be sync'd to the target); |
| # otherwise, they are copied from |
| # `$(TARGET_OUT)/../apex/com.android.runtime.debug` (the local |
| # directory under the build tree containing the (Debug) Runtime APEX |
| # artifacts, which is not sync'd to the target). |
| # |
| # This target is only used by Golem now. |
| # |
| # TODO(b/129332183): Remove this when Golem has full support for the |
| # Runtime APEX. |
| .PHONY: standalone-apex-files |
| standalone-apex-files: libc.bootstrap libdl.bootstrap libm.bootstrap linker com.android.runtime.debug |
| for f in $(PRIVATE_BIONIC_FILES); do \ |
| tf=$(TARGET_OUT)/$$f; \ |
| if [ -f $$tf ]; then cp -f $$tf $$(echo $$tf | sed 's,bootstrap/,,'); fi; \ |
| done |
| if [ "x$(TARGET_FLATTEN_APEX)" = xtrue ]; then \ |
| runtime_apex_orig_dir=$(TARGET_OUT)/apex/com.android.runtime.debug; \ |
| else \ |
| runtime_apex_orig_dir=$(TARGET_OUT)/../apex/com.android.runtime.debug; \ |
| fi; \ |
| for f in $(PRIVATE_RUNTIME_DEPENDENCY_LIBS); do \ |
| tf="$$runtime_apex_orig_dir/$$f"; \ |
| if [ -f $$tf ]; then cp -f $$tf $(TARGET_OUT)/$$f; fi; \ |
| done |
| |
| ######################################################################## |
| # Phony target for only building what go/lem requires for pushing ART on /data. |
| |
| .PHONY: build-art-target-golem |
| # Also include libartbenchmark, we always include it when running golem. |
| # libstdc++ is needed when building for ART_TARGET_LINUX. |
| |
| # Also include the bootstrap Bionic libraries (libc, libdl, libm). |
| # These are required as the "main" libc, libdl, and libm have moved to |
| # the Runtime APEX. This is a temporary change needed until Golem |
| # fully supports the Runtime APEX. |
| # |
| # TODO(b/121117762, b/129332183): Remove this when the ART Buildbot |
| # and Golem have full support for the Runtime APEX. |
| |
| # Also include: |
| # - a copy of the ICU prebuilt .dat file in /system/etc/icu on target |
| # (see module `icu-data-art-test-runtime`); and |
| # so that it can be found even if the Runtime APEX is not available, |
| # by setting the environment variable `ART_TEST_ANDROID_RUNTIME_ROOT` |
| # to "/system" on device. This is a temporary change needed |
| # until Golem fully supports the Runtime APEX. |
| # |
| # Also include: |
| # - a copy of the time zone data prebuilt files in |
| # /system/etc/tzdata_module/etc/tz and /system/etc/tzdata_module/etc/icu |
| # on target, (see modules `tzdata-art-test-tzdata`, |
| # `tzlookup.xml-art-test-tzdata`, and `tz_version-art-test-tzdata`, and |
| # `icu_overlay-art-test-tzdata`) |
| # so that they can be found even if the Time Zone Data APEX is not available, |
| # by setting the environment variable `ART_TEST_ANDROID_TZDATA_ROOT` |
| # to "/system/etc/tzdata_module" on device. This is a temporary change needed |
| # until Golem fully supports the Time Zone Data APEX. |
| |
| # |
| # TODO(b/121117762, b/129332183): Remove this when the ART Buildbot |
| # and Golem have full support for the Runtime APEX. |
| ART_TARGET_SHARED_LIBRARY_BENCHMARK := $(TARGET_OUT_SHARED_LIBRARIES)/libartbenchmark.so |
| build-art-target-golem: dex2oat dalvikvm linker libstdc++ \ |
| $(TARGET_OUT_EXECUTABLES)/art \ |
| $(TARGET_OUT)/etc/public.libraries.txt \ |
| $(ART_TARGET_DEX_DEPENDENCIES) \ |
| $(ART_TARGET_SHARED_LIBRARY_DEPENDENCIES) \ |
| $(ART_TARGET_SHARED_LIBRARY_BENCHMARK) \ |
| $(TARGET_CORE_IMG_OUT_BASE).art \ |
| $(TARGET_CORE_IMG_OUT_BASE)-interpreter.art \ |
| libc.bootstrap libdl.bootstrap libm.bootstrap \ |
| icu-data-art-test-runtime \ |
| tzdata-art-test-tzdata tzlookup.xml-art-test-tzdata \ |
| tz_version-art-test-tzdata icu_overlay-art-test-tzdata \ |
| standalone-apex-files |
| # remove debug libraries from public.libraries.txt because golem builds |
| # won't have it. |
| sed -i '/libartd.so/d' $(TARGET_OUT)/etc/public.libraries.txt |
| sed -i '/libdexfiled.so/d' $(TARGET_OUT)/etc/public.libraries.txt |
| sed -i '/libprofiled.so/d' $(TARGET_OUT)/etc/public.libraries.txt |
| sed -i '/libartbased.so/d' $(TARGET_OUT)/etc/public.libraries.txt |
| |
| ######################################################################## |
| # Phony target for building what go/lem requires on host. |
| .PHONY: build-art-host-golem |
| # Also include libartbenchmark, we always include it when running golem. |
| ART_HOST_SHARED_LIBRARY_BENCHMARK := $(ART_HOST_OUT_SHARED_LIBRARIES)/libartbenchmark.so |
| build-art-host-golem: build-art-host \ |
| $(ART_HOST_SHARED_LIBRARY_BENCHMARK) |
| |
| ######################################################################## |
| # Phony target for building what go/lem requires for syncing /system to target. |
| .PHONY: build-art-unbundled-golem |
| build-art-unbundled-golem: art-runtime linker oatdump $(TARGET_CORE_JARS) crash_dump |
| |
| ######################################################################## |
| # Rules for building all dependencies for tests. |
| |
| .PHONY: build-art-host-tests |
| build-art-host-tests: build-art-host $(TEST_ART_RUN_TEST_DEPENDENCIES) $(ART_TEST_HOST_RUN_TEST_DEPENDENCIES) $(ART_TEST_HOST_GTEST_DEPENDENCIES) | $(TEST_ART_RUN_TEST_ORDERONLY_DEPENDENCIES) |
| |
| .PHONY: build-art-target-tests |
| build-art-target-tests: build-art-target $(TEST_ART_RUN_TEST_DEPENDENCIES) $(ART_TEST_TARGET_RUN_TEST_DEPENDENCIES) $(ART_TEST_TARGET_GTEST_DEPENDENCIES) | $(TEST_ART_RUN_TEST_ORDERONLY_DEPENDENCIES) |
| |
| ######################################################################## |
| # targets to switch back and forth from libdvm to libart |
| |
| .PHONY: use-art |
| use-art: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libart.so |
| $(ADB) shell start |
| |
| .PHONY: use-artd |
| use-artd: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libartd.so |
| $(ADB) shell start |
| |
| .PHONY: use-dalvik |
| use-dalvik: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libdvm.so |
| $(ADB) shell start |
| |
| .PHONY: use-art-full |
| use-art-full: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter \"\" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter \"\" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libart.so |
| $(ADB) shell setprop dalvik.vm.usejit false |
| $(ADB) shell start |
| |
| .PHONY: use-artd-full |
| use-artd-full: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter \"\" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter \"\" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libartd.so |
| $(ADB) shell setprop dalvik.vm.usejit false |
| $(ADB) shell start |
| |
| .PHONY: use-art-jit |
| use-art-jit: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter "verify-at-runtime" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter "verify-at-runtime" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libart.so |
| $(ADB) shell setprop dalvik.vm.usejit true |
| $(ADB) shell start |
| |
| .PHONY: use-art-interpret-only |
| use-art-interpret-only: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter "interpret-only" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter "interpret-only" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libart.so |
| $(ADB) shell setprop dalvik.vm.usejit false |
| $(ADB) shell start |
| |
| .PHONY: use-artd-interpret-only |
| use-artd-interpret-only: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter "interpret-only" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter "interpret-only" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libartd.so |
| $(ADB) shell setprop dalvik.vm.usejit false |
| $(ADB) shell start |
| |
| .PHONY: use-art-verify-none |
| use-art-verify-none: |
| $(ADB) root |
| $(ADB) wait-for-device shell stop |
| $(ADB) shell rm -rf $(ART_TARGET_DALVIK_CACHE_DIR)/* |
| $(ADB) shell setprop dalvik.vm.dex2oat-filter "verify-none" |
| $(ADB) shell setprop dalvik.vm.image-dex2oat-filter "verify-none" |
| $(ADB) shell setprop persist.sys.dalvik.vm.lib.2 libart.so |
| $(ADB) shell setprop dalvik.vm.usejit false |
| $(ADB) shell start |
| |
| ######################################################################## |
| |
| # Clear locally used variables. |
| TEST_ART_TARGET_SYNC_DEPS := |
| |
| # Helper target that depends on boot image creation. |
| # |
| # Can be used, for example, to dump initialization failures: |
| # m art-boot-image ART_BOOT_IMAGE_EXTRA_ARGS=--dump-init-failures=fails.txt |
| .PHONY: art-boot-image |
| art-boot-image: $(DEXPREOPT_IMAGE_boot_$(TARGET_ARCH)) |
| |
| .PHONY: art-job-images |
| art-job-images: \ |
| art-boot-image \ |
| $(2ND_DEFAULT_DEX_PREOPT_BUILT_IMAGE_FILENAME) \ |
| $(HOST_OUT_EXECUTABLES)/dex2oats \ |
| $(HOST_OUT_EXECUTABLES)/dex2oatds \ |
| $(HOST_OUT_EXECUTABLES)/profman |