| // Copyright 2015 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 config |
| |
| import ( |
| "strings" |
| |
| "android/soong/android" |
| ) |
| |
| var ( |
| mipsCflags = []string{ |
| "-fno-exceptions", // from build/core/combo/select.mk |
| "-Wno-multichar", // from build/core/combo/select.mk |
| "-O2", |
| "-fomit-frame-pointer", |
| "-fno-strict-aliasing", |
| "-funswitch-loops", |
| "-U__unix", |
| "-U__unix__", |
| "-Umips", |
| "-ffunction-sections", |
| "-fdata-sections", |
| "-funwind-tables", |
| "-fstack-protector-strong", |
| "-Wa,--noexecstack", |
| "-Werror=format-security", |
| "-D_FORTIFY_SOURCE=2", |
| "-no-canonical-prefixes", |
| "-fno-canonical-system-headers", |
| |
| // TARGET_RELEASE_CFLAGS |
| "-DNDEBUG", |
| "-g", |
| "-Wstrict-aliasing=2", |
| "-fgcse-after-reload", |
| "-frerun-cse-after-loop", |
| "-frename-registers", |
| } |
| |
| mipsClangCflags = append(mipsCflags, []string{ |
| "-fPIC", |
| "-fno-integrated-as", |
| }...) |
| |
| mipsCppflags = []string{ |
| "-fvisibility-inlines-hidden", |
| } |
| |
| mipsLdflags = []string{ |
| "-Wl,-z,noexecstack", |
| "-Wl,-z,relro", |
| "-Wl,-z,now", |
| "-Wl,--build-id=md5", |
| "-Wl,--warn-shared-textrel", |
| "-Wl,--fatal-warnings", |
| "-Wl,--allow-shlib-undefined", |
| "-Wl,--no-undefined-version", |
| } |
| |
| mipsToolchainLdflags = []string{ |
| "-Wl,-melf32ltsmip", |
| } |
| |
| mipsArchVariantCflags = map[string][]string{ |
| "mips32-fp": []string{ |
| "-mips32", |
| "-mfp32", |
| "-modd-spreg", |
| "-mno-synci", |
| }, |
| "mips32r2-fp": []string{ |
| "-mips32r2", |
| "-mfp32", |
| "-modd-spreg", |
| "-msynci", |
| }, |
| "mips32r2-fp-xburst": []string{ |
| "-mips32r2", |
| "-mfp32", |
| "-modd-spreg", |
| "-mno-fused-madd", |
| "-Wa,-mmxu", |
| "-mno-synci", |
| }, |
| "mips32r2dsp-fp": []string{ |
| "-mips32r2", |
| "-mfp32", |
| "-modd-spreg", |
| "-mdsp", |
| "-msynci", |
| }, |
| "mips32r2dspr2-fp": []string{ |
| "-mips32r2", |
| "-mfp32", |
| "-modd-spreg", |
| "-mdspr2", |
| "-msynci", |
| }, |
| "mips32r6": []string{ |
| "-mips32r6", |
| "-mfp64", |
| "-mno-odd-spreg", |
| "-msynci", |
| |
| // revert once clang picks up r278824 |
| "-mcompact-branches=never", |
| }, |
| } |
| ) |
| |
| const ( |
| mipsGccVersion = "4.9" |
| ) |
| |
| func init() { |
| android.RegisterArchVariants(android.Mips, |
| "mips32_fp", |
| "mips32r2_fp", |
| "mips32r2_fp_xburst", |
| "mips32r2dsp_fp", |
| "mips32r2dspr2_fp", |
| "mips32r6") |
| android.RegisterArchFeatures(android.Mips, "rev6") |
| android.RegisterArchVariantFeatures(android.Mips, "mips32r6", |
| "rev6") |
| |
| pctx.StaticVariable("mipsGccVersion", mipsGccVersion) |
| |
| pctx.SourcePathVariable("MipsGccRoot", |
| "prebuilts/gcc/${HostPrebuiltTag}/mips/mips64el-linux-android-${mipsGccVersion}") |
| |
| pctx.StaticVariable("MipsToolchainLdflags", strings.Join(mipsToolchainLdflags, " ")) |
| pctx.StaticVariable("MipsCflags", strings.Join(mipsCflags, " ")) |
| pctx.StaticVariable("MipsLdflags", strings.Join(mipsLdflags, " ")) |
| pctx.StaticVariable("MipsCppflags", strings.Join(mipsCppflags, " ")) |
| pctx.StaticVariable("MipsIncludeFlags", bionicHeaders("mips", "mips")) |
| |
| // Clang cflags |
| pctx.StaticVariable("MipsClangCflags", strings.Join(ClangFilterUnknownCflags(mipsClangCflags), " ")) |
| pctx.StaticVariable("MipsClangLdflags", strings.Join(ClangFilterUnknownCflags(mipsLdflags), " ")) |
| pctx.StaticVariable("MipsClangCppflags", strings.Join(ClangFilterUnknownCflags(mipsCppflags), " ")) |
| |
| // Extended cflags |
| |
| // Architecture variant cflags |
| for variant, cflags := range mipsArchVariantCflags { |
| pctx.StaticVariable("Mips"+variant+"VariantCflags", strings.Join(cflags, " ")) |
| pctx.StaticVariable("Mips"+variant+"VariantClangCflags", |
| strings.Join(ClangFilterUnknownCflags(cflags), " ")) |
| } |
| } |
| |
| type toolchainMips struct { |
| toolchain32Bit |
| cflags, clangCflags string |
| toolchainCflags, toolchainClangCflags string |
| } |
| |
| func (t *toolchainMips) Name() string { |
| return "mips" |
| } |
| |
| func (t *toolchainMips) GccRoot() string { |
| return "${config.MipsGccRoot}" |
| } |
| |
| func (t *toolchainMips) GccTriple() string { |
| return "mips64el-linux-android" |
| } |
| |
| func (t *toolchainMips) GccVersion() string { |
| return mipsGccVersion |
| } |
| |
| func (t *toolchainMips) ToolchainLdflags() string { |
| return "${config.MipsToolchainLdflags}" |
| } |
| |
| func (t *toolchainMips) ToolchainCflags() string { |
| return t.toolchainCflags |
| } |
| |
| func (t *toolchainMips) Cflags() string { |
| return t.cflags |
| } |
| |
| func (t *toolchainMips) Cppflags() string { |
| return "${config.MipsCppflags}" |
| } |
| |
| func (t *toolchainMips) Ldflags() string { |
| return "${config.MipsLdflags}" |
| } |
| |
| func (t *toolchainMips) IncludeFlags() string { |
| return "${config.MipsIncludeFlags}" |
| } |
| |
| func (t *toolchainMips) ClangTriple() string { |
| return "mipsel-linux-android" |
| } |
| |
| func (t *toolchainMips) ToolchainClangLdflags() string { |
| return "${config.MipsToolchainLdflags}" |
| } |
| |
| func (t *toolchainMips) ToolchainClangCflags() string { |
| return t.toolchainClangCflags |
| } |
| |
| func (t *toolchainMips) ClangAsflags() string { |
| return "-fPIC -fno-integrated-as" |
| } |
| |
| func (t *toolchainMips) ClangCflags() string { |
| return t.clangCflags |
| } |
| |
| func (t *toolchainMips) ClangCppflags() string { |
| return "${config.MipsClangCppflags}" |
| } |
| |
| func (t *toolchainMips) ClangLdflags() string { |
| return "${config.MipsClangLdflags}" |
| } |
| |
| func (toolchainMips) SanitizerRuntimeLibraryArch() string { |
| return "mips" |
| } |
| |
| func mipsToolchainFactory(arch android.Arch) Toolchain { |
| return &toolchainMips{ |
| cflags: "${config.MipsCflags}", |
| clangCflags: "${config.MipsClangCflags}", |
| toolchainCflags: "${config.Mips" + arch.ArchVariant + "VariantCflags}", |
| toolchainClangCflags: "${config.Mips" + arch.ArchVariant + "VariantClangCflags}", |
| } |
| } |
| |
| func init() { |
| registerToolchainFactory(android.Android, android.Mips, mipsToolchainFactory) |
| } |