blob: d467b1273e35e2916a252e66ab06747cdf835aab [file] [log] [blame]
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001// Copyright (C) 2018 The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package apex
16
17import (
18 "fmt"
Jooyung Han54aca7b2019-11-20 02:26:02 +090019 "path"
Jiyong Park48ca7dc2018-10-10 14:01:00 +090020 "path/filepath"
Jiyong Parkab3ceb32018-10-10 14:05:29 +090021 "sort"
Jiyong Park48ca7dc2018-10-10 14:01:00 +090022 "strings"
Jooyung Han344d5432019-08-23 11:17:39 +090023 "sync"
Jiyong Park48ca7dc2018-10-10 14:01:00 +090024
25 "android/soong/android"
26 "android/soong/cc"
27 "android/soong/java"
Alex Light778127a2019-02-27 14:19:50 -080028 "android/soong/python"
Jiyong Park48ca7dc2018-10-10 14:01:00 +090029
30 "github.com/google/blueprint"
Alex Light778127a2019-02-27 14:19:50 -080031 "github.com/google/blueprint/bootstrap"
Jiyong Park48ca7dc2018-10-10 14:01:00 +090032 "github.com/google/blueprint/proptools"
33)
34
Jooyung Han72bd2f82019-10-23 16:46:38 +090035const (
36 imageApexSuffix = ".apex"
37 zipApexSuffix = ".zipapex"
Sundong Ahnabb64432019-10-22 13:58:29 +090038 flattenedSuffix = ".flattened"
Alex Light5098a612018-11-29 17:12:15 -080039
Sundong Ahnabb64432019-10-22 13:58:29 +090040 imageApexType = "image"
41 zipApexType = "zip"
42 flattenedApexType = "flattened"
Jooyung Han72bd2f82019-10-23 16:46:38 +090043)
Jiyong Park48ca7dc2018-10-10 14:01:00 +090044
45type dependencyTag struct {
46 blueprint.BaseDependencyTag
47 name string
48}
49
50var (
Jiyong Parkc00cbd92018-10-30 21:20:05 +090051 sharedLibTag = dependencyTag{name: "sharedLib"}
52 executableTag = dependencyTag{name: "executable"}
53 javaLibTag = dependencyTag{name: "javaLib"}
54 prebuiltTag = dependencyTag{name: "prebuilt"}
Roland Levillain630846d2019-06-26 12:48:34 +010055 testTag = dependencyTag{name: "test"}
Jiyong Parkc00cbd92018-10-30 21:20:05 +090056 keyTag = dependencyTag{name: "key"}
57 certificateTag = dependencyTag{name: "certificate"}
Jooyung Han5c998b92019-06-27 11:30:33 +090058 usesTag = dependencyTag{name: "uses"}
Sundong Ahne1f05aa2019-08-27 13:55:42 +090059 androidAppTag = dependencyTag{name: "androidApp"}
Jiyong Park48ca7dc2018-10-10 14:01:00 +090060)
61
62func init() {
Jiyong Parkd1063c12019-07-17 20:08:41 +090063 android.RegisterModuleType("apex", BundleFactory)
Alex Light0851b882019-02-07 13:20:53 -080064 android.RegisterModuleType("apex_test", testApexBundleFactory)
Jooyung Han344d5432019-08-23 11:17:39 +090065 android.RegisterModuleType("apex_vndk", vndkApexBundleFactory)
Jiyong Park30ca9372019-02-07 16:27:23 +090066 android.RegisterModuleType("apex_defaults", defaultsFactory)
Jaewoong Jung939ebd52019-03-26 15:07:36 -070067 android.RegisterModuleType("prebuilt_apex", PrebuiltFactory)
Jiyong Park5d790c32019-11-15 18:40:32 +090068 android.RegisterModuleType("override_apex", overrideApexFactory)
Jiyong Park48ca7dc2018-10-10 14:01:00 +090069
Jooyung Han31c470b2019-10-18 16:26:59 +090070 android.PreDepsMutators(RegisterPreDepsMutators)
Jiyong Parkd1063c12019-07-17 20:08:41 +090071 android.PostDepsMutators(RegisterPostDepsMutators)
Jooyung Han7a78a922019-10-08 21:59:58 +090072
73 android.RegisterMakeVarsProvider(pctx, func(ctx android.MakeVarsContext) {
74 apexFileContextsInfos := apexFileContextsInfos(ctx.Config())
75 sort.Strings(*apexFileContextsInfos)
76 ctx.Strict("APEX_FILE_CONTEXTS_INFOS", strings.Join(*apexFileContextsInfos, " "))
77 })
Jiyong Parkd1063c12019-07-17 20:08:41 +090078}
79
Jooyung Han31c470b2019-10-18 16:26:59 +090080func RegisterPreDepsMutators(ctx android.RegisterMutatorsContext) {
81 ctx.TopDown("apex_vndk", apexVndkMutator).Parallel()
82 ctx.BottomUp("apex_vndk_deps", apexVndkDepsMutator).Parallel()
83}
84
Jiyong Parkd1063c12019-07-17 20:08:41 +090085func RegisterPostDepsMutators(ctx android.RegisterMutatorsContext) {
Jiyong Parka308ea12019-11-15 10:38:39 +090086 ctx.BottomUp("apex_deps", apexDepsMutator)
Jiyong Parkd1063c12019-07-17 20:08:41 +090087 ctx.BottomUp("apex", apexMutator).Parallel()
88 ctx.BottomUp("apex_flattened", apexFlattenedMutator).Parallel()
89 ctx.BottomUp("apex_uses", apexUsesMutator).Parallel()
Jiyong Park48ca7dc2018-10-10 14:01:00 +090090}
91
Jiyong Park48ca7dc2018-10-10 14:01:00 +090092// Mark the direct and transitive dependencies of apex bundles so that they
93// can be built for the apex bundles.
Jiyong Parka308ea12019-11-15 10:38:39 +090094func apexDepsMutator(mctx android.BottomUpMutatorContext) {
Alex Lightf98087f2019-02-04 14:45:06 -080095 if a, ok := mctx.Module().(*apexBundle); ok {
Colin Crossa4925902018-11-16 11:36:28 -080096 apexBundleName := mctx.ModuleName()
Jiyong Park48ca7dc2018-10-10 14:01:00 +090097 mctx.WalkDeps(func(child, parent android.Module) bool {
Jiyong Park0ddfcd12018-12-11 01:35:25 +090098 depName := mctx.OtherModuleName(child)
99 // If the parent is apexBundle, this child is directly depended.
100 _, directDep := parent.(*apexBundle)
Alex Light0851b882019-02-07 13:20:53 -0800101 if a.installable() && !a.testApex {
Alex Lightf98087f2019-02-04 14:45:06 -0800102 // TODO(b/123892969): Workaround for not having any way to annotate test-apexs
103 // non-installable apex's cannot be installed and so should not prevent libraries from being
104 // installed to the system.
105 android.UpdateApexDependency(apexBundleName, depName, directDep)
106 }
Jiyong Park0ddfcd12018-12-11 01:35:25 +0900107
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900108 if am, ok := child.(android.ApexModule); ok && am.CanHaveApexVariants() {
Jiyong Park0ddfcd12018-12-11 01:35:25 +0900109 am.BuildForApex(apexBundleName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900110 return true
111 } else {
112 return false
113 }
114 })
115 }
116}
117
118// Create apex variations if a module is included in APEX(s).
119func apexMutator(mctx android.BottomUpMutatorContext) {
120 if am, ok := mctx.Module().(android.ApexModule); ok && am.CanHaveApexVariants() {
Jiyong Park0ddfcd12018-12-11 01:35:25 +0900121 am.CreateApexVariations(mctx)
Jooyung Han54aca7b2019-11-20 02:26:02 +0900122 } else if _, ok := mctx.Module().(*apexBundle); ok {
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900123 // apex bundle itself is mutated so that it and its modules have same
124 // apex variant.
125 apexBundleName := mctx.ModuleName()
126 mctx.CreateVariations(apexBundleName)
Jiyong Park5d790c32019-11-15 18:40:32 +0900127 } else if o, ok := mctx.Module().(*OverrideApex); ok {
128 apexBundleName := o.GetOverriddenModuleName()
129 if apexBundleName == "" {
130 mctx.ModuleErrorf("base property is not set")
131 return
132 }
133 mctx.CreateVariations(apexBundleName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900134 }
Jiyong Park5d790c32019-11-15 18:40:32 +0900135
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900136}
Sundong Ahne9b55722019-09-06 17:37:42 +0900137
Jooyung Han7a78a922019-10-08 21:59:58 +0900138var (
139 apexFileContextsInfosKey = android.NewOnceKey("apexFileContextsInfosKey")
140 apexFileContextsInfosMutex sync.Mutex
141)
142
143func apexFileContextsInfos(config android.Config) *[]string {
144 return config.Once(apexFileContextsInfosKey, func() interface{} {
145 return &[]string{}
146 }).(*[]string)
147}
148
Jooyung Han54aca7b2019-11-20 02:26:02 +0900149func addFlattenedFileContextsInfos(ctx android.BaseModuleContext, fileContextsInfo string) {
Jooyung Han7a78a922019-10-08 21:59:58 +0900150 apexFileContextsInfosMutex.Lock()
151 defer apexFileContextsInfosMutex.Unlock()
152 apexFileContextsInfos := apexFileContextsInfos(ctx.Config())
Jooyung Han54aca7b2019-11-20 02:26:02 +0900153 *apexFileContextsInfos = append(*apexFileContextsInfos, fileContextsInfo)
Jooyung Han7a78a922019-10-08 21:59:58 +0900154}
155
Sundong Ahne9b55722019-09-06 17:37:42 +0900156func apexFlattenedMutator(mctx android.BottomUpMutatorContext) {
Sundong Ahne8fb7242019-09-17 13:50:45 +0900157 if ab, ok := mctx.Module().(*apexBundle); ok {
Sundong Ahnabb64432019-10-22 13:58:29 +0900158 var variants []string
159 switch proptools.StringDefault(ab.properties.Payload_type, "image") {
160 case "image":
161 variants = append(variants, imageApexType, flattenedApexType)
162 case "zip":
163 variants = append(variants, zipApexType)
164 case "both":
165 variants = append(variants, imageApexType, zipApexType, flattenedApexType)
166 default:
Sundong Ahnd95aa2d2019-10-08 19:34:03 +0900167 mctx.PropertyErrorf("type", "%q is not one of \"image\", \"zip\", or \"both\".", *ab.properties.Payload_type)
Sundong Ahnabb64432019-10-22 13:58:29 +0900168 return
169 }
170
171 modules := mctx.CreateLocalVariations(variants...)
172
173 for i, v := range variants {
174 switch v {
175 case imageApexType:
176 modules[i].(*apexBundle).properties.ApexType = imageApex
177 case zipApexType:
178 modules[i].(*apexBundle).properties.ApexType = zipApex
179 case flattenedApexType:
180 modules[i].(*apexBundle).properties.ApexType = flattenedApex
Jooyung Han91df2082019-11-20 01:49:42 +0900181 if !mctx.Config().FlattenApex() && ab.Platform() {
Sundong Ahnd95aa2d2019-10-08 19:34:03 +0900182 modules[i].(*apexBundle).MakeAsSystemExt()
183 }
Sundong Ahnabb64432019-10-22 13:58:29 +0900184 }
Sundong Ahne9b55722019-09-06 17:37:42 +0900185 }
Jiyong Park5d790c32019-11-15 18:40:32 +0900186 } else if _, ok := mctx.Module().(*OverrideApex); ok {
187 mctx.CreateVariations(imageApexType, flattenedApexType)
Sundong Ahne9b55722019-09-06 17:37:42 +0900188 }
189}
190
Jooyung Han5c998b92019-06-27 11:30:33 +0900191func apexUsesMutator(mctx android.BottomUpMutatorContext) {
192 if ab, ok := mctx.Module().(*apexBundle); ok {
193 mctx.AddFarVariationDependencies(nil, usesTag, ab.properties.Uses...)
194 }
195}
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900196
Jooyung Handc782442019-11-01 03:14:38 +0900197var (
198 useVendorWhitelistKey = android.NewOnceKey("useVendorWhitelist")
199)
200
201// useVendorWhitelist returns the list of APEXes which are allowed to use_vendor.
202// When use_vendor is used, native modules are built with __ANDROID_VNDK__ and __ANDROID_APEX__,
203// which may cause compatibility issues. (e.g. libbinder)
204// Even though libbinder restricts its availability via 'apex_available' property and relies on
205// yet another macro __ANDROID_APEX_<NAME>__, we restrict usage of "use_vendor:" from other APEX modules
206// to avoid similar problems.
207func useVendorWhitelist(config android.Config) []string {
208 return config.Once(useVendorWhitelistKey, func() interface{} {
209 return []string{
210 // swcodec uses "vendor" variants for smaller size
211 "com.android.media.swcodec",
212 "test_com.android.media.swcodec",
213 }
214 }).([]string)
215}
216
217// setUseVendorWhitelistForTest overrides useVendorWhitelist and must be
218// called before the first call to useVendorWhitelist()
219func setUseVendorWhitelistForTest(config android.Config, whitelist []string) {
220 config.Once(useVendorWhitelistKey, func() interface{} {
221 return whitelist
222 })
223}
224
Alex Light9670d332019-01-29 18:07:33 -0800225type apexNativeDependencies struct {
226 // List of native libraries
227 Native_shared_libs []string
Jooyung Han344d5432019-08-23 11:17:39 +0900228
Alex Light9670d332019-01-29 18:07:33 -0800229 // List of native executables
230 Binaries []string
Jooyung Han344d5432019-08-23 11:17:39 +0900231
Roland Levillain630846d2019-06-26 12:48:34 +0100232 // List of native tests
233 Tests []string
Alex Light9670d332019-01-29 18:07:33 -0800234}
Jooyung Han344d5432019-08-23 11:17:39 +0900235
Alex Light9670d332019-01-29 18:07:33 -0800236type apexMultilibProperties struct {
237 // Native dependencies whose compile_multilib is "first"
238 First apexNativeDependencies
239
240 // Native dependencies whose compile_multilib is "both"
241 Both apexNativeDependencies
242
243 // Native dependencies whose compile_multilib is "prefer32"
244 Prefer32 apexNativeDependencies
245
246 // Native dependencies whose compile_multilib is "32"
247 Lib32 apexNativeDependencies
248
249 // Native dependencies whose compile_multilib is "64"
250 Lib64 apexNativeDependencies
251}
252
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900253type apexBundleProperties struct {
254 // Json manifest file describing meta info of this APEX bundle. Default:
Dario Freni4abb1dc2018-11-20 18:04:58 +0000255 // "apex_manifest.json"
Colin Cross27b922f2019-03-04 22:35:41 -0800256 Manifest *string `android:"path"`
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900257
Jiyong Park40e26a22019-02-08 02:53:06 +0900258 // AndroidManifest.xml file used for the zip container of this APEX bundle.
259 // If unspecified, a default one is automatically generated.
Colin Cross27b922f2019-03-04 22:35:41 -0800260 AndroidManifest *string `android:"path"`
Jiyong Park40e26a22019-02-08 02:53:06 +0900261
Roland Levillain411c5842019-09-19 16:37:20 +0100262 // Canonical name of the APEX bundle. Used to determine the path to the activated APEX on
263 // device (/apex/<apex_name>).
264 // If unspecified, defaults to the value of name.
Jiyong Park05e70dd2019-03-18 14:26:32 +0900265 Apex_name *string
266
Jiyong Parkd0a65ba2018-11-10 06:37:15 +0900267 // Determines the file contexts file for setting security context to each file in this APEX bundle.
Jooyung Han54aca7b2019-11-20 02:26:02 +0900268 // For platform APEXes, this should points to a file under /system/sepolicy
269 // Default: /system/sepolicy/apex/<module_name>_file_contexts.
270 File_contexts *string `android:"path"`
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900271
272 // List of native shared libs that are embedded inside this APEX bundle
273 Native_shared_libs []string
274
Roland Levillain630846d2019-06-26 12:48:34 +0100275 // List of executables that are embedded inside this APEX bundle
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900276 Binaries []string
277
278 // List of java libraries that are embedded inside this APEX bundle
279 Java_libs []string
280
281 // List of prebuilt files that are embedded inside this APEX bundle
282 Prebuilts []string
Jiyong Parkff1458f2018-10-12 21:49:38 +0900283
Roland Levillain630846d2019-06-26 12:48:34 +0100284 // List of tests that are embedded inside this APEX bundle
285 Tests []string
286
Jiyong Parkff1458f2018-10-12 21:49:38 +0900287 // Name of the apex_key module that provides the private key to sign APEX
288 Key *string
Jiyong Park397e55e2018-10-24 21:09:55 +0900289
Alex Light5098a612018-11-29 17:12:15 -0800290 // The type of APEX to build. Controls what the APEX payload is. Either
291 // 'image', 'zip' or 'both'. Default: 'image'.
292 Payload_type *string
293
Jiyong Parkc00cbd92018-10-30 21:20:05 +0900294 // The name of a certificate in the default certificate directory, blank to use the default product certificate,
295 // or an android_app_certificate module name in the form ":module".
296 Certificate *string
297
Jiyong Park92c0f9c2018-12-13 23:14:57 +0900298 // Whether this APEX is installable to one of the partitions. Default: true.
299 Installable *bool
300
Jiyong Parkda6eb592018-12-19 17:12:36 +0900301 // For native libraries and binaries, use the vendor variant instead of the core (platform) variant.
302 // Default is false.
303 Use_vendor *bool
304
Alex Lightfc0bd7c2019-01-29 18:31:59 -0800305 // For telling the apex to ignore special handling for system libraries such as bionic. Default is false.
306 Ignore_system_library_special_case *bool
307
Alex Light9670d332019-01-29 18:07:33 -0800308 Multilib apexMultilibProperties
Jiyong Park235e67c2019-02-09 11:50:56 +0900309
Jiyong Parkf97782b2019-02-13 20:28:58 +0900310 // List of sanitizer names that this APEX is enabled for
311 SanitizerNames []string `blueprint:"mutated"`
Jooyung Han5c998b92019-06-27 11:30:33 +0900312
Jiyong Parkee9a98d2019-08-09 14:44:36 +0900313 PreventInstall bool `blueprint:"mutated"`
314
315 HideFromMake bool `blueprint:"mutated"`
316
Jooyung Han5c998b92019-06-27 11:30:33 +0900317 // Indicates this APEX provides C++ shared libaries to other APEXes. Default: false.
318 Provide_cpp_shared_libs *bool
319
320 // List of providing APEXes' names so that this APEX can depend on provided shared libraries.
321 Uses []string
Nikita Ioffe5d5ae762019-08-31 14:38:05 +0100322
323 // A txt file containing list of files that are whitelisted to be included in this APEX.
324 Whitelisted_files *string
Sundong Ahne1f05aa2019-08-27 13:55:42 +0900325
Sundong Ahnabb64432019-10-22 13:58:29 +0900326 // package format of this apex variant; could be non-flattened, flattened, or zip.
327 // imageApex, zipApex or flattened
328 ApexType apexPackaging `blueprint:"mutated"`
Sundong Ahne8fb7242019-09-17 13:50:45 +0900329
Jiyong Parkd1063c12019-07-17 20:08:41 +0900330 // List of SDKs that are used to build this APEX. A reference to an SDK should be either
331 // `name#version` or `name` which is an alias for `name#current`. If left empty, `platform#current`
332 // is implied. This value affects all modules included in this APEX. In other words, they are
333 // also built with the SDKs specified here.
334 Uses_sdks []string
Jiyong Park5d790c32019-11-15 18:40:32 +0900335
336 // Names of modules to be overridden. Listed modules can only be other binaries
337 // (in Make or Soong).
338 // This does not completely prevent installation of the overridden binaries, but if both
339 // binaries would be installed by default (in PRODUCT_PACKAGES) the other binary will be removed
340 // from PRODUCT_PACKAGES.
341 Overrides []string
Alex Light9670d332019-01-29 18:07:33 -0800342}
343
344type apexTargetBundleProperties struct {
345 Target struct {
346 // Multilib properties only for android.
347 Android struct {
348 Multilib apexMultilibProperties
Jiyong Park397e55e2018-10-24 21:09:55 +0900349 }
Jooyung Han344d5432019-08-23 11:17:39 +0900350
Alex Light9670d332019-01-29 18:07:33 -0800351 // Multilib properties only for host.
352 Host struct {
353 Multilib apexMultilibProperties
Jiyong Park397e55e2018-10-24 21:09:55 +0900354 }
Jooyung Han344d5432019-08-23 11:17:39 +0900355
Alex Light9670d332019-01-29 18:07:33 -0800356 // Multilib properties only for host linux_bionic.
357 Linux_bionic struct {
358 Multilib apexMultilibProperties
Jiyong Park397e55e2018-10-24 21:09:55 +0900359 }
Jooyung Han344d5432019-08-23 11:17:39 +0900360
Alex Light9670d332019-01-29 18:07:33 -0800361 // Multilib properties only for host linux_glibc.
362 Linux_glibc struct {
363 Multilib apexMultilibProperties
Jiyong Park397e55e2018-10-24 21:09:55 +0900364 }
365 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900366}
367
Jiyong Park5d790c32019-11-15 18:40:32 +0900368type overridableProperties struct {
369 // List of APKs to package inside APEX
370 Apps []string
371}
372
Jiyong Park8fd61922018-11-08 02:50:25 +0900373type apexFileClass int
374
375const (
376 etc apexFileClass = iota
377 nativeSharedLib
378 nativeExecutable
Jiyong Park04480cf2019-02-06 00:16:29 +0900379 shBinary
Alex Light778127a2019-02-27 14:19:50 -0800380 pyBinary
381 goBinary
Jiyong Park8fd61922018-11-08 02:50:25 +0900382 javaSharedLib
Roland Levillain630846d2019-06-26 12:48:34 +0100383 nativeTest
Sundong Ahne1f05aa2019-08-27 13:55:42 +0900384 app
Jiyong Park8fd61922018-11-08 02:50:25 +0900385)
386
Alex Light5098a612018-11-29 17:12:15 -0800387type apexPackaging int
388
389const (
390 imageApex apexPackaging = iota
391 zipApex
Sundong Ahnabb64432019-10-22 13:58:29 +0900392 flattenedApex
Alex Light5098a612018-11-29 17:12:15 -0800393)
394
Sundong Ahnabb64432019-10-22 13:58:29 +0900395// The suffix for the output "file", not the module
Alex Light5098a612018-11-29 17:12:15 -0800396func (a apexPackaging) suffix() string {
397 switch a {
398 case imageApex:
399 return imageApexSuffix
400 case zipApex:
401 return zipApexSuffix
Alex Light5098a612018-11-29 17:12:15 -0800402 default:
Roland Levillain4644b222019-07-31 14:09:17 +0100403 panic(fmt.Errorf("unknown APEX type %d", a))
Alex Light5098a612018-11-29 17:12:15 -0800404 }
405}
406
407func (a apexPackaging) name() string {
408 switch a {
409 case imageApex:
410 return imageApexType
411 case zipApex:
412 return zipApexType
Alex Light5098a612018-11-29 17:12:15 -0800413 default:
Roland Levillain4644b222019-07-31 14:09:17 +0100414 panic(fmt.Errorf("unknown APEX type %d", a))
Alex Light5098a612018-11-29 17:12:15 -0800415 }
416}
417
Jiyong Park8fd61922018-11-08 02:50:25 +0900418func (class apexFileClass) NameInMake() string {
419 switch class {
420 case etc:
421 return "ETC"
422 case nativeSharedLib:
423 return "SHARED_LIBRARIES"
Alex Light778127a2019-02-27 14:19:50 -0800424 case nativeExecutable, shBinary, pyBinary, goBinary:
Jiyong Park8fd61922018-11-08 02:50:25 +0900425 return "EXECUTABLES"
426 case javaSharedLib:
427 return "JAVA_LIBRARIES"
Roland Levillain630846d2019-06-26 12:48:34 +0100428 case nativeTest:
429 return "NATIVE_TESTS"
Sundong Ahne1f05aa2019-08-27 13:55:42 +0900430 case app:
Jiyong Parkf383f7c2019-10-11 20:46:25 +0900431 // b/142537672 Why isn't this APP? We want to have full control over
432 // the paths and file names of the apk file under the flattend APEX.
433 // If this is set to APP, then the paths and file names are modified
434 // by the Make build system. For example, it is installed to
435 // /system/apex/<apexname>/app/<Appname>/<apexname>.<Appname>/ instead of
436 // /system/apex/<apexname>/app/<Appname> because the build system automatically
437 // appends module name (which is <apexname>.<Appname> to the path.
438 return "ETC"
Jiyong Park8fd61922018-11-08 02:50:25 +0900439 default:
Roland Levillain4644b222019-07-31 14:09:17 +0100440 panic(fmt.Errorf("unknown class %d", class))
Jiyong Park8fd61922018-11-08 02:50:25 +0900441 }
442}
443
444type apexFile struct {
445 builtFile android.Path
446 moduleName string
Jiyong Park8fd61922018-11-08 02:50:25 +0900447 installDir string
448 class apexFileClass
Jiyong Parka8894842018-12-19 17:36:39 +0900449 module android.Module
Alex Light3d673592019-01-18 14:37:31 -0800450 symlinks []string
Jiyong Park8fd61922018-11-08 02:50:25 +0900451}
452
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900453type apexBundle struct {
454 android.ModuleBase
455 android.DefaultableModuleBase
Jiyong Park5d790c32019-11-15 18:40:32 +0900456 android.OverridableModuleBase
Jiyong Parkd1063c12019-07-17 20:08:41 +0900457 android.SdkBase
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900458
Jiyong Park5d790c32019-11-15 18:40:32 +0900459 properties apexBundleProperties
460 targetProperties apexTargetBundleProperties
461 vndkProperties apexVndkProperties
462 overridableProperties overridableProperties
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900463
Colin Crossa4925902018-11-16 11:36:28 -0800464 bundleModuleFile android.WritablePath
Sundong Ahnabb64432019-10-22 13:58:29 +0900465 outputFile android.WritablePath
Colin Cross70dda7e2019-10-01 22:05:35 -0700466 installDir android.InstallPath
Jiyong Park8fd61922018-11-08 02:50:25 +0900467
Jiyong Park03b68dd2019-07-26 23:20:40 +0900468 prebuiltFileToDelete string
469
Jiyong Park42cca6c2019-04-01 11:15:50 +0900470 public_key_file android.Path
471 private_key_file android.Path
Jiyong Park0ca3ce82019-02-18 15:25:04 +0900472
473 container_certificate_file android.Path
474 container_private_key_file android.Path
475
Jooyung Han54aca7b2019-11-20 02:26:02 +0900476 fileContexts android.Path
477
Jiyong Park8fd61922018-11-08 02:50:25 +0900478 // list of files to be included in this apex
479 filesInfo []apexFile
480
Jiyong Parkac2bacd2019-02-20 21:49:26 +0900481 // list of module names that this APEX is depending on
482 externalDeps []string
483
Sundong Ahnabb64432019-10-22 13:58:29 +0900484 testApex bool
485 vndkApex bool
Ulyana Trafimovichde534412019-11-08 10:51:01 +0000486 artApex bool
Sundong Ahnabb64432019-10-22 13:58:29 +0900487 primaryApexType bool
Jooyung Hane1633032019-08-01 17:41:43 +0900488
489 // intermediate path for apex_manifest.json
Jooyung Han01a3ee22019-11-02 02:52:25 +0900490 manifestJsonOut android.WritablePath
491 manifestJsonFullOut android.WritablePath
492 manifestPbOut android.WritablePath
Jooyung Han72bd2f82019-10-23 16:46:38 +0900493
494 // list of commands to create symlinks for backward compatibility
495 // these commands will be attached as LOCAL_POST_INSTALL_CMD to
496 // apex package itself(for unflattened build) or apex_manifest.json(for flattened build)
497 // so that compat symlinks are always installed regardless of TARGET_FLATTEN_APEX setting.
498 compatSymlinks []string
Sundong Ahnabb64432019-10-22 13:58:29 +0900499
500 // Suffix of module name in Android.mk
501 // ".flattened", ".apex", ".zipapex", or ""
502 suffix string
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900503}
504
Jiyong Park397e55e2018-10-24 21:09:55 +0900505func addDependenciesForNativeModules(ctx android.BottomUpMutatorContext,
Roland Levillain630846d2019-06-26 12:48:34 +0100506 native_shared_libs []string, binaries []string, tests []string,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700507 target android.Target, imageVariation string) {
Jiyong Park397e55e2018-10-24 21:09:55 +0900508 // Use *FarVariation* to be able to depend on modules having
509 // conflicting variations with this module. This is required since
510 // arch variant of an APEX bundle is 'common' but it is 'arm' or 'arm64'
511 // for native shared libs.
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700512 ctx.AddFarVariationDependencies(append(target.Variations(), []blueprint.Variation{
Jiyong Parkda6eb592018-12-19 17:12:36 +0900513 {Mutator: "image", Variation: imageVariation},
Jiyong Park397e55e2018-10-24 21:09:55 +0900514 {Mutator: "link", Variation: "shared"},
Jiyong Park28d395a2018-12-07 22:42:47 +0900515 {Mutator: "version", Variation: ""}, // "" is the non-stub variant
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700516 }...), sharedLibTag, native_shared_libs...)
Jiyong Park397e55e2018-10-24 21:09:55 +0900517
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700518 ctx.AddFarVariationDependencies(append(target.Variations(),
519 blueprint.Variation{Mutator: "image", Variation: imageVariation}),
520 executableTag, binaries...)
Roland Levillain630846d2019-06-26 12:48:34 +0100521
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700522 ctx.AddFarVariationDependencies(append(target.Variations(), []blueprint.Variation{
Roland Levillain630846d2019-06-26 12:48:34 +0100523 {Mutator: "image", Variation: imageVariation},
Roland Levillain9b5fde92019-06-28 15:41:19 +0100524 {Mutator: "test_per_src", Variation: ""}, // "" is the all-tests variant
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700525 }...), testTag, tests...)
Jiyong Park397e55e2018-10-24 21:09:55 +0900526}
527
Alex Light9670d332019-01-29 18:07:33 -0800528func (a *apexBundle) combineProperties(ctx android.BottomUpMutatorContext) {
529 if ctx.Os().Class == android.Device {
530 proptools.AppendProperties(&a.properties.Multilib, &a.targetProperties.Target.Android.Multilib, nil)
531 } else {
532 proptools.AppendProperties(&a.properties.Multilib, &a.targetProperties.Target.Host.Multilib, nil)
533 if ctx.Os().Bionic() {
534 proptools.AppendProperties(&a.properties.Multilib, &a.targetProperties.Target.Linux_bionic.Multilib, nil)
535 } else {
536 proptools.AppendProperties(&a.properties.Multilib, &a.targetProperties.Target.Linux_glibc.Multilib, nil)
537 }
538 }
539}
540
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900541func (a *apexBundle) DepsMutator(ctx android.BottomUpMutatorContext) {
Jooyung Handc782442019-11-01 03:14:38 +0900542 if proptools.Bool(a.properties.Use_vendor) && !android.InList(a.Name(), useVendorWhitelist(ctx.Config())) {
543 ctx.PropertyErrorf("use_vendor", "not allowed to set use_vendor: true")
544 }
545
Jiyong Park397e55e2018-10-24 21:09:55 +0900546 targets := ctx.MultiTargets()
Jiyong Park7c1dc612019-01-05 11:15:24 +0900547 config := ctx.DeviceConfig()
Alex Light9670d332019-01-29 18:07:33 -0800548
549 a.combineProperties(ctx)
550
Jiyong Park397e55e2018-10-24 21:09:55 +0900551 has32BitTarget := false
552 for _, target := range targets {
553 if target.Arch.ArchType.Multilib == "lib32" {
554 has32BitTarget = true
555 }
556 }
557 for i, target := range targets {
558 // When multilib.* is omitted for native_shared_libs, it implies
559 // multilib.both.
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700560 ctx.AddFarVariationDependencies(append(target.Variations(), []blueprint.Variation{
Jiyong Park7c1dc612019-01-05 11:15:24 +0900561 {Mutator: "image", Variation: a.getImageVariation(config)},
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900562 {Mutator: "link", Variation: "shared"},
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700563 }...), sharedLibTag, a.properties.Native_shared_libs...)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900564
Roland Levillain630846d2019-06-26 12:48:34 +0100565 // When multilib.* is omitted for tests, it implies
566 // multilib.both.
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700567 ctx.AddFarVariationDependencies(append(target.Variations(), []blueprint.Variation{
Roland Levillain630846d2019-06-26 12:48:34 +0100568 {Mutator: "image", Variation: a.getImageVariation(config)},
Roland Levillain9b5fde92019-06-28 15:41:19 +0100569 {Mutator: "test_per_src", Variation: ""}, // "" is the all-tests variant
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700570 }...), testTag, a.properties.Tests...)
Roland Levillain630846d2019-06-26 12:48:34 +0100571
Jiyong Park397e55e2018-10-24 21:09:55 +0900572 // Add native modules targetting both ABIs
573 addDependenciesForNativeModules(ctx,
574 a.properties.Multilib.Both.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100575 a.properties.Multilib.Both.Binaries,
576 a.properties.Multilib.Both.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700577 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900578 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900579
Alex Light3d673592019-01-18 14:37:31 -0800580 isPrimaryAbi := i == 0
581 if isPrimaryAbi {
Jiyong Park397e55e2018-10-24 21:09:55 +0900582 // When multilib.* is omitted for binaries, it implies
583 // multilib.first.
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700584 ctx.AddFarVariationDependencies(append(target.Variations(),
585 blueprint.Variation{Mutator: "image", Variation: a.getImageVariation(config)}),
586 executableTag, a.properties.Binaries...)
Jiyong Park397e55e2018-10-24 21:09:55 +0900587
588 // Add native modules targetting the first ABI
589 addDependenciesForNativeModules(ctx,
590 a.properties.Multilib.First.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100591 a.properties.Multilib.First.Binaries,
592 a.properties.Multilib.First.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700593 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900594 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900595 }
596
597 switch target.Arch.ArchType.Multilib {
598 case "lib32":
599 // Add native modules targetting 32-bit ABI
600 addDependenciesForNativeModules(ctx,
601 a.properties.Multilib.Lib32.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100602 a.properties.Multilib.Lib32.Binaries,
603 a.properties.Multilib.Lib32.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700604 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900605 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900606
607 addDependenciesForNativeModules(ctx,
608 a.properties.Multilib.Prefer32.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100609 a.properties.Multilib.Prefer32.Binaries,
610 a.properties.Multilib.Prefer32.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700611 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900612 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900613 case "lib64":
614 // Add native modules targetting 64-bit ABI
615 addDependenciesForNativeModules(ctx,
616 a.properties.Multilib.Lib64.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100617 a.properties.Multilib.Lib64.Binaries,
618 a.properties.Multilib.Lib64.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700619 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900620 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900621
622 if !has32BitTarget {
623 addDependenciesForNativeModules(ctx,
624 a.properties.Multilib.Prefer32.Native_shared_libs,
Roland Levillain630846d2019-06-26 12:48:34 +0100625 a.properties.Multilib.Prefer32.Binaries,
626 a.properties.Multilib.Prefer32.Tests,
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700627 target,
Jiyong Park7c1dc612019-01-05 11:15:24 +0900628 a.getImageVariation(config))
Jiyong Park397e55e2018-10-24 21:09:55 +0900629 }
Peter Collingbourne3478bb22019-04-24 14:41:12 -0700630
631 if strings.HasPrefix(ctx.ModuleName(), "com.android.runtime") && target.Os.Class == android.Device {
632 for _, sanitizer := range ctx.Config().SanitizeDevice() {
633 if sanitizer == "hwaddress" {
634 addDependenciesForNativeModules(ctx,
635 []string{"libclang_rt.hwasan-aarch64-android"},
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700636 nil, nil, target, a.getImageVariation(config))
Peter Collingbourne3478bb22019-04-24 14:41:12 -0700637 break
638 }
639 }
640 }
Jiyong Park397e55e2018-10-24 21:09:55 +0900641 }
642
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900643 }
644
Jiyong Parkce6aadc2019-11-20 13:58:28 +0900645 // For prebuilt_etc, use the first variant (64 on 64/32bit device,
646 // 32 on 32bit device) regardless of the TARGET_PREFER_* setting.
647 // b/144532908
648 archForPrebuiltEtc := config.Arches()[0]
649 for _, arch := range config.Arches() {
650 // Prefer 64-bit arch if there is any
651 if arch.ArchType.Multilib == "lib64" {
652 archForPrebuiltEtc = arch
653 break
654 }
655 }
656 ctx.AddFarVariationDependencies([]blueprint.Variation{
657 {Mutator: "os", Variation: ctx.Os().String()},
658 {Mutator: "arch", Variation: archForPrebuiltEtc.String()},
659 }, prebuiltTag, a.properties.Prebuilts...)
660
Colin Cross0f7d2ef2019-10-16 11:03:10 -0700661 ctx.AddFarVariationDependencies(ctx.Config().AndroidCommonTarget.Variations(),
662 javaLibTag, a.properties.Java_libs...)
Jiyong Parkff1458f2018-10-12 21:49:38 +0900663
Jiyong Park23c52b02019-02-02 13:13:47 +0900664 if String(a.properties.Key) == "" {
665 ctx.ModuleErrorf("key is missing")
666 return
667 }
668 ctx.AddDependency(ctx.Module(), keyTag, String(a.properties.Key))
Jiyong Parkc00cbd92018-10-30 21:20:05 +0900669
Jiyong Parkb2742fd2019-02-11 11:38:15 +0900670 cert := android.SrcIsModule(a.getCertString(ctx))
Jiyong Park23c52b02019-02-02 13:13:47 +0900671 if cert != "" {
672 ctx.AddDependency(ctx.Module(), certificateTag, cert)
Jiyong Parkc00cbd92018-10-30 21:20:05 +0900673 }
Jiyong Parkd1063c12019-07-17 20:08:41 +0900674
675 // TODO(jiyong): ensure that all apexes are with non-empty uses_sdks
676 if len(a.properties.Uses_sdks) > 0 {
677 sdkRefs := []android.SdkRef{}
678 for _, str := range a.properties.Uses_sdks {
679 parsed := android.ParseSdkRef(ctx, str, "uses_sdks")
680 sdkRefs = append(sdkRefs, parsed)
681 }
682 a.BuildWithSdks(sdkRefs)
683 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900684}
685
Jiyong Park5d790c32019-11-15 18:40:32 +0900686func (a *apexBundle) OverridablePropertiesDepsMutator(ctx android.BottomUpMutatorContext) {
687 ctx.AddFarVariationDependencies(ctx.Config().AndroidCommonTarget.Variations(),
688 androidAppTag, a.overridableProperties.Apps...)
689}
690
Jiyong Parka7bc8ad2019-10-15 15:20:07 +0900691func (a *apexBundle) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Module) bool {
692 // direct deps of an APEX bundle are all part of the APEX bundle
693 return true
694}
695
Colin Cross0ea8ba82019-06-06 14:33:29 -0700696func (a *apexBundle) getCertString(ctx android.BaseModuleContext) string {
Jiyong Parkb2742fd2019-02-11 11:38:15 +0900697 certificate, overridden := ctx.DeviceConfig().OverrideCertificateFor(ctx.ModuleName())
698 if overridden {
Jaewoong Jungacb6db32019-02-28 16:22:30 +0000699 return ":" + certificate
Jiyong Parkb2742fd2019-02-11 11:38:15 +0900700 }
701 return String(a.properties.Certificate)
702}
703
Colin Cross41955e82019-05-29 14:40:35 -0700704func (a *apexBundle) OutputFiles(tag string) (android.Paths, error) {
705 switch tag {
706 case "":
Sundong Ahnabb64432019-10-22 13:58:29 +0900707 return android.Paths{a.outputFile}, nil
Colin Cross41955e82019-05-29 14:40:35 -0700708 default:
709 return nil, fmt.Errorf("unsupported module reference tag %q", tag)
Jiyong Park5a832022018-12-20 09:54:35 +0900710 }
Jiyong Park74e240b2018-11-27 21:27:08 +0900711}
712
Jiyong Park92c0f9c2018-12-13 23:14:57 +0900713func (a *apexBundle) installable() bool {
Jiyong Parkee9a98d2019-08-09 14:44:36 +0900714 return !a.properties.PreventInstall && (a.properties.Installable == nil || proptools.Bool(a.properties.Installable))
Jiyong Park92c0f9c2018-12-13 23:14:57 +0900715}
716
Jiyong Park7c1dc612019-01-05 11:15:24 +0900717func (a *apexBundle) getImageVariation(config android.DeviceConfig) string {
Jooyung Han31c470b2019-10-18 16:26:59 +0900718 if a.vndkApex {
Colin Cross7228ecd2019-11-18 16:00:16 -0800719 return cc.VendorVariationPrefix + a.vndkVersion(config)
Jooyung Han31c470b2019-10-18 16:26:59 +0900720 }
Jiyong Park7c1dc612019-01-05 11:15:24 +0900721 if config.VndkVersion() != "" && proptools.Bool(a.properties.Use_vendor) {
Colin Cross7228ecd2019-11-18 16:00:16 -0800722 return cc.VendorVariationPrefix + config.PlatformVndkVersion()
Jiyong Parkda6eb592018-12-19 17:12:36 +0900723 } else {
Colin Cross7228ecd2019-11-18 16:00:16 -0800724 return android.CoreVariation
Jiyong Parkda6eb592018-12-19 17:12:36 +0900725 }
726}
727
Jiyong Parkf97782b2019-02-13 20:28:58 +0900728func (a *apexBundle) EnableSanitizer(sanitizerName string) {
729 if !android.InList(sanitizerName, a.properties.SanitizerNames) {
730 a.properties.SanitizerNames = append(a.properties.SanitizerNames, sanitizerName)
731 }
732}
733
Jiyong Park388ef3f2019-01-28 19:47:32 +0900734func (a *apexBundle) IsSanitizerEnabled(ctx android.BaseModuleContext, sanitizerName string) bool {
Jiyong Parkf97782b2019-02-13 20:28:58 +0900735 if android.InList(sanitizerName, a.properties.SanitizerNames) {
736 return true
Jiyong Park235e67c2019-02-09 11:50:56 +0900737 }
738
739 // Then follow the global setting
Jiyong Park388ef3f2019-01-28 19:47:32 +0900740 globalSanitizerNames := []string{}
741 if a.Host() {
742 globalSanitizerNames = ctx.Config().SanitizeHost()
743 } else {
744 arches := ctx.Config().SanitizeDeviceArch()
745 if len(arches) == 0 || android.InList(a.Arch().ArchType.Name, arches) {
746 globalSanitizerNames = ctx.Config().SanitizeDevice()
747 }
748 }
749 return android.InList(sanitizerName, globalSanitizerNames)
Jiyong Park379de2f2018-12-19 02:47:14 +0900750}
751
Jiyong Parkee9a98d2019-08-09 14:44:36 +0900752func (a *apexBundle) IsNativeCoverageNeeded(ctx android.BaseModuleContext) bool {
753 return ctx.Device() && ctx.DeviceConfig().NativeCoverageEnabled()
754}
755
756func (a *apexBundle) PreventInstall() {
757 a.properties.PreventInstall = true
758}
759
760func (a *apexBundle) HideFromMake() {
761 a.properties.HideFromMake = true
762}
763
Martin Stjernholm279de572019-09-10 23:18:20 +0100764func getCopyManifestForNativeLibrary(ccMod *cc.Module, config android.Config, handleSpecialLibs bool) (fileToCopy android.Path, dirInApex string) {
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900765 // Decide the APEX-local directory by the multilib of the library
766 // In the future, we may query this to the module.
Martin Stjernholm279de572019-09-10 23:18:20 +0100767 switch ccMod.Arch().ArchType.Multilib {
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900768 case "lib32":
769 dirInApex = "lib"
770 case "lib64":
771 dirInApex = "lib64"
772 }
Martin Stjernholm279de572019-09-10 23:18:20 +0100773 dirInApex = filepath.Join(dirInApex, ccMod.RelativeInstallPath())
Colin Cross3b19f5d2019-09-17 14:45:31 -0700774 if ccMod.Target().NativeBridge == android.NativeBridgeEnabled {
Martin Stjernholm279de572019-09-10 23:18:20 +0100775 dirInApex = filepath.Join(dirInApex, ccMod.Target().NativeBridgeRelativePath)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900776 }
Martin Stjernholm279de572019-09-10 23:18:20 +0100777 if handleSpecialLibs && cc.InstallToBootstrap(ccMod.BaseModuleName(), config) {
778 // Special case for Bionic libs and other libs installed with them. This is
779 // to prevent those libs from being included in the search path
780 // /apex/com.android.runtime/${LIB}. This exclusion is required because
781 // those libs in the Runtime APEX are available via the legacy paths in
782 // /system/lib/. By the init process, the libs in the APEX are bind-mounted
783 // to the legacy paths and thus will be loaded into the default linker
784 // namespace (aka "platform" namespace). If the libs are directly in
785 // /apex/com.android.runtime/${LIB} then the same libs will be loaded again
786 // into the runtime linker namespace, which will result in double loading of
787 // them, which isn't supported.
788 dirInApex = filepath.Join(dirInApex, "bionic")
Jiyong Parkb0788572018-12-20 22:10:17 +0900789 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900790
Martin Stjernholm279de572019-09-10 23:18:20 +0100791 fileToCopy = ccMod.OutputFile().Path()
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900792 return
793}
794
795func getCopyManifestForExecutable(cc *cc.Module) (fileToCopy android.Path, dirInApex string) {
Jiyong Parkbd13e442019-03-15 18:10:35 +0900796 dirInApex = filepath.Join("bin", cc.RelativeInstallPath())
Colin Cross3b19f5d2019-09-17 14:45:31 -0700797 if cc.Target().NativeBridge == android.NativeBridgeEnabled {
dimitry8d6dde82019-07-11 10:23:53 +0200798 dirInApex = filepath.Join(dirInApex, cc.Target().NativeBridgeRelativePath)
Jiyong Parkacbf6c72019-07-09 16:19:16 +0900799 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900800 fileToCopy = cc.OutputFile().Path()
801 return
802}
803
Alex Light778127a2019-02-27 14:19:50 -0800804func getCopyManifestForPyBinary(py *python.Module) (fileToCopy android.Path, dirInApex string) {
805 dirInApex = "bin"
806 fileToCopy = py.HostToolPath().Path()
807 return
808}
809func getCopyManifestForGoBinary(ctx android.ModuleContext, gb bootstrap.GoBinaryTool) (fileToCopy android.Path, dirInApex string) {
810 dirInApex = "bin"
811 s, err := filepath.Rel(android.PathForOutput(ctx).String(), gb.InstallPath())
812 if err != nil {
813 ctx.ModuleErrorf("Unable to use compiled binary at %s", gb.InstallPath())
814 return
815 }
816 fileToCopy = android.PathForOutput(ctx, s)
817 return
818}
819
Jiyong Park04480cf2019-02-06 00:16:29 +0900820func getCopyManifestForShBinary(sh *android.ShBinary) (fileToCopy android.Path, dirInApex string) {
821 dirInApex = filepath.Join("bin", sh.SubDir())
822 fileToCopy = sh.OutputFile()
823 return
824}
825
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900826func getCopyManifestForJavaLibrary(java *java.Library) (fileToCopy android.Path, dirInApex string) {
827 dirInApex = "javalib"
Jiyong Park8fd61922018-11-08 02:50:25 +0900828 fileToCopy = java.DexJarFile()
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900829 return
830}
831
Jiyong Park9e6c2422019-08-09 20:39:45 +0900832func getCopyManifestForPrebuiltJavaLibrary(java *java.Import) (fileToCopy android.Path, dirInApex string) {
833 dirInApex = "javalib"
834 // The output is only one, but for some reason, ImplementationJars returns Paths, not Path
835 implJars := java.ImplementationJars()
836 if len(implJars) != 1 {
837 panic(fmt.Errorf("java.ImplementationJars() must return single Path, but got: %s",
838 strings.Join(implJars.Strings(), ", ")))
839 }
840 fileToCopy = implJars[0]
841 return
842}
843
Jooyung Han39edb6c2019-11-06 16:53:07 +0900844func getCopyManifestForPrebuiltEtc(prebuilt android.PrebuiltEtcModule) (fileToCopy android.Path, dirInApex string) {
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900845 dirInApex = filepath.Join("etc", prebuilt.SubDir())
846 fileToCopy = prebuilt.OutputFile()
847 return
848}
849
Sundong Ahne1f05aa2019-08-27 13:55:42 +0900850func getCopyManifestForAndroidApp(app *java.AndroidApp, pkgName string) (fileToCopy android.Path, dirInApex string) {
Jiyong Parkf7487312019-10-17 12:54:30 +0900851 appDir := "app"
852 if app.Privileged() {
853 appDir = "priv-app"
854 }
855 dirInApex = filepath.Join(appDir, pkgName)
Sundong Ahne1f05aa2019-08-27 13:55:42 +0900856 fileToCopy = app.OutputFile()
857 return
858}
859
Dario Frenicde2a032019-10-27 00:29:22 +0100860func getCopyManifestForAndroidAppImport(app *java.AndroidAppImport, pkgName string) (fileToCopy android.Path, dirInApex string) {
861 appDir := "app"
862 if app.Privileged() {
863 appDir = "priv-app"
864 }
865 dirInApex = filepath.Join(appDir, pkgName)
866 fileToCopy = app.OutputFile()
867 return
868}
869
Roland Levillain935639d2019-08-13 14:55:28 +0100870// Context "decorator", overriding the InstallBypassMake method to always reply `true`.
871type flattenedApexContext struct {
872 android.ModuleContext
873}
874
875func (c *flattenedApexContext) InstallBypassMake() bool {
876 return true
877}
878
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900879func (a *apexBundle) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Jiyong Park8fd61922018-11-08 02:50:25 +0900880 filesInfo := []apexFile{}
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900881
Sundong Ahnabb64432019-10-22 13:58:29 +0900882 buildFlattenedAsDefault := ctx.Config().FlattenApex() && !ctx.Config().UnbundledBuild()
883 switch a.properties.ApexType {
884 case imageApex:
885 if buildFlattenedAsDefault {
886 a.suffix = imageApexSuffix
887 } else {
888 a.suffix = ""
889 a.primaryApexType = true
890 }
891 case zipApex:
892 if proptools.String(a.properties.Payload_type) == "zip" {
893 a.suffix = ""
894 a.primaryApexType = true
895 } else {
896 a.suffix = zipApexSuffix
897 }
898 case flattenedApex:
899 if buildFlattenedAsDefault {
900 a.suffix = ""
901 a.primaryApexType = true
902 } else {
903 a.suffix = flattenedSuffix
904 }
Alex Light5098a612018-11-29 17:12:15 -0800905 }
906
Roland Levillain630846d2019-06-26 12:48:34 +0100907 if len(a.properties.Tests) > 0 && !a.testApex {
908 ctx.PropertyErrorf("tests", "property not allowed in apex module type")
909 return
910 }
911
Alex Lightfc0bd7c2019-01-29 18:31:59 -0800912 handleSpecialLibs := !android.Bool(a.properties.Ignore_system_library_special_case)
913
Jooyung Hane1633032019-08-01 17:41:43 +0900914 // native lib dependencies
915 var provideNativeLibs []string
916 var requireNativeLibs []string
917
Jooyung Han5c998b92019-06-27 11:30:33 +0900918 // Check if "uses" requirements are met with dependent apexBundles
919 var providedNativeSharedLibs []string
920 useVendor := proptools.Bool(a.properties.Use_vendor)
921 ctx.VisitDirectDepsBlueprint(func(m blueprint.Module) {
922 if ctx.OtherModuleDependencyTag(m) != usesTag {
923 return
924 }
925 otherName := ctx.OtherModuleName(m)
926 other, ok := m.(*apexBundle)
927 if !ok {
928 ctx.PropertyErrorf("uses", "%q is not a provider", otherName)
929 return
930 }
931 if proptools.Bool(other.properties.Use_vendor) != useVendor {
932 ctx.PropertyErrorf("use_vendor", "%q has different value of use_vendor", otherName)
933 return
934 }
935 if !proptools.Bool(other.properties.Provide_cpp_shared_libs) {
936 ctx.PropertyErrorf("uses", "%q does not provide native_shared_libs", otherName)
937 return
938 }
939 providedNativeSharedLibs = append(providedNativeSharedLibs, other.properties.Native_shared_libs...)
940 })
941
Alex Light778127a2019-02-27 14:19:50 -0800942 ctx.WalkDepsBlueprint(func(child, parent blueprint.Module) bool {
Roland Levillainf89cd092019-07-29 16:22:59 +0100943 depTag := ctx.OtherModuleDependencyTag(child)
944 depName := ctx.OtherModuleName(child)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900945 if _, ok := parent.(*apexBundle); ok {
946 // direct dependencies
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900947 switch depTag {
948 case sharedLibTag:
949 if cc, ok := child.(*cc.Module); ok {
Jooyung Hane1633032019-08-01 17:41:43 +0900950 if cc.HasStubsVariants() {
951 provideNativeLibs = append(provideNativeLibs, cc.OutputFile().Path().Base())
952 }
Martin Stjernholm279de572019-09-10 23:18:20 +0100953 fileToCopy, dirInApex := getCopyManifestForNativeLibrary(cc, ctx.Config(), handleSpecialLibs)
Jiyong Park719b4462019-01-13 00:39:51 +0900954 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, nativeSharedLib, cc, nil})
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900955 return true
Jiyong Parkff1458f2018-10-12 21:49:38 +0900956 } else {
957 ctx.PropertyErrorf("native_shared_libs", "%q is not a cc_library or cc_library_shared module", depName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900958 }
959 case executableTag:
960 if cc, ok := child.(*cc.Module); ok {
961 fileToCopy, dirInApex := getCopyManifestForExecutable(cc)
Jiyong Park719b4462019-01-13 00:39:51 +0900962 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, nativeExecutable, cc, cc.Symlinks()})
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900963 return true
Jiyong Park04480cf2019-02-06 00:16:29 +0900964 } else if sh, ok := child.(*android.ShBinary); ok {
965 fileToCopy, dirInApex := getCopyManifestForShBinary(sh)
Rashed Abdel-Tawab6a341312019-10-04 20:38:01 -0700966 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, shBinary, sh, sh.Symlinks()})
Alex Light778127a2019-02-27 14:19:50 -0800967 } else if py, ok := child.(*python.Module); ok && py.HostToolPath().Valid() {
968 fileToCopy, dirInApex := getCopyManifestForPyBinary(py)
969 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, pyBinary, py, nil})
970 } else if gb, ok := child.(bootstrap.GoBinaryTool); ok && a.Host() {
971 fileToCopy, dirInApex := getCopyManifestForGoBinary(ctx, gb)
972 // NB: Since go binaries are static we don't need the module for anything here, which is
973 // good since the go tool is a blueprint.Module not an android.Module like we would
974 // normally use.
975 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, goBinary, nil, nil})
Jiyong Parkff1458f2018-10-12 21:49:38 +0900976 } else {
Alex Light778127a2019-02-27 14:19:50 -0800977 ctx.PropertyErrorf("binaries", "%q is neither cc_binary, (embedded) py_binary, (host) blueprint_go_binary, (host) bootstrap_go_binary, nor sh_binary", depName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900978 }
979 case javaLibTag:
Jiyong Park9e6c2422019-08-09 20:39:45 +0900980 if javaLib, ok := child.(*java.Library); ok {
981 fileToCopy, dirInApex := getCopyManifestForJavaLibrary(javaLib)
Jiyong Park8fd61922018-11-08 02:50:25 +0900982 if fileToCopy == nil {
983 ctx.PropertyErrorf("java_libs", "%q is not configured to be compiled into dex", depName)
984 } else {
Jiyong Park9e6c2422019-08-09 20:39:45 +0900985 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, javaSharedLib, javaLib, nil})
986 }
987 return true
988 } else if javaLib, ok := child.(*java.Import); ok {
989 fileToCopy, dirInApex := getCopyManifestForPrebuiltJavaLibrary(javaLib)
990 if fileToCopy == nil {
991 ctx.PropertyErrorf("java_libs", "%q does not have a jar output", depName)
992 } else {
993 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, javaSharedLib, javaLib, nil})
Jiyong Park8fd61922018-11-08 02:50:25 +0900994 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900995 return true
Jiyong Parkff1458f2018-10-12 21:49:38 +0900996 } else {
Jiyong Park9e6c2422019-08-09 20:39:45 +0900997 ctx.PropertyErrorf("java_libs", "%q of type %q is not supported", depName, ctx.OtherModuleType(child))
Jiyong Park48ca7dc2018-10-10 14:01:00 +0900998 }
999 case prebuiltTag:
Jooyung Han39edb6c2019-11-06 16:53:07 +09001000 if prebuilt, ok := child.(android.PrebuiltEtcModule); ok {
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001001 fileToCopy, dirInApex := getCopyManifestForPrebuiltEtc(prebuilt)
Jiyong Park719b4462019-01-13 00:39:51 +09001002 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, etc, prebuilt, nil})
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001003 return true
Jiyong Parkff1458f2018-10-12 21:49:38 +09001004 } else {
1005 ctx.PropertyErrorf("prebuilts", "%q is not a prebuilt_etc module", depName)
1006 }
Roland Levillain630846d2019-06-26 12:48:34 +01001007 case testTag:
Roland Levillainf89cd092019-07-29 16:22:59 +01001008 if ccTest, ok := child.(*cc.Module); ok {
1009 if ccTest.IsTestPerSrcAllTestsVariation() {
1010 // Multiple-output test module (where `test_per_src: true`).
1011 //
1012 // `ccTest` is the "" ("all tests") variation of a `test_per_src` module.
1013 // We do not add this variation to `filesInfo`, as it has no output;
1014 // however, we do add the other variations of this module as indirect
1015 // dependencies (see below).
1016 return true
Roland Levillain9b5fde92019-06-28 15:41:19 +01001017 } else {
Roland Levillainf89cd092019-07-29 16:22:59 +01001018 // Single-output test module (where `test_per_src: false`).
1019 fileToCopy, dirInApex := getCopyManifestForExecutable(ccTest)
1020 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, nativeTest, ccTest, nil})
Roland Levillain9b5fde92019-06-28 15:41:19 +01001021 }
Roland Levillain630846d2019-06-26 12:48:34 +01001022 return true
1023 } else {
1024 ctx.PropertyErrorf("tests", "%q is not a cc module", depName)
1025 }
Jiyong Parkff1458f2018-10-12 21:49:38 +09001026 case keyTag:
1027 if key, ok := child.(*apexKey); ok {
Jiyong Park0ca3ce82019-02-18 15:25:04 +09001028 a.private_key_file = key.private_key_file
1029 a.public_key_file = key.public_key_file
Jiyong Parkff1458f2018-10-12 21:49:38 +09001030 return false
1031 } else {
1032 ctx.PropertyErrorf("key", "%q is not an apex_key module", depName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001033 }
Jiyong Parkc00cbd92018-10-30 21:20:05 +09001034 case certificateTag:
1035 if dep, ok := child.(*java.AndroidAppCertificate); ok {
Jiyong Park0ca3ce82019-02-18 15:25:04 +09001036 a.container_certificate_file = dep.Certificate.Pem
1037 a.container_private_key_file = dep.Certificate.Key
Jiyong Parkc00cbd92018-10-30 21:20:05 +09001038 return false
1039 } else {
1040 ctx.ModuleErrorf("certificate dependency %q must be an android_app_certificate module", depName)
1041 }
Jiyong Park03b68dd2019-07-26 23:20:40 +09001042 case android.PrebuiltDepTag:
1043 // If the prebuilt is force disabled, remember to delete the prebuilt file
1044 // that might have been installed in the previous builds
1045 if prebuilt, ok := child.(*Prebuilt); ok && prebuilt.isForceDisabled() {
1046 a.prebuiltFileToDelete = prebuilt.InstallFilename()
1047 }
Sundong Ahne1f05aa2019-08-27 13:55:42 +09001048 case androidAppTag:
1049 if ap, ok := child.(*java.AndroidApp); ok {
1050 fileToCopy, dirInApex := getCopyManifestForAndroidApp(ap, ctx.DeviceConfig().OverridePackageNameFor(depName))
1051 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, app, ap, nil})
1052 return true
Dario Frenicde2a032019-10-27 00:29:22 +01001053 } else if ap, ok := child.(*java.AndroidAppImport); ok {
1054 fileToCopy, dirInApex := getCopyManifestForAndroidAppImport(ap, ctx.DeviceConfig().OverridePackageNameFor(depName))
1055 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, app, ap, nil})
Sundong Ahne1f05aa2019-08-27 13:55:42 +09001056 } else {
1057 ctx.PropertyErrorf("apps", "%q is not an android_app module", depName)
1058 }
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001059 }
Jooyung Han8aee2042019-10-29 05:08:31 +09001060 } else if !a.vndkApex {
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001061 // indirect dependencies
Jooyung Han9c80bae2019-08-20 17:30:57 +09001062 if am, ok := child.(android.ApexModule); ok {
Roland Levillainf89cd092019-07-29 16:22:59 +01001063 // We cannot use a switch statement on `depTag` here as the checked
1064 // tags used below are private (e.g. `cc.sharedDepTag`).
Jiyong Park52cd06f2019-11-11 10:14:32 +09001065 if cc.IsSharedDepTag(depTag) || cc.IsRuntimeDepTag(depTag) {
Roland Levillainf89cd092019-07-29 16:22:59 +01001066 if cc, ok := child.(*cc.Module); ok {
1067 if android.InList(cc.Name(), providedNativeSharedLibs) {
1068 // If we're using a shared library which is provided from other APEX,
1069 // don't include it in this APEX
1070 return false
Jiyong Parkac2bacd2019-02-20 21:49:26 +09001071 }
Roland Levillainf89cd092019-07-29 16:22:59 +01001072 if !a.Host() && (cc.IsStubs() || cc.HasStubsVariants()) {
1073 // If the dependency is a stubs lib, don't include it in this APEX,
1074 // but make sure that the lib is installed on the device.
1075 // In case no APEX is having the lib, the lib is installed to the system
1076 // partition.
1077 //
1078 // Always include if we are a host-apex however since those won't have any
1079 // system libraries.
1080 if !android.DirectlyInAnyApex(ctx, cc.Name()) && !android.InList(cc.Name(), a.externalDeps) {
1081 a.externalDeps = append(a.externalDeps, cc.Name())
1082 }
Jooyung Hane1633032019-08-01 17:41:43 +09001083 requireNativeLibs = append(requireNativeLibs, cc.OutputFile().Path().Base())
Roland Levillainf89cd092019-07-29 16:22:59 +01001084 // Don't track further
1085 return false
1086 }
Martin Stjernholm279de572019-09-10 23:18:20 +01001087 fileToCopy, dirInApex := getCopyManifestForNativeLibrary(cc, ctx.Config(), handleSpecialLibs)
Roland Levillainf89cd092019-07-29 16:22:59 +01001088 filesInfo = append(filesInfo, apexFile{fileToCopy, depName, dirInApex, nativeSharedLib, cc, nil})
1089 return true
Jiyong Park25fc6a92018-11-18 18:02:45 +09001090 }
Roland Levillainf89cd092019-07-29 16:22:59 +01001091 } else if cc.IsTestPerSrcDepTag(depTag) {
1092 if cc, ok := child.(*cc.Module); ok {
1093 fileToCopy, dirInApex := getCopyManifestForExecutable(cc)
1094 // Handle modules created as `test_per_src` variations of a single test module:
1095 // use the name of the generated test binary (`fileToCopy`) instead of the name
1096 // of the original test module (`depName`, shared by all `test_per_src`
1097 // variations of that module).
1098 moduleName := filepath.Base(fileToCopy.String())
1099 filesInfo = append(filesInfo, apexFile{fileToCopy, moduleName, dirInApex, nativeTest, cc, nil})
1100 return true
1101 }
Jiyong Park52cd06f2019-11-11 10:14:32 +09001102 } else if java.IsJniDepTag(depTag) {
1103 // Do nothing for JNI dep. JNI libraries are always embedded in APK-in-APEX.
Jooyung Han9c80bae2019-08-20 17:30:57 +09001104 } else if am.CanHaveApexVariants() && am.IsInstallableToApex() {
Roland Levillainf89cd092019-07-29 16:22:59 +01001105 ctx.ModuleErrorf("unexpected tag %q for indirect dependency %q", depTag, depName)
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001106 }
1107 }
1108 }
1109 return false
1110 })
1111
Ulyana Trafimovichde534412019-11-08 10:51:01 +00001112 // Specific to the ART apex: dexpreopt artifacts for libcore Java libraries.
1113 // Build rules are generated by the dexpreopt singleton, and here we access build artifacts
1114 // via the global boot image config.
1115 if a.artApex {
1116 for arch, files := range java.DexpreoptedArtApexJars(ctx) {
1117 dirInApex := filepath.Join("javalib", arch.String())
1118 for _, f := range files {
1119 localModule := "javalib_" + arch.String() + "_" + filepath.Base(f.String())
1120 filesInfo = append(filesInfo, apexFile{f, localModule, dirInApex, etc, nil, nil})
1121 }
1122 }
1123 }
1124
Jiyong Park0ca3ce82019-02-18 15:25:04 +09001125 if a.private_key_file == nil {
Jiyong Parkfa0a3732018-11-09 05:52:26 +09001126 ctx.PropertyErrorf("key", "private_key for %q could not be found", String(a.properties.Key))
1127 return
1128 }
1129
Jiyong Park8fd61922018-11-08 02:50:25 +09001130 // remove duplicates in filesInfo
1131 removeDup := func(filesInfo []apexFile) []apexFile {
Jooyung Han344d5432019-08-23 11:17:39 +09001132 encountered := make(map[string]bool)
Jiyong Park8fd61922018-11-08 02:50:25 +09001133 result := []apexFile{}
1134 for _, f := range filesInfo {
Jooyung Han344d5432019-08-23 11:17:39 +09001135 dest := filepath.Join(f.installDir, f.builtFile.Base())
1136 if !encountered[dest] {
1137 encountered[dest] = true
Jiyong Park8fd61922018-11-08 02:50:25 +09001138 result = append(result, f)
1139 }
1140 }
1141 return result
1142 }
1143 filesInfo = removeDup(filesInfo)
1144
1145 // to have consistent build rules
1146 sort.Slice(filesInfo, func(i, j int) bool {
1147 return filesInfo[i].builtFile.String() < filesInfo[j].builtFile.String()
1148 })
1149
Jiyong Park127b40b2019-09-30 16:04:35 +09001150 // check apex_available requirements
Jiyong Park3814f4d2019-12-02 13:08:53 +09001151 if !ctx.Host() && !a.testApex {
Jiyong Park583a2262019-10-08 20:55:38 +09001152 for _, fi := range filesInfo {
1153 if am, ok := fi.module.(android.ApexModule); ok {
1154 if !am.AvailableFor(ctx.ModuleName()) {
1155 ctx.ModuleErrorf("requires %q that is not available for the APEX", fi.module.Name())
Jiyong Park3814f4d2019-12-02 13:08:53 +09001156 // don't stop so that we can report other violations in the same run
Jiyong Park583a2262019-10-08 20:55:38 +09001157 }
Jiyong Park127b40b2019-09-30 16:04:35 +09001158 }
1159 }
1160 }
1161
Jiyong Park8fd61922018-11-08 02:50:25 +09001162 // prepend the name of this APEX to the module names. These names will be the names of
1163 // modules that will be defined if the APEX is flattened.
1164 for i := range filesInfo {
Jaewoong Jung1670ca02019-11-22 14:50:42 -08001165 filesInfo[i].moduleName = filesInfo[i].moduleName + "." + a.Name() + a.suffix
Jiyong Park8fd61922018-11-08 02:50:25 +09001166 }
1167
Jiyong Park8fd61922018-11-08 02:50:25 +09001168 a.installDir = android.PathForModuleInstall(ctx, "apex")
1169 a.filesInfo = filesInfo
Alex Light5098a612018-11-29 17:12:15 -08001170
Jooyung Han54aca7b2019-11-20 02:26:02 +09001171 if a.properties.ApexType != zipApex {
1172 if a.properties.File_contexts == nil {
1173 a.fileContexts = android.PathForSource(ctx, "system/sepolicy/apex", ctx.ModuleName()+"-file_contexts")
1174 } else {
1175 a.fileContexts = android.PathForModuleSrc(ctx, *a.properties.File_contexts)
1176 if a.Platform() {
1177 if matched, err := path.Match("system/sepolicy/**/*", a.fileContexts.String()); err != nil || !matched {
1178 ctx.PropertyErrorf("file_contexts", "should be under system/sepolicy, but %q", a.fileContexts)
1179 }
1180 }
1181 }
1182 if !android.ExistentPathForSource(ctx, a.fileContexts.String()).Valid() {
1183 ctx.PropertyErrorf("file_contexts", "cannot find file_contexts file: %q", a.fileContexts)
1184 return
1185 }
1186 }
1187
Jooyung Hand15aa1f2019-09-27 00:38:03 +09001188 // prepare apex_manifest.json
Jooyung Han01a3ee22019-11-02 02:52:25 +09001189 a.buildManifest(ctx, provideNativeLibs, requireNativeLibs)
1190
1191 a.setCertificateAndPrivateKey(ctx)
1192 if a.properties.ApexType == flattenedApex {
1193 a.buildFlattenedApex(ctx)
1194 } else {
1195 a.buildUnflattenedApex(ctx)
1196 }
1197
Jaewoong Jung1670ca02019-11-22 14:50:42 -08001198 apexName := proptools.StringDefault(a.properties.Apex_name, a.Name())
Jooyung Han01a3ee22019-11-02 02:52:25 +09001199 a.compatSymlinks = makeCompatSymlinks(apexName, ctx)
1200}
1201
Jooyung Han344d5432019-08-23 11:17:39 +09001202func newApexBundle() *apexBundle {
Sundong Ahnabb64432019-10-22 13:58:29 +09001203 module := &apexBundle{}
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001204 module.AddProperties(&module.properties)
Alex Light9670d332019-01-29 18:07:33 -08001205 module.AddProperties(&module.targetProperties)
Jiyong Park5d790c32019-11-15 18:40:32 +09001206 module.AddProperties(&module.overridableProperties)
Alex Light5098a612018-11-29 17:12:15 -08001207 module.Prefer32(func(ctx android.BaseModuleContext, base *android.ModuleBase, class android.OsClass) bool {
Jiyong Park397e55e2018-10-24 21:09:55 +09001208 return class == android.Device && ctx.Config().DevicePrefer32BitExecutables()
1209 })
Alex Light5098a612018-11-29 17:12:15 -08001210 android.InitAndroidMultiTargetsArchModule(module, android.HostAndDeviceSupported, android.MultilibCommon)
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001211 android.InitDefaultableModule(module)
Jiyong Parkd1063c12019-07-17 20:08:41 +09001212 android.InitSdkAwareModule(module)
Jiyong Park5d790c32019-11-15 18:40:32 +09001213 android.InitOverridableModule(module, &module.properties.Overrides)
Jiyong Park48ca7dc2018-10-10 14:01:00 +09001214 return module
1215}
Jiyong Park30ca9372019-02-07 16:27:23 +09001216
Ulyana Trafimovichde534412019-11-08 10:51:01 +00001217func ApexBundleFactory(testApex bool, artApex bool) android.Module {
Jooyung Han344d5432019-08-23 11:17:39 +09001218 bundle := newApexBundle()
1219 bundle.testApex = testApex
Ulyana Trafimovichde534412019-11-08 10:51:01 +00001220 bundle.artApex = artApex
Jooyung Han344d5432019-08-23 11:17:39 +09001221 return bundle
1222}
1223
1224func testApexBundleFactory() android.Module {
1225 bundle := newApexBundle()
1226 bundle.testApex = true
1227 return bundle
1228}
1229
Jiyong Parkd1063c12019-07-17 20:08:41 +09001230func BundleFactory() android.Module {
Jooyung Han344d5432019-08-23 11:17:39 +09001231 return newApexBundle()
1232}
1233
Jiyong Park30ca9372019-02-07 16:27:23 +09001234//
1235// Defaults
1236//
1237type Defaults struct {
1238 android.ModuleBase
1239 android.DefaultsModuleBase
1240}
1241
Jiyong Park30ca9372019-02-07 16:27:23 +09001242func defaultsFactory() android.Module {
1243 return DefaultsFactory()
1244}
1245
1246func DefaultsFactory(props ...interface{}) android.Module {
1247 module := &Defaults{}
1248
1249 module.AddProperties(props...)
1250 module.AddProperties(
1251 &apexBundleProperties{},
1252 &apexTargetBundleProperties{},
1253 )
1254
1255 android.InitDefaultsModule(module)
1256 return module
1257}
Jiyong Park5d790c32019-11-15 18:40:32 +09001258
1259//
1260// OverrideApex
1261//
1262type OverrideApex struct {
1263 android.ModuleBase
1264 android.OverrideModuleBase
1265}
1266
1267func (o *OverrideApex) GenerateAndroidBuildActions(ctx android.ModuleContext) {
1268 // All the overrides happen in the base module.
1269}
1270
1271// override_apex is used to create an apex module based on another apex module
1272// by overriding some of its properties.
1273func overrideApexFactory() android.Module {
1274 m := &OverrideApex{}
1275 m.AddProperties(&overridableProperties{})
1276
1277 android.InitAndroidMultiTargetsArchModule(m, android.DeviceSupported, android.MultilibCommon)
1278 android.InitOverrideModule(m)
1279 return m
1280}