aboutsummaryrefslogtreecommitdiffstats
path: root/cc
diff options
context:
space:
mode:
authorDan Willemsen <dwillemsen@google.com>2016-05-13 01:36:28 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2016-05-13 01:36:28 +0000
commit7f08e2194177daafbc9c103a7d3f7df1bd0903d7 (patch)
tree50bd550656ec3c4b42a1f26712b88b8dd13a08e4 /cc
parent2522660da7fa8039176842e5e353a57e7f1d7772 (diff)
parent4b7d5deb843a46aa34f337af852da940556cbd32 (diff)
downloadbuild_soong-7f08e2194177daafbc9c103a7d3f7df1bd0903d7.tar.gz
build_soong-7f08e2194177daafbc9c103a7d3f7df1bd0903d7.tar.bz2
build_soong-7f08e2194177daafbc9c103a7d3f7df1bd0903d7.zip
Merge "Publish Soong configuration to Make variables"
Diffstat (limited to 'cc')
-rw-r--r--cc/makevars.go111
1 files changed, 111 insertions, 0 deletions
diff --git a/cc/makevars.go b/cc/makevars.go
new file mode 100644
index 00000000..00a4f712
--- /dev/null
+++ b/cc/makevars.go
@@ -0,0 +1,111 @@
+// Copyright 2016 Google Inc. All rights reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package cc
+
+import (
+ "fmt"
+ "path/filepath"
+ "strings"
+
+ "android/soong/common"
+)
+
+func init() {
+ common.RegisterMakeVarsProvider(pctx, makeVarsProvider)
+}
+
+func makeVarsProvider(ctx common.MakeVarsContext) {
+ ctx.Strict("LLVM_PREBUILTS_VERSION", "${clangVersion}")
+ ctx.Strict("LLVM_PREBUILTS_BASE", "${clangBase}")
+
+ hostType := common.CurrentHostType()
+ arches := ctx.Config().HostArches[hostType]
+ makeVarsToolchain(ctx, "", common.Host, hostType, arches[0])
+ if len(arches) > 1 {
+ makeVarsToolchain(ctx, "2ND_", common.Host, hostType, arches[1])
+ }
+
+ if winArches, ok := ctx.Config().HostArches[common.Windows]; ok {
+ makeVarsToolchain(ctx, "", common.Host, common.Windows, winArches[0])
+ if len(winArches) > 1 {
+ makeVarsToolchain(ctx, "2ND_", common.Host, common.Windows, winArches[1])
+ }
+ }
+
+ arches = ctx.Config().DeviceArches
+ makeVarsToolchain(ctx, "", common.Device, common.NoHostType, arches[0])
+ if len(arches) > 1 {
+ makeVarsToolchain(ctx, "2ND_", common.Device, common.NoHostType, arches[1])
+ }
+}
+
+func makeVarsToolchain(ctx common.MakeVarsContext, secondPrefix string,
+ hod common.HostOrDevice, ht common.HostType, arch common.Arch) {
+ var typePrefix string
+ if hod.Host() {
+ if ht == common.Windows {
+ typePrefix = "HOST_CROSS_"
+ } else {
+ typePrefix = "HOST_"
+ }
+ } else {
+ typePrefix = "TARGET_"
+ }
+ makePrefix := secondPrefix + typePrefix
+
+ toolchain := toolchainFactories[hod][ht][arch.ArchType](arch)
+
+ globalCflags := fmt.Sprintf("${commonGlobalCflags} ${%sGlobalCflags}", hod)
+
+ ctx.CheckSorted(makePrefix+"GLOBAL_CFLAGS", strings.Join([]string{
+ toolchain.ToolchainCflags(),
+ globalCflags,
+ toolchain.Cflags(),
+ }, " "))
+ ctx.CheckSorted(makePrefix+"GLOBAL_LDFLAGS", strings.Join([]string{
+ toolchain.ToolchainLdflags(),
+ toolchain.Ldflags(),
+ }, " "))
+
+ if toolchain.ClangSupported() {
+ clangPrefix := secondPrefix + "CLANG_" + typePrefix
+ clangExtras := "-target " + toolchain.ClangTriple() + " -B" + filepath.Join(toolchain.GccRoot(), toolchain.GccTriple(), "bin")
+
+ globalClangCflags := fmt.Sprintf("${commonClangGlobalCflags} ${clangExtraCflags} ${%sClangGlobalCflags}", hod)
+
+ ctx.CheckSorted(clangPrefix+"GLOBAL_CFLAGS", strings.Join([]string{
+ toolchain.ToolchainClangCflags(),
+ globalClangCflags,
+ toolchain.ClangCflags(),
+ clangExtras,
+ }, " "))
+ ctx.CheckSorted(clangPrefix+"GLOBAL_LDFLAGS", strings.Join([]string{
+ toolchain.ToolchainClangLdflags(),
+ toolchain.ClangLdflags(),
+ clangExtras,
+ }, " "))
+ }
+
+ ctx.Strict(makePrefix+"CC", gccCmd(toolchain, "gcc"))
+ ctx.Strict(makePrefix+"CXX", gccCmd(toolchain, "g++"))
+
+ if ht == common.Darwin {
+ ctx.Strict(makePrefix+"AR", "${macArPath}")
+ } else {
+ ctx.Strict(makePrefix+"AR", gccCmd(toolchain, "ar"))
+ ctx.Strict(makePrefix+"READELF", gccCmd(toolchain, "readelf"))
+ ctx.Strict(makePrefix+"NM", gccCmd(toolchain, "nm"))
+ }
+}