diff options
| -rw-r--r-- | core/base_rules.mk | 10 | ||||
| -rw-r--r-- | core/clear_vars.mk | 1 | ||||
| -rw-r--r-- | core/line_coverage.mk | 7 | ||||
| -rw-r--r-- | core/soong_app_prebuilt.mk | 2 | ||||
| -rw-r--r-- | core/tasks/platform_availability_check.mk | 36 | ||||
| -rw-r--r-- | target/product/go_defaults_common.mk | 2 | ||||
| -rw-r--r-- | target/product/media_system.mk | 4 |
7 files changed, 55 insertions, 7 deletions
diff --git a/core/base_rules.mk b/core/base_rules.mk index 1db73ae6db..15d7a0ef24 100644 --- a/core/base_rules.mk +++ b/core/base_rules.mk @@ -811,6 +811,16 @@ ifdef LOCAL_PICKUP_FILES ALL_MODULES.$(my_register_name).PICKUP_FILES := \ $(ALL_MODULES.$(my_register_name).PICKUP_FILES) $(LOCAL_PICKUP_FILES) endif +# Record the platform availability of this module. Note that the availability is not +# meaningful for non-installable modules (e.g., static libs) or host modules. +# We only care about modules that are installable to the device. +ifeq (true,$(LOCAL_NOT_AVAILABLE_FOR_PLATFORM)) + ifneq (true,$(LOCAL_UNINSTALLABLE_MODULE)) + ifndef LOCAL_IS_HOST_MODULE + ALL_MODULES.$(my_register_name).NOT_AVAILABLE_FOR_PLATFORM := true + endif + endif +endif my_required_modules := $(LOCAL_REQUIRED_MODULES) \ $(LOCAL_REQUIRED_MODULES_$(TARGET_$(LOCAL_2ND_ARCH_VAR_PREFIX)ARCH)) diff --git a/core/clear_vars.mk b/core/clear_vars.mk index 3d481df558..0c613fa6e3 100644 --- a/core/clear_vars.mk +++ b/core/clear_vars.mk @@ -192,6 +192,7 @@ LOCAL_NO_PIC:= LOCAL_NOSANITIZE:= LOCAL_NO_STANDARD_LIBRARIES:= LOCAL_NO_STATIC_ANALYZER:= +LOCAL_NOT_AVAILABLE_FOR_PLATFORM:= LOCAL_NOTICE_FILE:= LOCAL_ODM_MODULE:= LOCAL_OEM_MODULE:= diff --git a/core/line_coverage.mk b/core/line_coverage.mk index a32eea6f7e..9b0b528600 100644 --- a/core/line_coverage.mk +++ b/core/line_coverage.mk @@ -35,6 +35,7 @@ critical_components_static := \ libvold \ libyuv +# Format is <module_name> or <module_name>:<apex_name> critical_components_shared := \ libaudioprocessing \ libbinder \ @@ -47,7 +48,7 @@ critical_components_shared := \ libopus \ libstagefright \ libunwind \ - libvixl + libvixl:com.android.art.debug # Use the intermediates directory to avoid installing libraries to the device. intermediates := $(call intermediates-dir-for,PACKAGING,haiku-line-coverage) @@ -60,7 +61,9 @@ critical_components_static_inputs := $(foreach lib,$(critical_components_static) $(call intermediates-dir-for,STATIC_LIBRARIES,$(lib))/$(lib).a) critical_components_shared_inputs := $(foreach lib,$(critical_components_shared), \ - $(call intermediates-dir-for,SHARED_LIBRARIES,$(lib))/$(lib).so) + $(eval filename := $(call word-colon,1,$(lib))) \ + $(eval modulename := $(subst :,.,$(lib))) \ + $(call intermediates-dir-for,SHARED_LIBRARIES,$(modulename))/$(filename).so) fuzz_target_inputs := $(foreach fuzz,$(fuzz_targets), \ $(call intermediates-dir-for,EXECUTABLES,$(fuzz))/$(fuzz)) diff --git a/core/soong_app_prebuilt.mk b/core/soong_app_prebuilt.mk index a3de688ee2..4197c58b3e 100644 --- a/core/soong_app_prebuilt.mk +++ b/core/soong_app_prebuilt.mk @@ -110,7 +110,7 @@ $(my_all_targets): $(my_installed) # Copy test suite files. ifdef LOCAL_COMPATIBILITY_SUITE -my_apks_to_install := $(foreach f,$(filter %.apk,$(LOCAL_SOONG_BUILT_INSTALLED)),$(call word-colon,1,$(f))) +my_apks_to_install := $(foreach f,$(filter %.apk %.idsig,$(LOCAL_SOONG_BUILT_INSTALLED)),$(call word-colon,1,$(f))) $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ $(eval my_compat_dist_$(suite) := $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ $(foreach a,$(my_apks_to_install),\ diff --git a/core/tasks/platform_availability_check.mk b/core/tasks/platform_availability_check.mk new file mode 100644 index 0000000000..043d130440 --- /dev/null +++ b/core/tasks/platform_availability_check.mk @@ -0,0 +1,36 @@ +# +# Copyright (C) 2020 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. +# + +# Check whether there is any module that isn't available for platform +# is installed to the platform. + +# Filter FAKE and NON_INSTALLABLE modules out and then collect those are not +# available for platform +_modules_not_available_for_platform := \ +$(strip $(foreach m,$(product_MODULES),\ + $(if $(filter-out FAKE,$(ALL_MODULES.$(m).CLASS)),\ + $(if $(ALL_MODULES.$(m).INSTALLED),\ + $(if $(filter true,$(ALL_MODULES.$(m).NOT_AVAILABLE_FOR_PLATFORM)),\ + $(m)))))) + +_violators_with_path := $(foreach m,$(sort $(_modules_not_available_for_platform)),\ + $(m):$(word 1,$(ALL_MODULES.$(m).PATH))\ +) + +$(call maybe-print-list-and-error,$(_violators_with_path),\ +Following modules are requested to be installed. But are not available \ +for platform because they do not have "//apex_available:platform" or \ +they depend on other modules that are not available for platform) diff --git a/target/product/go_defaults_common.mk b/target/product/go_defaults_common.mk index 64728f033b..ca171dff5c 100644 --- a/target/product/go_defaults_common.mk +++ b/target/product/go_defaults_common.mk @@ -40,7 +40,7 @@ PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD := false PRODUCT_PACKAGES += InProcessNetworkStack PRODUCT_PACKAGES += CellBroadcastAppPlatform PRODUCT_PACKAGES += CellBroadcastServiceModulePlatform -PRODUCT_PACKAGES += InProcessTethering +PRODUCT_PACKAGES += com.android.tethering.inprocess # Strip the local variable table and the local variable type table to reduce # the size of the system image. This has no bearing on stack traces, but will diff --git a/target/product/media_system.mk b/target/product/media_system.mk index 5ff747fa35..26fb7f34ba 100644 --- a/target/product/media_system.mk +++ b/target/product/media_system.mk @@ -52,9 +52,7 @@ endif PRODUCT_SYSTEM_SERVER_JARS := \ com.android.location.provider \ services \ - ethernet-service \ - service-jobscheduler \ - service-blobstore + ethernet-service # system server jars which are updated via apex modules. # The values should be of the format <apex name>:<jar name> |