blob: d05dbce4ce1df3c27cd81323c18d9618aa3d46ea [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
Dan Willemsenb916b802017-03-19 13:44:32 -070072}
73
74type llndkStubDecorator struct {
75 *libraryDecorator
76
77 Properties llndkLibraryProperties
Dan Willemsenb916b802017-03-19 13:44:32 -070078}
79
Colin Cross0477b422020-10-13 18:43:54 -070080var _ versionedInterface = (*llndkStubDecorator)(nil)
81
Colin Crossf18e1102017-11-16 14:33:08 -080082func (stub *llndkStubDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Colin Cross127bb8b2020-12-16 16:46:01 -080083 return flags
George Burgess IVf5310e32017-07-19 11:39:53 -070084}
85
Dan Willemsenb916b802017-03-19 13:44:32 -070086func (stub *llndkStubDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -080087 return Objects{}
Dan Willemsenb916b802017-03-19 13:44:32 -070088}
89
90func (stub *llndkStubDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Jiyong Park2a454122017-10-19 15:59:33 +090091 return deps
Dan Willemsenb916b802017-03-19 13:44:32 -070092}
93
Dan Willemsen01a90592017-04-07 15:21:13 -070094func (stub *llndkStubDecorator) Name(name string) string {
Colin Cross0477b422020-10-13 18:43:54 -070095 if strings.HasSuffix(name, llndkLibrarySuffix) {
96 return name
97 }
Dan Willemsen01a90592017-04-07 15:21:13 -070098 return name + llndkLibrarySuffix
99}
100
Colin Cross4f4f8eb2021-01-06 14:07:27 -0800101func (stub *llndkStubDecorator) linkerProps() []interface{} {
102 props := stub.libraryDecorator.linkerProps()
103 return append(props, &stub.Properties)
104}
105
Dan Willemsenb916b802017-03-19 13:44:32 -0700106func (stub *llndkStubDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross0477b422020-10-13 18:43:54 -0700107 stub.libraryDecorator.libName = stub.implementationModuleName(ctx.ModuleName())
Dan Willemsenb916b802017-03-19 13:44:32 -0700108 return stub.libraryDecorator.linkerFlags(ctx, flags)
109}
110
Dan Willemsenb916b802017-03-19 13:44:32 -0700111func (stub *llndkStubDecorator) link(ctx ModuleContext, flags Flags, deps PathDeps,
112 objs Objects) android.Path {
Colin Cross127bb8b2020-12-16 16:46:01 -0800113 return nil
Dan Willemsenb916b802017-03-19 13:44:32 -0700114}
115
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -0700116func (stub *llndkStubDecorator) nativeCoverage() bool {
117 return false
118}
119
Colin Cross0477b422020-10-13 18:43:54 -0700120func (stub *llndkStubDecorator) implementationModuleName(name string) string {
121 return strings.TrimSuffix(name, llndkLibrarySuffix)
122}
123
Colin Crossc88c2722020-09-28 17:32:47 -0700124func (stub *llndkStubDecorator) buildStubs() bool {
125 return true
126}
127
Jiyong Park64ca4b72017-11-14 20:53:00 +0900128func NewLLndkStubLibrary() *Module {
Dan Willemsenb916b802017-03-19 13:44:32 -0700129 module, library := NewLibrary(android.DeviceSupported)
Dan Willemsenb916b802017-03-19 13:44:32 -0700130 module.stl = nil
131 module.sanitize = nil
ThiƩbaud Weksteend4587452020-08-19 14:53:01 +0200132 library.disableStripping()
Dan Willemsenb916b802017-03-19 13:44:32 -0700133
134 stub := &llndkStubDecorator{
135 libraryDecorator: library,
136 }
137 module.compiler = stub
138 module.linker = stub
139 module.installer = nil
Colin Cross31076b32020-10-23 17:22:06 -0700140 module.library = stub
Dan Willemsenb916b802017-03-19 13:44:32 -0700141
Colin Cross36242852017-06-23 15:06:31 -0700142 return module
Dan Willemsenb916b802017-03-19 13:44:32 -0700143}
144
Patrice Arrudaea3fcdf2019-04-03 14:37:46 -0700145// llndk_library creates a stub llndk shared library based on the provided
146// version file. Example:
147//
148// llndk_library {
149// name: "libfoo",
150// symbol_file: "libfoo.map.txt",
151// export_include_dirs: ["include_vndk"],
152// }
Jiyong Parkda6eb592018-12-19 17:12:36 +0900153func LlndkLibraryFactory() android.Module {
Jiyong Park64ca4b72017-11-14 20:53:00 +0900154 module := NewLLndkStubLibrary()
Colin Cross4f4f8eb2021-01-06 14:07:27 -0800155 return module.Init()
156}
157
158// isVestigialLLNDKModule returns true if m is a vestigial llndk_library module used to provide
159// properties to the LLNDK variant of a cc_library.
160func isVestigialLLNDKModule(m *Module) bool {
161 _, ok := m.linker.(*llndkStubDecorator)
162 return ok
Dan Willemsenb916b802017-03-19 13:44:32 -0700163}
164
Jiyong Park2a454122017-10-19 15:59:33 +0900165type llndkHeadersDecorator struct {
166 *libraryDecorator
167}
168
Colin Crossb5f6fa62021-01-06 17:05:04 -0800169func (llndk *llndkHeadersDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
170 deps.HeaderLibs = append(deps.HeaderLibs, llndk.Properties.Llndk.Export_llndk_headers...)
171 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
172 llndk.Properties.Llndk.Export_llndk_headers...)
173 return deps
174}
175
Patrice Arrudaea3fcdf2019-04-03 14:37:46 -0700176// llndk_headers contains a set of c/c++ llndk headers files which are imported
177// by other soongs cc modules.
Jiyong Park2a454122017-10-19 15:59:33 +0900178func llndkHeadersFactory() android.Module {
179 module, library := NewLibrary(android.DeviceSupported)
180 library.HeaderOnly()
Inseob Kimc7c69102020-07-08 07:56:02 +0900181 module.stl = nil
182 module.sanitize = nil
Jiyong Park2a454122017-10-19 15:59:33 +0900183
184 decorator := &llndkHeadersDecorator{
185 libraryDecorator: library,
186 }
187
188 module.compiler = nil
189 module.linker = decorator
190 module.installer = nil
Colin Cross31076b32020-10-23 17:22:06 -0700191 module.library = decorator
Jiyong Park2a454122017-10-19 15:59:33 +0900192
Jiyong Park1d1119f2019-07-29 21:27:18 +0900193 module.Init()
Jiyong Park2a454122017-10-19 15:59:33 +0900194
195 return module
196}
197
Dan Willemsenb916b802017-03-19 13:44:32 -0700198func init() {
Jiyong Parkda6eb592018-12-19 17:12:36 +0900199 android.RegisterModuleType("llndk_library", LlndkLibraryFactory)
Jiyong Park2a454122017-10-19 15:59:33 +0900200 android.RegisterModuleType("llndk_headers", llndkHeadersFactory)
Dan Willemsenb916b802017-03-19 13:44:32 -0700201}