diff options
| author | Daniel Dunbar <daniel@zuster.org> | 2009-09-04 18:35:31 +0000 |
|---|---|---|
| committer | Daniel Dunbar <daniel@zuster.org> | 2009-09-04 18:35:31 +0000 |
| commit | 91dbfd6666d0de927cd948f8a8905fb63d57bdbd (patch) | |
| tree | bdb00f88b70d1cd6026bb7d33c1af339416cd736 /clang/lib | |
| parent | 84e727fb726a80d96835aae0736095cde83882b9 (diff) | |
| download | bcm5719-llvm-91dbfd6666d0de927cd948f8a8905fb63d57bdbd.tar.gz bcm5719-llvm-91dbfd6666d0de927cd948f8a8905fb63d57bdbd.zip | |
Implement darwin::Link::AddDarwinArch for ARM.
llvm-svn: 81020
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Driver/Tools.cpp | 74 |
1 files changed, 73 insertions, 1 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index 27b34c7676a..068ccd34bb8 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -1368,11 +1368,83 @@ static bool isMacosxVersionLT(unsigned (&A)[3], return isMacosxVersionLT(A, B); } +// FIXME: Can we tablegen this? +static const char *GetArmArchForMArch(llvm::StringRef Value) { + if (Value == "armv6k") + return "armv6"; + + if (Value == "armv5tej") + return "armv5"; + + if (Value == "xscale") + return "xscale"; + + if (Value == "armv4t") + return "armv4t"; + + if (Value == "armv7" || Value == "armv7-a" || Value == "armv7-r" || + Value == "armv7-m" || Value == "armv7a" || Value == "armv7r" || + Value == "armv7m") + return "armv7"; + + return 0; +} + +// FIXME: Can we tablegen this? +static const char *GetArmArchForMCpu(llvm::StringRef Value) { + if (Value == "arm10tdmi" || Value == "arm1020t" || Value == "arm9e" || + Value == "arm946e-s" || Value == "arm966e-s" || + Value == "arm968e-s" || Value == "arm10e" || + Value == "arm1020e" || Value == "arm1022e" || Value == "arm926ej-s" || + Value == "arm1026ej-s") + return "armv5"; + + if (Value == "xscale") + return "xscale"; + + if (Value == "arm1136j-s" || Value == "arm1136jf-s" || + Value == "arm1176jz-s" || Value == "arm1176jzf-s") + return "armv6"; + + if (Value == "cortex-a8" || Value == "cortex-r4" || Value == "cortex-m3") + return "armv7"; + + return 0; +} + void darwin::Link::AddDarwinArch(const ArgList &Args, ArgStringList &CmdArgs) const { // Derived from darwin_arch spec. CmdArgs.push_back("-arch"); - CmdArgs.push_back(Args.MakeArgString(getToolChain().getArchName().c_str())); + + switch (getToolChain().getTriple().getArch()) { + default: + CmdArgs.push_back(Args.MakeArgString(getToolChain().getArchName().c_str())); + break; + + case llvm::Triple::arm: { + // FIXME: gcc isn't actually following this, it looks like the arch is + // getting forced somewhere else (translation?). + + if (const Arg *A = Args.getLastArg(options::OPT_march_EQ)) { + if (const char *Arch = GetArmArchForMArch(A->getValue(Args))) { + CmdArgs.push_back(Arch); + return; + } + } + + if (const Arg *A = Args.getLastArg(options::OPT_mcpu_EQ)) { + if (const char *Arch = GetArmArchForMCpu(A->getValue(Args))) { + CmdArgs.push_back(Arch); + return; + } + } + + CmdArgs.push_back("arm"); + CmdArgs.push_back("-force_cpusubtype_ALL"); + return; + } + } } void darwin::Link::AddDarwinSubArch(const ArgList &Args, |

