blob: 571a3bb71cea06338c22bb6970f1268ed522f4fc [file] [log] [blame]
Ivan Lozano183a3212019-10-18 14:18:45 -07001package cc
2
3import (
Ivan Lozano183a3212019-10-18 14:18:45 -07004 "android/soong/android"
Colin Cross6e511a92020-07-27 21:26:48 -07005
6 "github.com/google/blueprint"
Ivan Lozano183a3212019-10-18 14:18:45 -07007)
8
Ivan Lozano3968d8f2020-12-14 11:27:52 -05009// PlatformSanitizeable is an interface for sanitizing platform modules.
10type PlatformSanitizeable interface {
11 LinkableInterface
12
13 // SanitizePropDefined returns whether the Sanitizer properties struct for this module is defined.
14 SanitizePropDefined() bool
15
16 // IsDependencyRoot returns whether a module is of a type which cannot be a linkage dependency
17 // of another module. For example, cc_binary and rust_binary represent dependency roots as other
18 // modules cannot have linkage dependencies against these types.
19 IsDependencyRoot() bool
20
21 // IsSanitizerEnabled returns whether a sanitizer is enabled.
22 IsSanitizerEnabled(t SanitizerType) bool
23
24 // IsSanitizerExplicitlyDisabled returns whether a sanitizer has been explicitly disabled (set to false) rather
25 // than left undefined.
26 IsSanitizerExplicitlyDisabled(t SanitizerType) bool
27
28 // SanitizeDep returns the value of the SanitizeDep flag, which is set if a module is a dependency of a
29 // sanitized module.
30 SanitizeDep() bool
31
32 // SetSanitizer enables or disables the specified sanitizer type if it's supported, otherwise this should panic.
33 SetSanitizer(t SanitizerType, b bool)
34
35 // SetSanitizerDep returns true if the module is statically linked.
36 SetSanitizeDep(b bool)
37
38 // StaticallyLinked returns true if the module is statically linked.
39 StaticallyLinked() bool
40
41 // SetInSanitizerDir sets the module installation to the sanitizer directory.
42 SetInSanitizerDir()
43
44 // SanitizeNever returns true if this module should never be sanitized.
45 SanitizeNever() bool
46
47 // SanitizerSupported returns true if a sanitizer type is supported by this modules compiler.
48 SanitizerSupported(t SanitizerType) bool
49
50 // SanitizableDepTagChecker returns a SantizableDependencyTagChecker function type.
51 SanitizableDepTagChecker() SantizableDependencyTagChecker
52}
53
54// SantizableDependencyTagChecker functions check whether or not a dependency
55// tag can be sanitized. These functions should return true if the tag can be
56// sanitized, otherwise they should return false. These functions should also
57// handle all possible dependency tags in the dependency tree. For example,
58// Rust modules can depend on both Rust and CC libraries, so the Rust module
59// implementation should handle tags from both.
60type SantizableDependencyTagChecker func(tag blueprint.DependencyTag) bool
61
Chris Parsons3c27ca32020-11-20 12:42:07 -050062// LinkableInterface is an interface for a type of module that is linkable in a C++ library.
Ivan Lozano183a3212019-10-18 14:18:45 -070063type LinkableInterface interface {
Ivan Lozanof9e21722020-12-02 09:00:51 -050064 android.Module
65
Ivan Lozano183a3212019-10-18 14:18:45 -070066 Module() android.Module
67 CcLibrary() bool
68 CcLibraryInterface() bool
69
Ivan Lozano183a3212019-10-18 14:18:45 -070070 OutputFile() android.OptionalPath
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040071 CoverageFiles() android.Paths
Ivan Lozano183a3212019-10-18 14:18:45 -070072
Ivan Lozano2b262972019-11-21 12:30:50 -080073 NonCcVariants() bool
74
Ivan Lozano52767be2019-10-18 14:49:46 -070075 SelectedStl() string
Ivan Lozano183a3212019-10-18 14:18:45 -070076
77 BuildStaticVariant() bool
78 BuildSharedVariant() bool
79 SetStatic()
80 SetShared()
Ivan Lozano52767be2019-10-18 14:49:46 -070081 Static() bool
82 Shared() bool
Ivan Lozano3968d8f2020-12-14 11:27:52 -050083 Header() bool
84 IsPrebuilt() bool
Ivan Lozano52767be2019-10-18 14:49:46 -070085 Toc() android.OptionalPath
86
Jooyung Han624d35c2020-04-10 12:57:24 +090087 Host() bool
88
Yifan Hong1b3348d2020-01-21 15:53:22 -080089 InRamdisk() bool
90 OnlyInRamdisk() bool
91
Yifan Hong60e0cfb2020-10-21 15:17:56 -070092 InVendorRamdisk() bool
93 OnlyInVendorRamdisk() bool
94
Ivan Lozano52767be2019-10-18 14:49:46 -070095 InRecovery() bool
96 OnlyInRecovery() bool
97
Ivan Lozano3968d8f2020-12-14 11:27:52 -050098 InVendor() bool
99
Colin Crossc511bc52020-04-07 16:50:32 +0000100 UseSdk() bool
Ivan Lozano3a7d0002021-03-30 12:19:36 -0400101
102 // IsLlndk returns true for both LLNDK (public) and LLNDK-private libs.
103 IsLlndk() bool
104
105 // IsLlndkPublic returns true only for LLNDK (public) libs.
106 IsLlndkPublic() bool
107
108 // IsLlndkHeaders returns true if this module is an LLNDK headers module.
109 IsLlndkHeaders() bool
110
111 // IsLlndkLibrary returns true if this module is an LLNDK library module.
112 IsLlndkLibrary() bool
113
114 // HasLlndkStubs returns true if this module has LLNDK stubs.
115 HasLlndkStubs() bool
116
Ivan Lozano52767be2019-10-18 14:49:46 -0700117 UseVndk() bool
118 MustUseVendorVariant() bool
119 IsVndk() bool
Ivan Lozanof9e21722020-12-02 09:00:51 -0500120 IsVndkExt() bool
Colin Cross127bb8b2020-12-16 16:46:01 -0800121 IsVndkPrivate() bool
Ivan Lozano52767be2019-10-18 14:49:46 -0700122 HasVendorVariant() bool
Justin Yuncbca3732021-02-03 19:24:13 +0900123 HasProductVariant() bool
124 HasNonSystemVariants() bool
Ivan Lozanof9e21722020-12-02 09:00:51 -0500125 InProduct() bool
Ivan Lozano52767be2019-10-18 14:49:46 -0700126
Ivan Lozanoc08897c2021-04-02 12:41:32 -0400127 // SubName returns the modules SubName, used for image and NDK/SDK variations.
128 SubName() string
129
Ivan Lozano52767be2019-10-18 14:49:46 -0700130 SdkVersion() string
Jiyong Parkfdaa5f72021-03-19 22:18:04 +0900131 MinSdkVersion() string
Colin Crossc511bc52020-04-07 16:50:32 +0000132 AlwaysSdk() bool
Jiyong Park2286afd2020-06-16 21:58:53 +0900133 IsSdkVariant() bool
Ivan Lozano52767be2019-10-18 14:49:46 -0700134
Colin Cross1348ce32020-10-01 13:37:16 -0700135 SplitPerApiLevel() bool
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500136
137 // SetPreventInstall sets the PreventInstall property to 'true' for this module.
138 SetPreventInstall()
139 // SetHideFromMake sets the HideFromMake property to 'true' for this module.
140 SetHideFromMake()
Ivan Lozano3a7d0002021-03-30 12:19:36 -0400141
142 // KernelHeadersDecorator returns true if this is a kernel headers decorator module.
143 // This is specific to cc and should always return false for all other packages.
144 KernelHeadersDecorator() bool
Ivan Lozano183a3212019-10-18 14:18:45 -0700145}
146
Colin Cross6e511a92020-07-27 21:26:48 -0700147var (
Chris Parsons3c27ca32020-11-20 12:42:07 -0500148 // Dependency tag for crtbegin, an object file responsible for initialization.
Colin Cross6e511a92020-07-27 21:26:48 -0700149 CrtBeginDepTag = dependencyTag{name: "crtbegin"}
Chris Parsons3c27ca32020-11-20 12:42:07 -0500150 // Dependency tag for crtend, an object file responsible for program termination.
151 CrtEndDepTag = dependencyTag{name: "crtend"}
152 // Dependency tag for coverage library.
Colin Cross6e511a92020-07-27 21:26:48 -0700153 CoverageDepTag = dependencyTag{name: "coverage"}
154)
Ivan Lozano183a3212019-10-18 14:18:45 -0700155
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500156// GetImageVariantType returns the ImageVariantType string value for the given module
157// (these are defined in cc/image.go).
158func GetImageVariantType(c LinkableInterface) ImageVariantType {
159 if c.Host() {
160 return hostImageVariant
161 } else if c.InVendor() {
162 return vendorImageVariant
163 } else if c.InProduct() {
164 return productImageVariant
165 } else if c.InRamdisk() {
166 return ramdiskImageVariant
167 } else if c.InVendorRamdisk() {
168 return vendorRamdiskImageVariant
169 } else if c.InRecovery() {
170 return recoveryImageVariant
171 } else {
172 return coreImageVariant
173 }
174}
175
Ivan Lozanoc08897c2021-04-02 12:41:32 -0400176// DepTagMakeSuffix returns the makeSuffix value of a particular library dependency tag.
177// Returns an empty string if not a library dependency tag.
178func DepTagMakeSuffix(depTag blueprint.DependencyTag) string {
179 if libDepTag, ok := depTag.(libraryDependencyTag); ok {
180 return libDepTag.makeSuffix
181 }
182 return ""
183}
184
Chris Parsons3c27ca32020-11-20 12:42:07 -0500185// SharedDepTag returns the dependency tag for any C++ shared libraries.
Colin Cross6e511a92020-07-27 21:26:48 -0700186func SharedDepTag() blueprint.DependencyTag {
187 return libraryDependencyTag{Kind: sharedLibraryDependency}
Ivan Lozano183a3212019-10-18 14:18:45 -0700188}
189
Chris Parsons3c27ca32020-11-20 12:42:07 -0500190// StaticDepTag returns the dependency tag for any C++ static libraries.
Ivan Lozano63bb7682021-03-23 15:53:44 -0400191func StaticDepTag(wholeStatic bool) blueprint.DependencyTag {
192 return libraryDependencyTag{Kind: staticLibraryDependency, wholeStatic: wholeStatic}
193}
194
195// IsWholeStaticLib whether a dependency tag is a whole static library dependency.
196func IsWholeStaticLib(depTag blueprint.DependencyTag) bool {
197 if tag, ok := depTag.(libraryDependencyTag); ok {
198 return tag.wholeStatic
199 }
200 return false
Colin Cross6e511a92020-07-27 21:26:48 -0700201}
Colin Cross0de8a1e2020-09-18 14:15:30 -0700202
Chris Parsons3c27ca32020-11-20 12:42:07 -0500203// HeaderDepTag returns the dependency tag for any C++ "header-only" libraries.
Zach Johnson3df4e632020-11-06 11:56:27 -0800204func HeaderDepTag() blueprint.DependencyTag {
205 return libraryDependencyTag{Kind: headerLibraryDependency}
206}
207
Chris Parsons3c27ca32020-11-20 12:42:07 -0500208// SharedLibraryInfo is a provider to propagate information about a shared C++ library.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700209type SharedLibraryInfo struct {
210 SharedLibrary android.Path
211 UnstrippedSharedLibrary android.Path
212
213 TableOfContents android.OptionalPath
214 CoverageSharedLibrary android.OptionalPath
215
216 StaticAnalogue *StaticLibraryInfo
217}
218
219var SharedLibraryInfoProvider = blueprint.NewProvider(SharedLibraryInfo{})
220
Chris Parsons3c27ca32020-11-20 12:42:07 -0500221// SharedStubLibrary is a struct containing information about a stub shared library.
222// Stub libraries are used for cross-APEX dependencies; when a library is to depend on a shared
223// library in another APEX, it must depend on the stub version of that library.
224type SharedStubLibrary struct {
225 // The version of the stub (corresponding to the stable version of the shared library being
226 // stubbed).
Colin Cross0de8a1e2020-09-18 14:15:30 -0700227 Version string
228 SharedLibraryInfo SharedLibraryInfo
229 FlagExporterInfo FlagExporterInfo
230}
231
Chris Parsons3c27ca32020-11-20 12:42:07 -0500232// SharedLibraryStubsInfo is a provider to propagate information about all shared library stubs
233// which are dependencies of a library.
234// Stub libraries are used for cross-APEX dependencies; when a library is to depend on a shared
235// library in another APEX, it must depend on the stub version of that library.
236type SharedLibraryStubsInfo struct {
237 SharedStubLibraries []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -0700238
Chris Parsons3c27ca32020-11-20 12:42:07 -0500239 IsLLNDK bool
240}
241
242var SharedLibraryStubsProvider = blueprint.NewProvider(SharedLibraryStubsInfo{})
243
244// StaticLibraryInfo is a provider to propagate information about a static C++ library.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700245type StaticLibraryInfo struct {
246 StaticLibrary android.Path
247 Objects Objects
248 ReuseObjects Objects
249
250 // This isn't the actual transitive DepSet, shared library dependencies have been
251 // converted into static library analogues. It is only used to order the static
252 // library dependencies that were specified for the current module.
253 TransitiveStaticLibrariesForOrdering *android.DepSet
254}
255
256var StaticLibraryInfoProvider = blueprint.NewProvider(StaticLibraryInfo{})
257
Colin Cross649d8172020-12-10 12:30:21 -0800258// HeaderLibraryInfo is a marker provider that identifies a module as a header library.
259type HeaderLibraryInfo struct {
260}
261
262// HeaderLibraryInfoProvider is a marker provider that identifies a module as a header library.
263var HeaderLibraryInfoProvider = blueprint.NewProvider(HeaderLibraryInfo{})
264
Chris Parsons3c27ca32020-11-20 12:42:07 -0500265// FlagExporterInfo is a provider to propagate transitive library information
266// pertaining to exported include paths and flags.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700267type FlagExporterInfo struct {
Chris Parsons3c27ca32020-11-20 12:42:07 -0500268 IncludeDirs android.Paths // Include directories to be included with -I
269 SystemIncludeDirs android.Paths // System include directories to be included with -isystem
270 Flags []string // Exported raw flags.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700271 Deps android.Paths
272 GeneratedHeaders android.Paths
273}
274
275var FlagExporterInfoProvider = blueprint.NewProvider(FlagExporterInfo{})