Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 1 | // Copyright 2021 Google Inc. All rights reserved. |
| 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 | |
| 15 | package java |
| 16 | |
| 17 | import ( |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 18 | "fmt" |
| 19 | |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 20 | "android/soong/android" |
| 21 | "android/soong/dexpreopt" |
| 22 | ) |
| 23 | |
| 24 | func init() { |
| 25 | registerPlatformBootclasspathBuildComponents(android.InitRegistrationContext) |
| 26 | } |
| 27 | |
| 28 | func registerPlatformBootclasspathBuildComponents(ctx android.RegistrationContext) { |
Paul Duffin | e3ecce6 | 2021-04-29 10:34:11 +0100 | [diff] [blame] | 29 | ctx.RegisterSingletonModuleType("platform_bootclasspath", platformBootclasspathFactory) |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 30 | } |
| 31 | |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 32 | // The tags used for the dependencies between the platform bootclasspath and any configured boot |
| 33 | // jars. |
| 34 | var ( |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 35 | platformBootclasspathArtBootJarDepTag = bootclasspathDependencyTag{name: "art-boot-jar"} |
| 36 | platformBootclasspathBootJarDepTag = bootclasspathDependencyTag{name: "platform-boot-jar"} |
| 37 | platformBootclasspathApexBootJarDepTag = bootclasspathDependencyTag{name: "apex-boot-jar"} |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 38 | ) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 39 | |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 40 | type platformBootclasspathModule struct { |
Paul Duffin | e3ecce6 | 2021-04-29 10:34:11 +0100 | [diff] [blame] | 41 | android.SingletonModuleBase |
Artur Satayev | 97259dc | 2021-04-07 15:17:14 +0100 | [diff] [blame] | 42 | ClasspathFragmentBase |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 43 | |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 44 | properties platformBootclasspathProperties |
| 45 | |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 46 | // The apex:module pairs obtained from the configured modules. |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 47 | configuredModules []android.Module |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 48 | |
| 49 | // The apex:module pairs obtained from the fragments. |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 50 | fragments []android.Module |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 51 | |
| 52 | // Path to the monolithic hiddenapi-flags.csv file. |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 53 | hiddenAPIFlagsCSV android.OutputPath |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 54 | |
| 55 | // Path to the monolithic hiddenapi-index.csv file. |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 56 | hiddenAPIIndexCSV android.OutputPath |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 57 | |
| 58 | // Path to the monolithic hiddenapi-unsupported.csv file. |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 59 | hiddenAPIMetadataCSV android.OutputPath |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 60 | } |
| 61 | |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 62 | type platformBootclasspathProperties struct { |
Paul Duffin | b67d878 | 2021-04-22 11:49:41 +0100 | [diff] [blame] | 63 | BootclasspathFragmentsDepsProperties |
Paul Duffin | 702210b | 2021-04-08 20:12:41 +0100 | [diff] [blame] | 64 | |
Paul Duffin | 9b61abb | 2022-07-27 16:16:54 +0000 | [diff] [blame] | 65 | HiddenAPIFlagFileProperties |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 66 | } |
| 67 | |
Paul Duffin | e3ecce6 | 2021-04-29 10:34:11 +0100 | [diff] [blame] | 68 | func platformBootclasspathFactory() android.SingletonModule { |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 69 | m := &platformBootclasspathModule{} |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 70 | m.AddProperties(&m.properties) |
satayev | 95e9c5b | 2021-04-29 11:50:26 +0100 | [diff] [blame] | 71 | initClasspathFragment(m, BOOTCLASSPATH) |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 72 | android.InitAndroidArchModule(m, android.DeviceSupported, android.MultilibCommon) |
| 73 | return m |
| 74 | } |
| 75 | |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 76 | var _ android.OutputFileProducer = (*platformBootclasspathModule)(nil) |
| 77 | |
Artur Satayev | 97259dc | 2021-04-07 15:17:14 +0100 | [diff] [blame] | 78 | func (b *platformBootclasspathModule) AndroidMkEntries() (entries []android.AndroidMkEntries) { |
| 79 | entries = append(entries, android.AndroidMkEntries{ |
| 80 | Class: "FAKE", |
| 81 | // Need at least one output file in order for this to take effect. |
| 82 | OutputFile: android.OptionalPathForPath(b.hiddenAPIFlagsCSV), |
| 83 | Include: "$(BUILD_PHONY_PACKAGE)", |
| 84 | }) |
satayev | 128ce2f | 2021-05-06 13:21:15 +0100 | [diff] [blame] | 85 | entries = append(entries, b.classpathFragmentBase().androidMkEntries()...) |
Artur Satayev | 97259dc | 2021-04-07 15:17:14 +0100 | [diff] [blame] | 86 | return |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 87 | } |
| 88 | |
| 89 | // Make the hidden API files available from the platform-bootclasspath module. |
| 90 | func (b *platformBootclasspathModule) OutputFiles(tag string) (android.Paths, error) { |
| 91 | switch tag { |
| 92 | case "hiddenapi-flags.csv": |
| 93 | return android.Paths{b.hiddenAPIFlagsCSV}, nil |
| 94 | case "hiddenapi-index.csv": |
| 95 | return android.Paths{b.hiddenAPIIndexCSV}, nil |
| 96 | case "hiddenapi-metadata.csv": |
| 97 | return android.Paths{b.hiddenAPIMetadataCSV}, nil |
| 98 | } |
| 99 | |
| 100 | return nil, fmt.Errorf("unknown tag %s", tag) |
| 101 | } |
| 102 | |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 103 | func (b *platformBootclasspathModule) DepsMutator(ctx android.BottomUpMutatorContext) { |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 104 | b.hiddenAPIDepsMutator(ctx) |
| 105 | |
Qiao Yang | 8d8c660 | 2023-05-05 15:03:24 +0000 | [diff] [blame^] | 106 | if SkipDexpreoptBootJars(ctx) { |
| 107 | return |
| 108 | } |
| 109 | |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 110 | // Add a dependency onto the dex2oat tool which is needed for creating the boot image. The |
| 111 | // path is retrieved from the dependency by GetGlobalSoongConfig(ctx). |
| 112 | dexpreopt.RegisterToolDeps(ctx) |
| 113 | } |
| 114 | |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 115 | func (b *platformBootclasspathModule) hiddenAPIDepsMutator(ctx android.BottomUpMutatorContext) { |
| 116 | if ctx.Config().IsEnvTrue("UNSAFE_DISABLE_HIDDENAPI_FLAGS") { |
| 117 | return |
| 118 | } |
| 119 | |
| 120 | // Add dependencies onto the stub lib modules. |
Paul Duffin | 31fad80 | 2021-06-18 18:14:25 +0100 | [diff] [blame] | 121 | apiLevelToStubLibModules := hiddenAPIComputeMonolithicStubLibModules(ctx.Config()) |
| 122 | hiddenAPIAddStubLibDependencies(ctx, apiLevelToStubLibModules) |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 123 | } |
| 124 | |
Paul Duffin | 4994d26 | 2021-04-22 12:08:59 +0100 | [diff] [blame] | 125 | func (b *platformBootclasspathModule) BootclasspathDepsMutator(ctx android.BottomUpMutatorContext) { |
| 126 | // Add dependencies on all the modules configured in the "art" boot image. |
| 127 | artImageConfig := genBootImageConfigs(ctx)[artBootImageName] |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 128 | addDependenciesOntoBootImageModules(ctx, artImageConfig.modules, platformBootclasspathArtBootJarDepTag) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 129 | |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 130 | // Add dependencies on all the non-updatable module configured in the "boot" boot image. That does |
| 131 | // not include modules configured in the "art" boot image. |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 132 | bootImageConfig := defaultBootImageConfig(ctx) |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 133 | addDependenciesOntoBootImageModules(ctx, bootImageConfig.modules, platformBootclasspathBootJarDepTag) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 134 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 135 | // Add dependencies on all the apex jars. |
| 136 | apexJars := dexpreopt.GetGlobalConfig(ctx).ApexBootJars |
| 137 | addDependenciesOntoBootImageModules(ctx, apexJars, platformBootclasspathApexBootJarDepTag) |
Paul Duffin | 62d8c3b | 2021-04-07 20:35:11 +0100 | [diff] [blame] | 138 | |
Paul Duffin | 4994d26 | 2021-04-22 12:08:59 +0100 | [diff] [blame] | 139 | // Add dependencies on all the fragments. |
| 140 | b.properties.BootclasspathFragmentsDepsProperties.addDependenciesOntoFragments(ctx) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 141 | } |
| 142 | |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 143 | func addDependenciesOntoBootImageModules(ctx android.BottomUpMutatorContext, modules android.ConfiguredJarList, tag bootclasspathDependencyTag) { |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 144 | for i := 0; i < modules.Len(); i++ { |
| 145 | apex := modules.Apex(i) |
| 146 | name := modules.Jar(i) |
| 147 | |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 148 | addDependencyOntoApexModulePair(ctx, apex, name, tag) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 149 | } |
| 150 | } |
| 151 | |
Paul Duffin | e3ecce6 | 2021-04-29 10:34:11 +0100 | [diff] [blame] | 152 | // GenerateSingletonBuildActions does nothing and must never do anything. |
| 153 | // |
| 154 | // This module only implements android.SingletonModule so that it can implement |
| 155 | // android.SingletonMakeVarsProvider. |
| 156 | func (b *platformBootclasspathModule) GenerateSingletonBuildActions(android.SingletonContext) { |
| 157 | // Keep empty |
| 158 | } |
| 159 | |
| 160 | func (d *platformBootclasspathModule) MakeVars(ctx android.MakeVarsContext) { |
Paul Duffin | 12d29b7 | 2021-04-29 13:50:01 +0100 | [diff] [blame] | 161 | d.generateHiddenApiMakeVars(ctx) |
Paul Duffin | e3ecce6 | 2021-04-29 10:34:11 +0100 | [diff] [blame] | 162 | } |
| 163 | |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 164 | func (b *platformBootclasspathModule) GenerateAndroidBuildActions(ctx android.ModuleContext) { |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 165 | // Gather all the dependencies from the art, platform, and apex boot jars. |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 166 | artModules := gatherApexModulePairDepsWithTag(ctx, platformBootclasspathArtBootJarDepTag) |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 167 | platformModules := gatherApexModulePairDepsWithTag(ctx, platformBootclasspathBootJarDepTag) |
| 168 | apexModules := gatherApexModulePairDepsWithTag(ctx, platformBootclasspathApexBootJarDepTag) |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 169 | |
| 170 | // Concatenate them all, in order as they would appear on the bootclasspath. |
| 171 | var allModules []android.Module |
| 172 | allModules = append(allModules, artModules...) |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 173 | allModules = append(allModules, platformModules...) |
| 174 | allModules = append(allModules, apexModules...) |
Paul Duffin | 01b463b | 2021-04-26 20:05:39 +0100 | [diff] [blame] | 175 | b.configuredModules = allModules |
| 176 | |
| 177 | // Gather all the fragments dependencies. |
Paul Duffin | 9bacf56 | 2021-04-28 21:16:02 +0100 | [diff] [blame] | 178 | b.fragments = gatherApexModulePairDepsWithTag(ctx, bootclasspathFragmentDepTag) |
Paul Duffin | b432df9 | 2021-03-22 22:09:42 +0000 | [diff] [blame] | 179 | |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 180 | // Check the configuration of the boot modules. |
| 181 | // ART modules are checked by the art-bootclasspath-fragment. |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 182 | b.checkPlatformModules(ctx, platformModules) |
| 183 | b.checkApexModules(ctx, apexModules) |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 184 | |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 185 | b.generateClasspathProtoBuildActions(ctx) |
| 186 | |
Paul Duffin | c8ead41 | 2021-06-07 19:28:15 +0100 | [diff] [blame] | 187 | bootDexJarByModule := b.generateHiddenAPIBuildActions(ctx, b.configuredModules, b.fragments) |
| 188 | buildRuleForBootJarsPackageCheck(ctx, bootDexJarByModule) |
Paul Duffin | 702210b | 2021-04-08 20:12:41 +0100 | [diff] [blame] | 189 | |
Qiao Yang | 8d8c660 | 2023-05-05 15:03:24 +0000 | [diff] [blame^] | 190 | // Nothing to do if skipping the dexpreopt of boot image jars. |
| 191 | if SkipDexpreoptBootJars(ctx) { |
| 192 | return |
| 193 | } |
| 194 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 195 | b.generateBootImageBuildActions(ctx, platformModules, apexModules) |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 196 | } |
| 197 | |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 198 | // Generate classpaths.proto config |
| 199 | func (b *platformBootclasspathModule) generateClasspathProtoBuildActions(ctx android.ModuleContext) { |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 200 | configuredJars := b.configuredJars(ctx) |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 201 | // ART and platform boot jars must have a corresponding entry in DEX2OATBOOTCLASSPATH |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 202 | classpathJars := configuredJarListToClasspathJars(ctx, configuredJars, BOOTCLASSPATH, DEX2OATBOOTCLASSPATH) |
| 203 | b.classpathFragmentBase().generateClasspathProtoBuildActions(ctx, configuredJars, classpathJars) |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 204 | } |
| 205 | |
satayev | 142ed27 | 2021-06-15 16:21:17 +0100 | [diff] [blame] | 206 | func (b *platformBootclasspathModule) configuredJars(ctx android.ModuleContext) android.ConfiguredJarList { |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 207 | // Include all non APEX jars |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 208 | jars := defaultBootImageConfig(ctx).modules |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 209 | |
| 210 | // Include jars from APEXes that don't populate their classpath proto config. |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 211 | remainingJars := dexpreopt.GetGlobalConfig(ctx).ApexBootJars |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 212 | for _, fragment := range b.fragments { |
| 213 | info := ctx.OtherModuleProvider(fragment, ClasspathFragmentProtoContentInfoProvider).(ClasspathFragmentProtoContentInfo) |
| 214 | if info.ClasspathFragmentProtoGenerated { |
| 215 | remainingJars = remainingJars.RemoveList(info.ClasspathFragmentProtoContents) |
| 216 | } |
| 217 | } |
| 218 | for i := 0; i < remainingJars.Len(); i++ { |
| 219 | jars = jars.Append(remainingJars.Apex(i), remainingJars.Jar(i)) |
| 220 | } |
| 221 | |
| 222 | return jars |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 223 | } |
| 224 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 225 | // checkPlatformModules ensures that the non-updatable modules supplied are not part of an |
| 226 | // apex module. |
| 227 | func (b *platformBootclasspathModule) checkPlatformModules(ctx android.ModuleContext, modules []android.Module) { |
| 228 | // TODO(satayev): change this check to only allow core-icu4j, all apex jars should not be here. |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 229 | for _, m := range modules { |
| 230 | apexInfo := ctx.OtherModuleProvider(m, android.ApexInfoProvider).(android.ApexInfo) |
| 231 | fromUpdatableApex := apexInfo.Updatable |
| 232 | if fromUpdatableApex { |
| 233 | // error: this jar is part of an updatable apex |
Jiyong Park | ab50b07 | 2021-05-12 17:13:56 +0900 | [diff] [blame] | 234 | ctx.ModuleErrorf("module %q from updatable apexes %q is not allowed in the framework boot image", ctx.OtherModuleName(m), apexInfo.InApexVariants) |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 235 | } else { |
| 236 | // ok: this jar is part of the platform or a non-updatable apex |
| 237 | } |
| 238 | } |
| 239 | } |
| 240 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 241 | // checkApexModules ensures that the apex modules supplied are not from the platform. |
| 242 | func (b *platformBootclasspathModule) checkApexModules(ctx android.ModuleContext, modules []android.Module) { |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 243 | for _, m := range modules { |
| 244 | apexInfo := ctx.OtherModuleProvider(m, android.ApexInfoProvider).(android.ApexInfo) |
| 245 | fromUpdatableApex := apexInfo.Updatable |
| 246 | if fromUpdatableApex { |
| 247 | // ok: this jar is part of an updatable apex |
| 248 | } else { |
| 249 | name := ctx.OtherModuleName(m) |
| 250 | if apexInfo.IsForPlatform() { |
Paul Duffin | 7487a7a | 2021-05-19 09:36:09 +0100 | [diff] [blame] | 251 | // If AlwaysUsePrebuiltSdks() returns true then it is possible that the updatable list will |
| 252 | // include platform variants of a prebuilt module due to workarounds elsewhere. In that case |
| 253 | // do not treat this as an error. |
| 254 | // TODO(b/179354495): Always treat this as an error when migration to bootclasspath_fragment |
| 255 | // modules is complete. |
| 256 | if !ctx.Config().AlwaysUsePrebuiltSdks() { |
| 257 | // error: this jar is part of the platform |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 258 | ctx.ModuleErrorf("module %q from platform is not allowed in the apex boot jars list", name) |
Paul Duffin | 7487a7a | 2021-05-19 09:36:09 +0100 | [diff] [blame] | 259 | } |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 260 | } else { |
| 261 | // TODO(b/177892522): Treat this as an error. |
| 262 | // Cannot do that at the moment because framework-wifi and framework-tethering are in the |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 263 | // PRODUCT_APEX_BOOT_JARS but not marked as updatable in AOSP. |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 264 | } |
| 265 | } |
| 266 | } |
| 267 | } |
| 268 | |
Paul Duffin | 702210b | 2021-04-08 20:12:41 +0100 | [diff] [blame] | 269 | // generateHiddenAPIBuildActions generates all the hidden API related build rules. |
Paul Duffin | c8ead41 | 2021-06-07 19:28:15 +0100 | [diff] [blame] | 270 | func (b *platformBootclasspathModule) generateHiddenAPIBuildActions(ctx android.ModuleContext, modules []android.Module, fragments []android.Module) bootDexJarByModule { |
Paul Duffin | 702210b | 2021-04-08 20:12:41 +0100 | [diff] [blame] | 271 | |
Paul Duffin | 90b8ad3 | 2021-04-13 12:25:01 +0100 | [diff] [blame] | 272 | // Save the paths to the monolithic files for retrieval via OutputFiles(). |
| 273 | b.hiddenAPIFlagsCSV = hiddenAPISingletonPaths(ctx).flags |
| 274 | b.hiddenAPIIndexCSV = hiddenAPISingletonPaths(ctx).index |
| 275 | b.hiddenAPIMetadataCSV = hiddenAPISingletonPaths(ctx).metadata |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 276 | |
Adrian Roos | e95a15e | 2021-06-21 16:03:11 +0200 | [diff] [blame] | 277 | bootDexJarByModule := extractBootDexJarsFromModules(ctx, modules) |
| 278 | |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 279 | // Don't run any hiddenapi rules if UNSAFE_DISABLE_HIDDENAPI_FLAGS=true. This is a performance |
| 280 | // optimization that can be used to reduce the incremental build time but as its name suggests it |
| 281 | // can be unsafe to use, e.g. when the changes affect anything that goes on the bootclasspath. |
Vishnu Nair | 0dbd02a | 2021-04-30 00:24:07 +0000 | [diff] [blame] | 282 | if ctx.Config().IsEnvTrue("UNSAFE_DISABLE_HIDDENAPI_FLAGS") { |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 283 | paths := android.OutputPaths{b.hiddenAPIFlagsCSV, b.hiddenAPIIndexCSV, b.hiddenAPIMetadataCSV} |
| 284 | for _, path := range paths { |
| 285 | ctx.Build(pctx, android.BuildParams{ |
| 286 | Rule: android.Touch, |
| 287 | Output: path, |
| 288 | }) |
| 289 | } |
Adrian Roos | e95a15e | 2021-06-21 16:03:11 +0200 | [diff] [blame] | 290 | return bootDexJarByModule |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 291 | } |
| 292 | |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 293 | // Construct a list of ClasspathElement objects from the modules and fragments. |
| 294 | classpathElements := CreateClasspathElements(ctx, modules, fragments) |
| 295 | |
| 296 | monolithicInfo := b.createAndProvideMonolithicHiddenAPIInfo(ctx, classpathElements) |
| 297 | |
| 298 | // Extract the classes jars only from those libraries that do not have corresponding fragments as |
| 299 | // the fragments will have already provided the flags that are needed. |
| 300 | classesJars := monolithicInfo.ClassesJars |
| 301 | |
Paul Duffin | 4539a37 | 2021-06-23 23:20:43 +0100 | [diff] [blame] | 302 | // Create the input to pass to buildRuleToGenerateHiddenAPIStubFlagsFile |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 303 | input := newHiddenAPIFlagInput() |
| 304 | |
| 305 | // Gather stub library information from the dependencies on modules provided by |
| 306 | // hiddenAPIComputeMonolithicStubLibModules. |
| 307 | input.gatherStubLibInfo(ctx, nil) |
| 308 | |
| 309 | // Use the flag files from this module and all the fragments. |
| 310 | input.FlagFilesByCategory = monolithicInfo.FlagsFilesByCategory |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 311 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 312 | // Generate the monolithic stub-flags.csv file. |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 313 | stubFlags := hiddenAPISingletonPaths(ctx).stubFlags |
Paul Duffin | 67b9d61 | 2021-07-21 17:38:47 +0100 | [diff] [blame] | 314 | buildRuleToGenerateHiddenAPIStubFlagsFile(ctx, "platform-bootclasspath-monolithic-hiddenapi-stub-flags", "monolithic hidden API stub flags", stubFlags, bootDexJarByModule.bootDexJars(), input, monolithicInfo.StubFlagSubsets) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 315 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 316 | // Generate the annotation-flags.csv file from all the module annotations. |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 317 | annotationFlags := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "annotation-flags-from-classes.csv") |
| 318 | buildRuleToGenerateAnnotationFlags(ctx, "intermediate hidden API flags", classesJars, stubFlags, annotationFlags) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 319 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 320 | // Generate the monolithic hiddenapi-flags.csv file. |
| 321 | // |
| 322 | // Use annotation flags generated directly from the classes jars as well as annotation flag files |
| 323 | // provided by prebuilts. |
| 324 | allAnnotationFlagFiles := android.Paths{annotationFlags} |
| 325 | allAnnotationFlagFiles = append(allAnnotationFlagFiles, monolithicInfo.AnnotationFlagsPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 326 | allFlags := hiddenAPISingletonPaths(ctx).flags |
Paul Duffin | 67b9d61 | 2021-07-21 17:38:47 +0100 | [diff] [blame] | 327 | buildRuleToGenerateHiddenApiFlags(ctx, "hiddenAPIFlagsFile", "monolithic hidden API flags", allFlags, stubFlags, allAnnotationFlagFiles, monolithicInfo.FlagsFilesByCategory, monolithicInfo.FlagSubsets, android.OptionalPath{}) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 328 | |
| 329 | // Generate an intermediate monolithic hiddenapi-metadata.csv file directly from the annotations |
| 330 | // in the source code. |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 331 | intermediateMetadataCSV := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "metadata-from-classes.csv") |
| 332 | buildRuleToGenerateMetadata(ctx, "intermediate hidden API metadata", classesJars, stubFlags, intermediateMetadataCSV) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 333 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 334 | // Generate the monolithic hiddenapi-metadata.csv file. |
| 335 | // |
| 336 | // Use metadata files generated directly from the classes jars as well as metadata files provided |
| 337 | // by prebuilts. |
| 338 | // |
| 339 | // This has the side effect of ensuring that the output file uses | quotes just in case that is |
| 340 | // important for the tools that consume the metadata file. |
| 341 | allMetadataFlagFiles := android.Paths{intermediateMetadataCSV} |
| 342 | allMetadataFlagFiles = append(allMetadataFlagFiles, monolithicInfo.MetadataPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 343 | metadataCSV := hiddenAPISingletonPaths(ctx).metadata |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 344 | b.buildRuleMergeCSV(ctx, "monolithic hidden API metadata", allMetadataFlagFiles, metadataCSV) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 345 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 346 | // Generate an intermediate monolithic hiddenapi-index.csv file directly from the CSV files in the |
| 347 | // classes jars. |
| 348 | intermediateIndexCSV := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "index-from-classes.csv") |
| 349 | buildRuleToGenerateIndex(ctx, "intermediate hidden API index", classesJars, intermediateIndexCSV) |
| 350 | |
| 351 | // Generate the monolithic hiddenapi-index.csv file. |
| 352 | // |
| 353 | // Use index files generated directly from the classes jars as well as index files provided |
| 354 | // by prebuilts. |
| 355 | allIndexFlagFiles := android.Paths{intermediateIndexCSV} |
| 356 | allIndexFlagFiles = append(allIndexFlagFiles, monolithicInfo.IndexPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 357 | indexCSV := hiddenAPISingletonPaths(ctx).index |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 358 | b.buildRuleMergeCSV(ctx, "monolithic hidden API index", allIndexFlagFiles, indexCSV) |
Paul Duffin | c8ead41 | 2021-06-07 19:28:15 +0100 | [diff] [blame] | 359 | |
| 360 | return bootDexJarByModule |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 361 | } |
| 362 | |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 363 | // createAndProvideMonolithicHiddenAPIInfo creates a MonolithicHiddenAPIInfo and provides it for |
| 364 | // testing. |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 365 | func (b *platformBootclasspathModule) createAndProvideMonolithicHiddenAPIInfo(ctx android.ModuleContext, classpathElements ClasspathElements) MonolithicHiddenAPIInfo { |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 366 | // Create a temporary input structure in which to collate information provided directly by this |
| 367 | // module, either through properties or direct dependencies. |
| 368 | temporaryInput := newHiddenAPIFlagInput() |
| 369 | |
| 370 | // Create paths to the flag files specified in the properties. |
Paul Duffin | 9b61abb | 2022-07-27 16:16:54 +0000 | [diff] [blame] | 371 | temporaryInput.extractFlagFilesFromProperties(ctx, &b.properties.HiddenAPIFlagFileProperties) |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 372 | |
| 373 | // Create the monolithic info, by starting with the flag files specified on this and then merging |
| 374 | // in information from all the fragment dependencies of this. |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 375 | monolithicInfo := newMonolithicHiddenAPIInfo(ctx, temporaryInput.FlagFilesByCategory, classpathElements) |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 376 | |
| 377 | // Store the information for testing. |
Paul Duffin | 524c82c | 2021-06-09 14:39:28 +0100 | [diff] [blame] | 378 | ctx.SetProvider(MonolithicHiddenAPIInfoProvider, monolithicInfo) |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 379 | return monolithicInfo |
| 380 | } |
| 381 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 382 | func (b *platformBootclasspathModule) buildRuleMergeCSV(ctx android.ModuleContext, desc string, inputPaths android.Paths, outputPath android.WritablePath) { |
Paul Duffin | 00b2bfd | 2021-04-12 17:24:36 +0100 | [diff] [blame] | 383 | rule := android.NewRuleBuilder(pctx, ctx) |
| 384 | rule.Command(). |
| 385 | BuiltTool("merge_csv"). |
| 386 | Flag("--key_field signature"). |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 387 | FlagWithOutput("--output=", outputPath). |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 388 | Inputs(inputPaths) |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 389 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 390 | rule.Build(desc, desc) |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 391 | } |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 392 | |
Paul Duffin | 12d29b7 | 2021-04-29 13:50:01 +0100 | [diff] [blame] | 393 | // generateHiddenApiMakeVars generates make variables needed by hidden API related make rules, e.g. |
| 394 | // veridex and run-appcompat. |
| 395 | func (b *platformBootclasspathModule) generateHiddenApiMakeVars(ctx android.MakeVarsContext) { |
| 396 | if ctx.Config().IsEnvTrue("UNSAFE_DISABLE_HIDDENAPI_FLAGS") { |
| 397 | return |
| 398 | } |
| 399 | // INTERNAL_PLATFORM_HIDDENAPI_FLAGS is used by Make rules in art/ and cts/. |
| 400 | ctx.Strict("INTERNAL_PLATFORM_HIDDENAPI_FLAGS", b.hiddenAPIFlagsCSV.String()) |
| 401 | } |
| 402 | |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 403 | // generateBootImageBuildActions generates ninja rules related to the boot image creation. |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 404 | func (b *platformBootclasspathModule) generateBootImageBuildActions(ctx android.ModuleContext, platformModules, apexModules []android.Module) { |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 405 | // Force the GlobalSoongConfig to be created and cached for use by the dex_bootjars |
| 406 | // GenerateSingletonBuildActions method as it cannot create it for itself. |
| 407 | dexpreopt.GetGlobalSoongConfig(ctx) |
| 408 | |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 409 | global := dexpreopt.GetGlobalConfig(ctx) |
| 410 | if !shouldBuildBootImages(ctx.Config(), global) { |
| 411 | return |
| 412 | } |
| 413 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 414 | frameworkBootImageConfig := defaultBootImageConfig(ctx) |
| 415 | bootFrameworkProfileRule(ctx, frameworkBootImageConfig) |
| 416 | b.generateBootImage(ctx, frameworkBootImageName, platformModules) |
Jiakai Zhang | b879620 | 2023-03-06 19:16:48 +0000 | [diff] [blame] | 417 | b.generateBootImage(ctx, mainlineBootImageName, apexModules) |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 418 | b.copyApexBootJarsForAppsDexpreopt(ctx, apexModules) |
| 419 | dumpOatRules(ctx, frameworkBootImageConfig) |
| 420 | } |
Paul Duffin | 4c09442 | 2021-04-26 20:10:48 +0100 | [diff] [blame] | 421 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 422 | func (b *platformBootclasspathModule) generateBootImage(ctx android.ModuleContext, imageName string, modules []android.Module) { |
| 423 | imageConfig := genBootImageConfigs(ctx)[imageName] |
Paul Duffin | 7ebebfd | 2021-04-27 19:36:57 +0100 | [diff] [blame] | 424 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 425 | // Copy module dex jars to their predefined locations. |
| 426 | bootDexJarsByModule := extractEncodedDexJarsFromModules(ctx, modules) |
| 427 | copyBootJarsToPredefinedLocations(ctx, bootDexJarsByModule, imageConfig.dexPathsByModule) |
Paul Duffin | 7ebebfd | 2021-04-27 19:36:57 +0100 | [diff] [blame] | 428 | |
Paul Duffin | 2fc82ad | 2021-04-29 23:36:12 +0100 | [diff] [blame] | 429 | // Build a profile for the image config and then use that to build the boot image. |
| 430 | profile := bootImageProfileRule(ctx, imageConfig) |
Paul Duffin | 56afb27 | 2021-07-01 22:04:22 +0100 | [diff] [blame] | 431 | |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 432 | // Build boot image files for the android variants. |
Paul Duffin | 9f6ac0b | 2022-10-04 15:36:44 +0100 | [diff] [blame] | 433 | androidBootImageFiles := buildBootImageVariantsForAndroidOs(ctx, imageConfig, profile) |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 434 | |
| 435 | // Zip the android variant boot image files up. |
Paul Duffin | 9f6ac0b | 2022-10-04 15:36:44 +0100 | [diff] [blame] | 436 | buildBootImageZipInPredefinedLocation(ctx, imageConfig, androidBootImageFiles.byArch) |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 437 | |
| 438 | // Build boot image files for the host variants. There are use directly by ART host side tests. |
| 439 | buildBootImageVariantsForBuildOs(ctx, imageConfig, profile) |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 440 | } |
Paul Duffin | 2fc82ad | 2021-04-29 23:36:12 +0100 | [diff] [blame] | 441 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 442 | // Copy apex module dex jars to their predefined locations. They will be used for dexpreopt for apps. |
| 443 | func (b *platformBootclasspathModule) copyApexBootJarsForAppsDexpreopt(ctx android.ModuleContext, apexModules []android.Module) { |
| 444 | config := GetApexBootConfig(ctx) |
| 445 | apexBootDexJarsByModule := extractEncodedDexJarsFromModules(ctx, apexModules) |
| 446 | copyBootJarsToPredefinedLocations(ctx, apexBootDexJarsByModule, config.dexPathsByModule) |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 447 | } |