Add an instruction_set property to Arch

Used to allow switching between thumb and arm ISAs

Change-Id: I94aa83cee7179e83c97eedc32fd216965b626d33
This commit is contained in:
Tim Kilbourn 2015-03-18 12:28:32 -07:00
parent c472d57f57
commit 1a9bf268ad
3 changed files with 38 additions and 3 deletions

View File

@ -149,7 +149,7 @@ func init() {
// Extended cflags
// ARM mode vs. Thumb mode
// ARM vs. Thumb instruction set flags
pctx.StaticVariable("armArmCflags", strings.Join(armArmCflags, " "))
pctx.StaticVariable("armThumbCflags", strings.Join(armThumbCflags, " "))
@ -256,6 +256,17 @@ func (t *toolchainArm) IncludeFlags() string {
return "${armIncludeFlags}"
}
func (t *toolchainArm) InstructionSetFlags(isa string) (string, error) {
switch isa {
case "arm":
return "${armArmCflags}", nil
case "thumb", "":
return "${armThumbCflags}", nil
default:
return t.toolchainBase.InstructionSetFlags(isa)
}
}
func (t *toolchainArm) ClangTriple() string {
return "${armGccTriple}"
}
@ -277,7 +288,6 @@ func armToolchainFactory(archVariant string, cpuVariant string) toolchain {
cflags: strings.Join([]string{
"${armCflags}",
"${armIncludeFlags}",
"${armThumbCflags}",
armArchVariantCflagsVar[archVariant],
armCpuVariantCflagsVar[cpuVariant],
}, " "),
@ -288,7 +298,6 @@ func armToolchainFactory(archVariant string, cpuVariant string) toolchain {
clangCflags: strings.Join([]string{
"${armClangCflags}",
"${armIncludeFlags}",
"${armThumbCflags}",
armClangArchVariantCflagsVar[archVariant],
armClangCpuVariantCflagsVar[cpuVariant],
}, " "),

View File

@ -126,6 +126,10 @@ type ccProperties struct {
// ldflags: list of module-specific flags that will be used for all link steps
Ldflags []string `android:"arch_variant"`
// instruction_set: the instruction set architecture to use to compile the C/C++
// module.
Instruction_set string `android:"arch_variant"`
// include_dirs: list of directories relative to the root of the source tree that will
// be added to the include path using -I.
// If possible, don't use this. If adding paths from the current directory use
@ -353,6 +357,11 @@ func (c *ccBase) flags(ctx common.AndroidModuleContext, toolchain toolchain) ccF
toolchain: toolchain,
clang: c.properties.Clang,
}
instructionSet := c.properties.Instruction_set
instructionSetFlags, err := toolchain.InstructionSetFlags(instructionSet)
if err != nil {
ctx.ModuleErrorf("%s", err)
}
if arch.HostOrDevice.Host() {
// TODO: allow per-module clang disable for host
@ -411,6 +420,7 @@ func (c *ccBase) flags(ctx common.AndroidModuleContext, toolchain toolchain) ccF
flags.globalFlags = []string{
"${commonGlobalIncludes}",
toolchain.IncludeFlags(),
instructionSetFlags,
toolchain.ClangCflags(),
"${commonClangGlobalCflags}",
fmt.Sprintf("${%sClangGlobalCflags}", arch.HostOrDevice),
@ -420,6 +430,7 @@ func (c *ccBase) flags(ctx common.AndroidModuleContext, toolchain toolchain) ccF
flags.globalFlags = []string{
"${commonGlobalIncludes}",
toolchain.IncludeFlags(),
instructionSetFlags,
toolchain.Cflags(),
"${commonGlobalCflags}",
fmt.Sprintf("${%sGlobalCflags}", arch.HostOrDevice),

View File

@ -15,6 +15,8 @@
package cc
import (
"fmt"
"android/soong/common"
)
@ -38,6 +40,7 @@ type toolchain interface {
Cppflags() string
Ldflags() string
IncludeFlags() string
InstructionSetFlags(string) (string, error)
ClangTriple() string
ClangCflags() string
@ -47,7 +50,18 @@ type toolchain interface {
Is64Bit() bool
}
type toolchainBase struct {
}
func (toolchainBase) InstructionSetFlags(s string) (string, error) {
if s != "" {
return "", fmt.Errorf("instruction_set: %s is not a supported instruction set", s)
}
return "", nil
}
type toolchain64Bit struct {
toolchainBase
}
func (toolchain64Bit) Is64Bit() bool {
@ -55,6 +69,7 @@ func (toolchain64Bit) Is64Bit() bool {
}
type toolchain32Bit struct {
toolchainBase
}
func (toolchain32Bit) Is64Bit() bool {