blob: 144d91c26edbe7957939f1a859e0ecbfce2525e4 [file] [log] [blame]
Dan Albert914449f2016-06-17 16:45:24 -07001// Copyright 2016 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
17// The platform needs to provide the following artifacts for the NDK:
18// 1. Bionic headers.
19// 2. Platform API headers.
20// 3. NDK stub shared libraries.
21// 4. Bionic static libraries.
22//
23// TODO(danalbert): All of the above need to include NOTICE files.
24//
25// Components 1 and 2: Headers
26// The bionic and platform API headers are generalized into a single
27// `ndk_headers` rule. This rule has a `from` property that indicates a base
28// directory from which headers are to be taken, and a `to` property that
29// indicates where in the sysroot they should reside relative to usr/include.
30// There is also a `srcs` property that is glob compatible for specifying which
31// headers to include.
32//
33// Component 3: Stub Libraries
34// The shared libraries in the NDK are not the actual shared libraries they
35// refer to (to prevent people from accidentally loading them), but stub
36// libraries with dummy implementations of everything for use at build time
37// only.
38//
39// Since we don't actually need to know anything about the stub libraries aside
40// from a list of functions and globals to be exposed, we can create these for
41// every platform level in the current tree. This is handled by the
42// ndk_library rule.
43//
44// Component 4: Static Libraries
45// The NDK only provides static libraries for bionic, not the platform APIs.
46// Since these need to be the actual implementation, we can't build old versions
47// in the current platform tree. As such, legacy versions are checked in
48// prebuilt to development/ndk, and a current version is built and archived as
49// part of the platform build. The platfrom already builds these libraries, our
50// NDK build rules only need to archive them for retrieval so they can be added
51// to the prebuilts.
52//
53// TODO(danalbert): Write `ndk_static_library` rule.
54
55import (
56 "github.com/google/blueprint"
57
58 "android/soong"
59 "android/soong/android"
60)
61
62func init() {
63 soong.RegisterModuleType("ndk_headers", ndkHeadersFactory)
64 soong.RegisterModuleType("ndk_library", ndkLibraryFactory)
65 soong.RegisterSingletonType("ndk", NdkSingleton)
66
67 pctx.Import("android/soong/common")
68}
69
70func getNdkInstallBase(ctx android.ModuleContext) android.OutputPath {
71 return android.PathForOutput(ctx, "ndk")
72}
73
74// Returns the main install directory for the NDK sysroot. Usable with --sysroot.
75func getNdkSysrootBase(ctx android.ModuleContext) android.OutputPath {
76 return getNdkInstallBase(ctx).Join(ctx, "sysroot")
77}
78
79func getNdkSysrootTimestampFile(ctx android.PathContext) android.Path {
80 return android.PathForOutput(ctx, "ndk.timestamp")
81}
82
83func NdkSingleton() blueprint.Singleton {
84 return &ndkSingleton{}
85}
86
87type ndkSingleton struct{}
88
89func (n *ndkSingleton) GenerateBuildActions(ctx blueprint.SingletonContext) {
90 installPaths := []string{}
91 ctx.VisitAllModules(func(module blueprint.Module) {
92 if m, ok := module.(*headerModule); ok {
93 installPaths = append(installPaths, m.installPaths...)
94 }
95 })
96
97 ctx.VisitAllModules(func(module blueprint.Module) {
98 if m, ok := module.(*Module); ok {
Colin Crossb916a382016-07-29 17:28:03 -070099 if installer, ok := m.installer.(*stubDecorator); ok {
Dan Albert914449f2016-06-17 16:45:24 -0700100 installPaths = append(installPaths, installer.installPath)
101 }
102 }
103 })
104
105 // There's a dummy "ndk" rule defined in ndk/Android.mk that depends on
106 // this. `m ndk` will build the sysroots.
107 ctx.Build(pctx, blueprint.BuildParams{
108 Rule: android.Touch,
109 Outputs: []string{getNdkSysrootTimestampFile(ctx).String()},
110 Implicits: installPaths,
Colin Crossf09c8432016-09-16 12:51:30 -0700111 Optional: true,
Dan Albert914449f2016-06-17 16:45:24 -0700112 })
113}