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 | |
Jiakai Zhang | bc698cd | 2023-05-08 16:28:38 +0000 | [diff] [blame^] | 106 | if !dexpreopt.IsDex2oatNeeded(ctx) { |
Qiao Yang | 8d8c660 | 2023-05-05 15:03:24 +0000 | [diff] [blame] | 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 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 190 | b.generateBootImageBuildActions(ctx, platformModules, apexModules) |
Paul Duffin | bb7f1ac | 2021-03-29 22:18:45 +0100 | [diff] [blame] | 191 | } |
| 192 | |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 193 | // Generate classpaths.proto config |
| 194 | func (b *platformBootclasspathModule) generateClasspathProtoBuildActions(ctx android.ModuleContext) { |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 195 | configuredJars := b.configuredJars(ctx) |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 196 | // ART and platform boot jars must have a corresponding entry in DEX2OATBOOTCLASSPATH |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 197 | classpathJars := configuredJarListToClasspathJars(ctx, configuredJars, BOOTCLASSPATH, DEX2OATBOOTCLASSPATH) |
| 198 | b.classpathFragmentBase().generateClasspathProtoBuildActions(ctx, configuredJars, classpathJars) |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 199 | } |
| 200 | |
satayev | 142ed27 | 2021-06-15 16:21:17 +0100 | [diff] [blame] | 201 | func (b *platformBootclasspathModule) configuredJars(ctx android.ModuleContext) android.ConfiguredJarList { |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 202 | // Include all non APEX jars |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 203 | jars := defaultBootImageConfig(ctx).modules |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 204 | |
| 205 | // Include jars from APEXes that don't populate their classpath proto config. |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 206 | remainingJars := dexpreopt.GetGlobalConfig(ctx).ApexBootJars |
satayev | b309050 | 2021-06-15 17:49:10 +0100 | [diff] [blame] | 207 | for _, fragment := range b.fragments { |
| 208 | info := ctx.OtherModuleProvider(fragment, ClasspathFragmentProtoContentInfoProvider).(ClasspathFragmentProtoContentInfo) |
| 209 | if info.ClasspathFragmentProtoGenerated { |
| 210 | remainingJars = remainingJars.RemoveList(info.ClasspathFragmentProtoContents) |
| 211 | } |
| 212 | } |
| 213 | for i := 0; i < remainingJars.Len(); i++ { |
| 214 | jars = jars.Append(remainingJars.Apex(i), remainingJars.Jar(i)) |
| 215 | } |
| 216 | |
| 217 | return jars |
satayev | 013485b | 2021-05-06 23:38:10 +0100 | [diff] [blame] | 218 | } |
| 219 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 220 | // checkPlatformModules ensures that the non-updatable modules supplied are not part of an |
| 221 | // apex module. |
| 222 | func (b *platformBootclasspathModule) checkPlatformModules(ctx android.ModuleContext, modules []android.Module) { |
| 223 | // 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] | 224 | for _, m := range modules { |
| 225 | apexInfo := ctx.OtherModuleProvider(m, android.ApexInfoProvider).(android.ApexInfo) |
| 226 | fromUpdatableApex := apexInfo.Updatable |
| 227 | if fromUpdatableApex { |
| 228 | // error: this jar is part of an updatable apex |
Jiyong Park | ab50b07 | 2021-05-12 17:13:56 +0900 | [diff] [blame] | 229 | 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] | 230 | } else { |
| 231 | // ok: this jar is part of the platform or a non-updatable apex |
| 232 | } |
| 233 | } |
| 234 | } |
| 235 | |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 236 | // checkApexModules ensures that the apex modules supplied are not from the platform. |
| 237 | func (b *platformBootclasspathModule) checkApexModules(ctx android.ModuleContext, modules []android.Module) { |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 238 | for _, m := range modules { |
| 239 | apexInfo := ctx.OtherModuleProvider(m, android.ApexInfoProvider).(android.ApexInfo) |
| 240 | fromUpdatableApex := apexInfo.Updatable |
| 241 | if fromUpdatableApex { |
| 242 | // ok: this jar is part of an updatable apex |
| 243 | } else { |
| 244 | name := ctx.OtherModuleName(m) |
| 245 | if apexInfo.IsForPlatform() { |
Paul Duffin | 7487a7a | 2021-05-19 09:36:09 +0100 | [diff] [blame] | 246 | // If AlwaysUsePrebuiltSdks() returns true then it is possible that the updatable list will |
| 247 | // include platform variants of a prebuilt module due to workarounds elsewhere. In that case |
| 248 | // do not treat this as an error. |
| 249 | // TODO(b/179354495): Always treat this as an error when migration to bootclasspath_fragment |
| 250 | // modules is complete. |
| 251 | if !ctx.Config().AlwaysUsePrebuiltSdks() { |
| 252 | // error: this jar is part of the platform |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 253 | 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] | 254 | } |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 255 | } else { |
| 256 | // TODO(b/177892522): Treat this as an error. |
| 257 | // 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] | 258 | // PRODUCT_APEX_BOOT_JARS but not marked as updatable in AOSP. |
Paul Duffin | f23bc47 | 2021-04-27 12:42:20 +0100 | [diff] [blame] | 259 | } |
| 260 | } |
| 261 | } |
| 262 | } |
| 263 | |
Paul Duffin | 702210b | 2021-04-08 20:12:41 +0100 | [diff] [blame] | 264 | // generateHiddenAPIBuildActions generates all the hidden API related build rules. |
Paul Duffin | c8ead41 | 2021-06-07 19:28:15 +0100 | [diff] [blame] | 265 | 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] | 266 | |
Paul Duffin | 90b8ad3 | 2021-04-13 12:25:01 +0100 | [diff] [blame] | 267 | // Save the paths to the monolithic files for retrieval via OutputFiles(). |
| 268 | b.hiddenAPIFlagsCSV = hiddenAPISingletonPaths(ctx).flags |
| 269 | b.hiddenAPIIndexCSV = hiddenAPISingletonPaths(ctx).index |
| 270 | b.hiddenAPIMetadataCSV = hiddenAPISingletonPaths(ctx).metadata |
Paul Duffin | 6a76645 | 2021-04-12 14:15:22 +0100 | [diff] [blame] | 271 | |
Adrian Roos | e95a15e | 2021-06-21 16:03:11 +0200 | [diff] [blame] | 272 | bootDexJarByModule := extractBootDexJarsFromModules(ctx, modules) |
| 273 | |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 274 | // Don't run any hiddenapi rules if UNSAFE_DISABLE_HIDDENAPI_FLAGS=true. This is a performance |
| 275 | // optimization that can be used to reduce the incremental build time but as its name suggests it |
| 276 | // 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] | 277 | if ctx.Config().IsEnvTrue("UNSAFE_DISABLE_HIDDENAPI_FLAGS") { |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 278 | paths := android.OutputPaths{b.hiddenAPIFlagsCSV, b.hiddenAPIIndexCSV, b.hiddenAPIMetadataCSV} |
| 279 | for _, path := range paths { |
| 280 | ctx.Build(pctx, android.BuildParams{ |
| 281 | Rule: android.Touch, |
| 282 | Output: path, |
| 283 | }) |
| 284 | } |
Adrian Roos | e95a15e | 2021-06-21 16:03:11 +0200 | [diff] [blame] | 285 | return bootDexJarByModule |
Paul Duffin | 0b65986 | 2021-04-13 13:02:29 +0100 | [diff] [blame] | 286 | } |
| 287 | |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 288 | // Construct a list of ClasspathElement objects from the modules and fragments. |
| 289 | classpathElements := CreateClasspathElements(ctx, modules, fragments) |
| 290 | |
| 291 | monolithicInfo := b.createAndProvideMonolithicHiddenAPIInfo(ctx, classpathElements) |
| 292 | |
| 293 | // Extract the classes jars only from those libraries that do not have corresponding fragments as |
| 294 | // the fragments will have already provided the flags that are needed. |
| 295 | classesJars := monolithicInfo.ClassesJars |
| 296 | |
Paul Duffin | 4539a37 | 2021-06-23 23:20:43 +0100 | [diff] [blame] | 297 | // Create the input to pass to buildRuleToGenerateHiddenAPIStubFlagsFile |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 298 | input := newHiddenAPIFlagInput() |
| 299 | |
| 300 | // Gather stub library information from the dependencies on modules provided by |
| 301 | // hiddenAPIComputeMonolithicStubLibModules. |
| 302 | input.gatherStubLibInfo(ctx, nil) |
| 303 | |
| 304 | // Use the flag files from this module and all the fragments. |
| 305 | input.FlagFilesByCategory = monolithicInfo.FlagsFilesByCategory |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 306 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 307 | // Generate the monolithic stub-flags.csv file. |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 308 | stubFlags := hiddenAPISingletonPaths(ctx).stubFlags |
Paul Duffin | 67b9d61 | 2021-07-21 17:38:47 +0100 | [diff] [blame] | 309 | 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] | 310 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 311 | // Generate the annotation-flags.csv file from all the module annotations. |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 312 | annotationFlags := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "annotation-flags-from-classes.csv") |
| 313 | buildRuleToGenerateAnnotationFlags(ctx, "intermediate hidden API flags", classesJars, stubFlags, annotationFlags) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 314 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 315 | // Generate the monolithic hiddenapi-flags.csv file. |
| 316 | // |
| 317 | // Use annotation flags generated directly from the classes jars as well as annotation flag files |
| 318 | // provided by prebuilts. |
| 319 | allAnnotationFlagFiles := android.Paths{annotationFlags} |
| 320 | allAnnotationFlagFiles = append(allAnnotationFlagFiles, monolithicInfo.AnnotationFlagsPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 321 | allFlags := hiddenAPISingletonPaths(ctx).flags |
Paul Duffin | 67b9d61 | 2021-07-21 17:38:47 +0100 | [diff] [blame] | 322 | 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] | 323 | |
| 324 | // Generate an intermediate monolithic hiddenapi-metadata.csv file directly from the annotations |
| 325 | // in the source code. |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 326 | intermediateMetadataCSV := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "metadata-from-classes.csv") |
| 327 | buildRuleToGenerateMetadata(ctx, "intermediate hidden API metadata", classesJars, stubFlags, intermediateMetadataCSV) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 328 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 329 | // Generate the monolithic hiddenapi-metadata.csv file. |
| 330 | // |
| 331 | // Use metadata files generated directly from the classes jars as well as metadata files provided |
| 332 | // by prebuilts. |
| 333 | // |
| 334 | // This has the side effect of ensuring that the output file uses | quotes just in case that is |
| 335 | // important for the tools that consume the metadata file. |
| 336 | allMetadataFlagFiles := android.Paths{intermediateMetadataCSV} |
| 337 | allMetadataFlagFiles = append(allMetadataFlagFiles, monolithicInfo.MetadataPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 338 | metadataCSV := hiddenAPISingletonPaths(ctx).metadata |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 339 | b.buildRuleMergeCSV(ctx, "monolithic hidden API metadata", allMetadataFlagFiles, metadataCSV) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 340 | |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 341 | // Generate an intermediate monolithic hiddenapi-index.csv file directly from the CSV files in the |
| 342 | // classes jars. |
| 343 | intermediateIndexCSV := android.PathForModuleOut(ctx, "hiddenapi-monolithic", "index-from-classes.csv") |
| 344 | buildRuleToGenerateIndex(ctx, "intermediate hidden API index", classesJars, intermediateIndexCSV) |
| 345 | |
| 346 | // Generate the monolithic hiddenapi-index.csv file. |
| 347 | // |
| 348 | // Use index files generated directly from the classes jars as well as index files provided |
| 349 | // by prebuilts. |
| 350 | allIndexFlagFiles := android.Paths{intermediateIndexCSV} |
| 351 | allIndexFlagFiles = append(allIndexFlagFiles, monolithicInfo.IndexPaths...) |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 352 | indexCSV := hiddenAPISingletonPaths(ctx).index |
Paul Duffin | d061d40 | 2021-06-07 21:36:01 +0100 | [diff] [blame] | 353 | b.buildRuleMergeCSV(ctx, "monolithic hidden API index", allIndexFlagFiles, indexCSV) |
Paul Duffin | c8ead41 | 2021-06-07 19:28:15 +0100 | [diff] [blame] | 354 | |
| 355 | return bootDexJarByModule |
Paul Duffin | 74431d5 | 2021-04-21 14:10:42 +0100 | [diff] [blame] | 356 | } |
| 357 | |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 358 | // createAndProvideMonolithicHiddenAPIInfo creates a MonolithicHiddenAPIInfo and provides it for |
| 359 | // testing. |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 360 | func (b *platformBootclasspathModule) createAndProvideMonolithicHiddenAPIInfo(ctx android.ModuleContext, classpathElements ClasspathElements) MonolithicHiddenAPIInfo { |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 361 | // Create a temporary input structure in which to collate information provided directly by this |
| 362 | // module, either through properties or direct dependencies. |
| 363 | temporaryInput := newHiddenAPIFlagInput() |
| 364 | |
| 365 | // Create paths to the flag files specified in the properties. |
Paul Duffin | 9b61abb | 2022-07-27 16:16:54 +0000 | [diff] [blame] | 366 | temporaryInput.extractFlagFilesFromProperties(ctx, &b.properties.HiddenAPIFlagFileProperties) |
Paul Duffin | 1352f7c | 2021-05-21 22:18:49 +0100 | [diff] [blame] | 367 | |
| 368 | // Create the monolithic info, by starting with the flag files specified on this and then merging |
| 369 | // in information from all the fragment dependencies of this. |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 370 | monolithicInfo := newMonolithicHiddenAPIInfo(ctx, temporaryInput.FlagFilesByCategory, classpathElements) |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 371 | |
| 372 | // Store the information for testing. |
Paul Duffin | 524c82c | 2021-06-09 14:39:28 +0100 | [diff] [blame] | 373 | ctx.SetProvider(MonolithicHiddenAPIInfoProvider, monolithicInfo) |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 374 | return monolithicInfo |
| 375 | } |
| 376 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 377 | 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] | 378 | rule := android.NewRuleBuilder(pctx, ctx) |
| 379 | rule.Command(). |
| 380 | BuiltTool("merge_csv"). |
| 381 | Flag("--key_field signature"). |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 382 | FlagWithOutput("--output=", outputPath). |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 383 | Inputs(inputPaths) |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 384 | |
Paul Duffin | 537ea3d | 2021-05-14 10:38:00 +0100 | [diff] [blame] | 385 | rule.Build(desc, desc) |
Paul Duffin | 85dee5d | 2021-04-13 00:14:38 +0100 | [diff] [blame] | 386 | } |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 387 | |
Paul Duffin | 12d29b7 | 2021-04-29 13:50:01 +0100 | [diff] [blame] | 388 | // generateHiddenApiMakeVars generates make variables needed by hidden API related make rules, e.g. |
| 389 | // veridex and run-appcompat. |
| 390 | func (b *platformBootclasspathModule) generateHiddenApiMakeVars(ctx android.MakeVarsContext) { |
| 391 | if ctx.Config().IsEnvTrue("UNSAFE_DISABLE_HIDDENAPI_FLAGS") { |
| 392 | return |
| 393 | } |
| 394 | // INTERNAL_PLATFORM_HIDDENAPI_FLAGS is used by Make rules in art/ and cts/. |
| 395 | ctx.Strict("INTERNAL_PLATFORM_HIDDENAPI_FLAGS", b.hiddenAPIFlagsCSV.String()) |
| 396 | } |
| 397 | |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 398 | // generateBootImageBuildActions generates ninja rules related to the boot image creation. |
satayev | d604b21 | 2021-07-21 14:23:52 +0100 | [diff] [blame] | 399 | func (b *platformBootclasspathModule) generateBootImageBuildActions(ctx android.ModuleContext, platformModules, apexModules []android.Module) { |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 400 | // Force the GlobalSoongConfig to be created and cached for use by the dex_bootjars |
| 401 | // GenerateSingletonBuildActions method as it cannot create it for itself. |
| 402 | dexpreopt.GetGlobalSoongConfig(ctx) |
| 403 | |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 404 | global := dexpreopt.GetGlobalConfig(ctx) |
| 405 | if !shouldBuildBootImages(ctx.Config(), global) { |
| 406 | return |
| 407 | } |
| 408 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 409 | frameworkBootImageConfig := defaultBootImageConfig(ctx) |
| 410 | bootFrameworkProfileRule(ctx, frameworkBootImageConfig) |
| 411 | b.generateBootImage(ctx, frameworkBootImageName, platformModules) |
Jiakai Zhang | b879620 | 2023-03-06 19:16:48 +0000 | [diff] [blame] | 412 | b.generateBootImage(ctx, mainlineBootImageName, apexModules) |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 413 | b.copyApexBootJarsForAppsDexpreopt(ctx, apexModules) |
| 414 | dumpOatRules(ctx, frameworkBootImageConfig) |
| 415 | } |
Paul Duffin | 4c09442 | 2021-04-26 20:10:48 +0100 | [diff] [blame] | 416 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 417 | func (b *platformBootclasspathModule) generateBootImage(ctx android.ModuleContext, imageName string, modules []android.Module) { |
| 418 | imageConfig := genBootImageConfigs(ctx)[imageName] |
Paul Duffin | 7ebebfd | 2021-04-27 19:36:57 +0100 | [diff] [blame] | 419 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 420 | // Copy module dex jars to their predefined locations. |
| 421 | bootDexJarsByModule := extractEncodedDexJarsFromModules(ctx, modules) |
| 422 | copyBootJarsToPredefinedLocations(ctx, bootDexJarsByModule, imageConfig.dexPathsByModule) |
Paul Duffin | 7ebebfd | 2021-04-27 19:36:57 +0100 | [diff] [blame] | 423 | |
Paul Duffin | 2fc82ad | 2021-04-29 23:36:12 +0100 | [diff] [blame] | 424 | // Build a profile for the image config and then use that to build the boot image. |
| 425 | profile := bootImageProfileRule(ctx, imageConfig) |
Paul Duffin | 56afb27 | 2021-07-01 22:04:22 +0100 | [diff] [blame] | 426 | |
Jiakai Zhang | bc698cd | 2023-05-08 16:28:38 +0000 | [diff] [blame^] | 427 | // If dexpreopt of boot image jars should be skipped, generate only a profile. |
| 428 | global := dexpreopt.GetGlobalConfig(ctx) |
| 429 | if global.DisablePreoptBootImages { |
| 430 | return |
| 431 | } |
| 432 | |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 433 | // Build boot image files for the android variants. |
Paul Duffin | 9f6ac0b | 2022-10-04 15:36:44 +0100 | [diff] [blame] | 434 | androidBootImageFiles := buildBootImageVariantsForAndroidOs(ctx, imageConfig, profile) |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 435 | |
| 436 | // Zip the android variant boot image files up. |
Paul Duffin | 9f6ac0b | 2022-10-04 15:36:44 +0100 | [diff] [blame] | 437 | buildBootImageZipInPredefinedLocation(ctx, imageConfig, androidBootImageFiles.byArch) |
Paul Duffin | a56be7d | 2021-07-02 13:00:43 +0100 | [diff] [blame] | 438 | |
| 439 | // Build boot image files for the host variants. There are use directly by ART host side tests. |
| 440 | buildBootImageVariantsForBuildOs(ctx, imageConfig, profile) |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 441 | } |
Paul Duffin | 2fc82ad | 2021-04-29 23:36:12 +0100 | [diff] [blame] | 442 | |
Jiakai Zhang | d49324d | 2023-02-24 17:05:02 +0000 | [diff] [blame] | 443 | // Copy apex module dex jars to their predefined locations. They will be used for dexpreopt for apps. |
| 444 | func (b *platformBootclasspathModule) copyApexBootJarsForAppsDexpreopt(ctx android.ModuleContext, apexModules []android.Module) { |
| 445 | config := GetApexBootConfig(ctx) |
| 446 | apexBootDexJarsByModule := extractEncodedDexJarsFromModules(ctx, apexModules) |
| 447 | copyBootJarsToPredefinedLocations(ctx, apexBootDexJarsByModule, config.dexPathsByModule) |
Paul Duffin | ad19d38 | 2021-04-26 16:44:00 +0100 | [diff] [blame] | 448 | } |