blob: ad19e47f313f6add883367c93a57b4abac6272c0 [file] [log] [blame]
Dan Willemsenb916b802017-03-19 13:44:32 -07001// Copyright 2017 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
15package cc
16
17import (
Dan Willemsenb916b802017-03-19 13:44:32 -070018 "strings"
19
Dan Willemsenb916b802017-03-19 13:44:32 -070020 "android/soong/android"
21)
22
23var (
24 llndkLibrarySuffix = ".llndk"
Jiyong Park2a454122017-10-19 15:59:33 +090025 llndkHeadersSuffix = ".llndk"
Dan Willemsenb916b802017-03-19 13:44:32 -070026)
27
Colin Cross127bb8b2020-12-16 16:46:01 -080028// Holds properties to describe a stub shared library based on the provided version file.
29// The stub library will actually be built by the cc_library module that points to this
30// module with the llndk_stubs property.
31// TODO(ccross): move the properties from llndk_library modules directly into the cc_library
32// modules and remove the llndk_library modules.
Dan Willemsenb916b802017-03-19 13:44:32 -070033//
Dan Willemsenb916b802017-03-19 13:44:32 -070034// Example:
35//
36// llndk_library {
Dan Willemsen01a90592017-04-07 15:21:13 -070037// name: "libfoo",
Dan Willemsenb916b802017-03-19 13:44:32 -070038// symbol_file: "libfoo.map.txt",
39// export_include_dirs: ["include_vndk"],
40// }
41//
42type llndkLibraryProperties struct {
43 // Relative path to the symbol map.
44 // An example file can be seen here: TODO(danalbert): Make an example.
Nan Zhang0007d812017-11-07 10:57:05 -080045 Symbol_file *string
Dan Willemsenb916b802017-03-19 13:44:32 -070046
47 // Whether to export any headers as -isystem instead of -I. Mainly for use by
48 // bionic/libc.
Nan Zhang0007d812017-11-07 10:57:05 -080049 Export_headers_as_system *bool
Dan Willemsenb916b802017-03-19 13:44:32 -070050
51 // Which headers to process with versioner. This really only handles
52 // bionic/libc/include right now.
53 Export_preprocessed_headers []string
54
55 // Whether the system library uses symbol versions.
Nan Zhang0007d812017-11-07 10:57:05 -080056 Unversioned *bool
Jiyong Park82e2bf32017-08-16 14:05:54 +090057
Jiyong Park2a454122017-10-19 15:59:33 +090058 // list of llndk headers to re-export include directories from.
Colin Cross0fb7fcd2021-03-02 11:00:07 -080059 Export_llndk_headers []string
60
61 // list of directories relative to the Blueprints file that willbe added to the include path
62 // (using -I) for any module that links against the LLNDK variant of this module, replacing
63 // any that were listed outside the llndk clause.
64 Override_export_include_dirs []string
Colin Cross127bb8b2020-12-16 16:46:01 -080065
66 // whether this module can be directly depended upon by libs that are installed
67 // to /vendor and /product.
68 // When set to true, this module can only be depended on by VNDK libraries, not
69 // vendor nor product libraries. This effectively hides this module from
70 // non-system modules. Default value is false.
71 Private *bool
Colin Cross1f3f1302021-04-26 18:37:44 -070072
73 // if true, make this module available to provide headers to other modules that set
74 // llndk.symbol_file.
75 Llndk_headers *bool
Dan Willemsenb916b802017-03-19 13:44:32 -070076}
77
78type llndkStubDecorator struct {
79 *libraryDecorator
80
81 Properties llndkLibraryProperties
Dan Willemsenb916b802017-03-19 13:44:32 -070082}
83
Colin Cross0477b422020-10-13 18:43:54 -070084var _ versionedInterface = (*llndkStubDecorator)(nil)
85
Colin Crossf18e1102017-11-16 14:33:08 -080086func (stub *llndkStubDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Colin Cross127bb8b2020-12-16 16:46:01 -080087 return flags
George Burgess IVf5310e32017-07-19 11:39:53 -070088}
89
Dan Willemsenb916b802017-03-19 13:44:32 -070090func (stub *llndkStubDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -080091 return Objects{}
Dan Willemsenb916b802017-03-19 13:44:32 -070092}
93
94func (stub *llndkStubDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Jiyong Park2a454122017-10-19 15:59:33 +090095 return deps
Dan Willemsenb916b802017-03-19 13:44:32 -070096}
97
Dan Willemsen01a90592017-04-07 15:21:13 -070098func (stub *llndkStubDecorator) Name(name string) string {
Colin Cross0477b422020-10-13 18:43:54 -070099 if strings.HasSuffix(name, llndkLibrarySuffix) {
100 return name
101 }
Dan Willemsen01a90592017-04-07 15:21:13 -0700102 return name + llndkLibrarySuffix
103}
104
Colin Cross4f4f8eb2021-01-06 14:07:27 -0800105func (stub *llndkStubDecorator) linkerProps() []interface{} {
106 props := stub.libraryDecorator.linkerProps()
107 return append(props, &stub.Properties)
108}
109
Dan Willemsenb916b802017-03-19 13:44:32 -0700110func (stub *llndkStubDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross0477b422020-10-13 18:43:54 -0700111 stub.libraryDecorator.libName = stub.implementationModuleName(ctx.ModuleName())
Dan Willemsenb916b802017-03-19 13:44:32 -0700112 return stub.libraryDecorator.linkerFlags(ctx, flags)
113}
114
Dan Willemsenb916b802017-03-19 13:44:32 -0700115func (stub *llndkStubDecorator) link(ctx ModuleContext, flags Flags, deps PathDeps,
116 objs Objects) android.Path {
Colin Cross127bb8b2020-12-16 16:46:01 -0800117 return nil
Dan Willemsenb916b802017-03-19 13:44:32 -0700118}
119
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -0700120func (stub *llndkStubDecorator) nativeCoverage() bool {
121 return false
122}
123
Colin Cross0477b422020-10-13 18:43:54 -0700124func (stub *llndkStubDecorator) implementationModuleName(name string) string {
125 return strings.TrimSuffix(name, llndkLibrarySuffix)
126}
127
Colin Crossc88c2722020-09-28 17:32:47 -0700128func (stub *llndkStubDecorator) buildStubs() bool {
129 return true
130}
131
Jiyong Park64ca4b72017-11-14 20:53:00 +0900132func NewLLndkStubLibrary() *Module {
Dan Willemsenb916b802017-03-19 13:44:32 -0700133 module, library := NewLibrary(android.DeviceSupported)
Dan Willemsenb916b802017-03-19 13:44:32 -0700134 module.stl = nil
135 module.sanitize = nil
ThiƩbaud Weksteend4587452020-08-19 14:53:01 +0200136 library.disableStripping()
Dan Willemsenb916b802017-03-19 13:44:32 -0700137
138 stub := &llndkStubDecorator{
139 libraryDecorator: library,
140 }
141 module.compiler = stub
142 module.linker = stub
143 module.installer = nil
Colin Cross31076b32020-10-23 17:22:06 -0700144 module.library = stub
Dan Willemsenb916b802017-03-19 13:44:32 -0700145
Colin Cross36242852017-06-23 15:06:31 -0700146 return module
Dan Willemsenb916b802017-03-19 13:44:32 -0700147}
148
Patrice Arrudaea3fcdf2019-04-03 14:37:46 -0700149// llndk_library creates a stub llndk shared library based on the provided
150// version file. Example:
151//
152// llndk_library {
153// name: "libfoo",
154// symbol_file: "libfoo.map.txt",
155// export_include_dirs: ["include_vndk"],
156// }
Jiyong Parkda6eb592018-12-19 17:12:36 +0900157func LlndkLibraryFactory() android.Module {
Jiyong Park64ca4b72017-11-14 20:53:00 +0900158 module := NewLLndkStubLibrary()
Colin Cross4f4f8eb2021-01-06 14:07:27 -0800159 return module.Init()
160}
161
162// isVestigialLLNDKModule returns true if m is a vestigial llndk_library module used to provide
163// properties to the LLNDK variant of a cc_library.
164func isVestigialLLNDKModule(m *Module) bool {
165 _, ok := m.linker.(*llndkStubDecorator)
166 return ok
Dan Willemsenb916b802017-03-19 13:44:32 -0700167}
168
Jiyong Park2a454122017-10-19 15:59:33 +0900169type llndkHeadersDecorator struct {
170 *libraryDecorator
171}
172
Colin Crossb5f6fa62021-01-06 17:05:04 -0800173func (llndk *llndkHeadersDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
174 deps.HeaderLibs = append(deps.HeaderLibs, llndk.Properties.Llndk.Export_llndk_headers...)
175 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
176 llndk.Properties.Llndk.Export_llndk_headers...)
177 return deps
178}
179
Patrice Arrudaea3fcdf2019-04-03 14:37:46 -0700180// llndk_headers contains a set of c/c++ llndk headers files which are imported
181// by other soongs cc modules.
Jiyong Park2a454122017-10-19 15:59:33 +0900182func llndkHeadersFactory() android.Module {
183 module, library := NewLibrary(android.DeviceSupported)
184 library.HeaderOnly()
Inseob Kimc7c69102020-07-08 07:56:02 +0900185 module.stl = nil
186 module.sanitize = nil
Jiyong Park2a454122017-10-19 15:59:33 +0900187
188 decorator := &llndkHeadersDecorator{
189 libraryDecorator: library,
190 }
191
192 module.compiler = nil
193 module.linker = decorator
194 module.installer = nil
Colin Cross31076b32020-10-23 17:22:06 -0700195 module.library = decorator
Jiyong Park2a454122017-10-19 15:59:33 +0900196
Jiyong Park1d1119f2019-07-29 21:27:18 +0900197 module.Init()
Jiyong Park2a454122017-10-19 15:59:33 +0900198
199 return module
200}
201
Dan Willemsenb916b802017-03-19 13:44:32 -0700202func init() {
Jiyong Parkda6eb592018-12-19 17:12:36 +0900203 android.RegisterModuleType("llndk_library", LlndkLibraryFactory)
Jiyong Park2a454122017-10-19 15:59:33 +0900204 android.RegisterModuleType("llndk_headers", llndkHeadersFactory)
Dan Willemsenb916b802017-03-19 13:44:32 -0700205}