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