diff options
| author | Christian Pirker <cpirker@a-bix.com> | 2014-05-05 08:48:18 +0000 |
|---|---|---|
| committer | Christian Pirker <cpirker@a-bix.com> | 2014-05-05 08:48:18 +0000 |
| commit | 918d1097a136b487e9ef0a7aa63f50d7b30a773a (patch) | |
| tree | 8953f5a3ebb6532ee2b6f104a9537d49e2b25c7f /clang/lib/Driver/Tools.cpp | |
| parent | 9509f18836479f70467337f64bffabe0dab6179e (diff) | |
| download | bcm5719-llvm-918d1097a136b487e9ef0a7aa63f50d7b30a773a.tar.gz bcm5719-llvm-918d1097a136b487e9ef0a7aa63f50d7b30a773a.zip | |
Simplify getARMCPUForMArch() and make it more consistent
llvm-svn: 207956
Diffstat (limited to 'clang/lib/Driver/Tools.cpp')
| -rw-r--r-- | clang/lib/Driver/Tools.cpp | 92 |
1 files changed, 39 insertions, 53 deletions
diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index fe0b727b1d9..247d0d8cfa1 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -4889,63 +4889,49 @@ const char *arm::getARMCPUForMArch(const ArgList &Args, break; } - const char *result = llvm::StringSwitch<const char *>(MArch) - .Cases("armv2", "armv2a","arm2") - .Case("armv3", "arm6") - .Case("armv3m", "arm7m") - .Case("armv4", "strongarm") - .Case("armv4t", "arm7tdmi") - .Case("thumbv4t", "arm7tdmi") - .Cases("armv5", "armv5t", "arm10tdmi") - .Cases("thumbv5", "thumbv5t", "arm10tdmi") - .Cases("armv5e", "armv5te", "arm1022e") - .Cases("thumbv5e", "thumbv5te", "arm1022e") - .Case("armv5tej", "arm926ej-s") - .Case("thumbv5tej", "arm926ej-s") - .Cases("armv6", "armv6k", "arm1136jf-s") - .Cases("thumbv6", "thumbv6k", "arm1136jf-s") - .Case("armv6j", "arm1136j-s") - .Case("thumbv6j", "arm1136j-s") - .Cases("armv6z", "armv6zk", "arm1176jzf-s") - .Cases("thumbv6z", "thumbv6zk", "arm1176jzf-s") - .Case("armv6t2", "arm1156t2-s") - .Case("thumbv6t2", "arm1156t2-s") - .Cases("armv6m", "armv6-m", "cortex-m0") - .Case("thumbv6m", "cortex-m0") - .Cases("armv7", "armv7a", "armv7-a", "cortex-a8") - .Cases("armebv7", "armebv7a", "armebv7-a", "cortex-a8") - .Cases("thumbv7", "thumbv7a", "cortex-a8") - .Cases("thumbebv7", "thumbebv7a", "cortex-a8") - .Cases("armv7l", "armv7-l", "cortex-a8") - .Cases("armebv7l", "armebv7-l", "cortex-a8") - .Cases("armv7s", "armv7-s", "swift") - .Cases("armebv7s", "armebv7-s", "swift") - .Cases("armv7r", "armv7-r", "cortex-r4") - .Cases("armebv7r", "armebv7-r", "cortex-r4") - .Case("thumbv7r", "cortex-r4") - .Case("thumbebv7r", "cortex-r4") - .Cases("armv7m", "armv7-m", "cortex-m3") - .Cases("armebv7m", "armebv7-m", "cortex-m3") - .Case("thumbv7m", "cortex-m3") - .Case("thumbebv7m", "cortex-m3") - .Cases("armv7em", "armv7e-m", "cortex-m4") - .Cases("armebv7em", "armebv7e-m", "cortex-m4") - .Cases("thumbv7em", "thumbv7e-m", "cortex-m4") - .Cases("thumbebv7em", "thumbebv7e-m", "cortex-m4") - .Cases("armv8", "armv8a", "armv8-a", "cortex-a53") - .Cases("armebv8", "armebv8a", "armebv8-a", "cortex-a53") - .Cases("thumbv8", "thumbv8a", "cortex-a53") - .Cases("thumbebv8", "thumbebv8a", "cortex-a53") - .Case("ep9312", "ep9312") - .Case("iwmmxt", "iwmmxt") - .Case("xscale", "xscale") - // If all else failed, return the most base CPU with thumb interworking - // supported by LLVM. - .Default(0); + const char *result = nullptr; + size_t offset = StringRef::npos; + if (MArch.startswith("arm")) + offset = 3; + if (MArch.startswith("thumb")) + offset = 5; + if (offset != StringRef::npos && MArch.substr(offset, 2) == "eb") + offset += 2; + if (offset != StringRef::npos) + result = llvm::StringSwitch<const char *>(MArch.substr(offset)) + .Cases("v2", "v2a", "arm2") + .Case("v3", "arm6") + .Case("v3m", "arm7m") + .Case("v4", "strongarm") + .Case("v4t", "arm7tdmi") + .Cases("v5", "v5t", "arm10tdmi") + .Cases("v5e", "v5te", "arm1022e") + .Case("v5tej", "arm926ej-s") + .Cases("v6", "v6k", "arm1136jf-s") + .Case("v6j", "arm1136j-s") + .Cases("v6z", "v6zk", "arm1176jzf-s") + .Case("v6t2", "arm1156t2-s") + .Cases("v6m", "v6-m", "cortex-m0") + .Cases("v7", "v7a", "v7-a", "v7l", "v7-l", "cortex-a8") + .Cases("v7s", "v7-s", "swift") + .Cases("v7r", "v7-r", "cortex-r4") + .Cases("v7m", "v7-m", "cortex-m3") + .Cases("v7em", "v7e-m", "cortex-m4") + .Cases("v8", "v8a", "v8-a", "cortex-a53") + .Default(nullptr); + else + result = llvm::StringSwitch<const char *>(MArch) + .Case("ep9312", "ep9312") + .Case("iwmmxt", "iwmmxt") + .Case("xscale", "xscale") + .Default(nullptr); if (result) return result; + // If all else failed, return the most base CPU with thumb interworking + // supported by LLVM. + // FIXME: Should warn once that we're falling back. switch (Triple.getOS()) { case llvm::Triple::NetBSD: switch (Triple.getEnvironment()) { |

