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