diff options
author | Craig Topper <craig.topper@intel.com> | 2017-07-12 06:49:56 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@intel.com> | 2017-07-12 06:49:56 +0000 |
commit | 3db11705f5c909b3fca43cda8eebc390c053a8b4 (patch) | |
tree | fe6cda9e15e67e96cd06404beb281acf0712df7d /llvm/lib/Support | |
parent | e98b65b8097ce2989d757cc91324ec047728036d (diff) | |
download | bcm5719-llvm-3db11705f5c909b3fca43cda8eebc390c053a8b4.tar.gz bcm5719-llvm-3db11705f5c909b3fca43cda8eebc390c053a8b4.zip |
[X86] Cleanup the switches in getHostCPUName to remove impossible combinations.
llvm-svn: 307756
Diffstat (limited to 'llvm/lib/Support')
-rw-r--r-- | llvm/lib/Support/Host.cpp | 35 |
1 files changed, 9 insertions, 26 deletions
diff --git a/llvm/lib/Support/Host.cpp b/llvm/lib/Support/Host.cpp index 817375b64dc..72b0486d3a7 100644 --- a/llvm/lib/Support/Host.cpp +++ b/llvm/lib/Support/Host.cpp @@ -910,7 +910,7 @@ static void getAMDProcessorTypeAndSubtype(unsigned Family, unsigned Model, *Type = AMDFAM15H; if (Model >= 0x60 && Model <= 0x7f) { *Subtype = AMDFAM15H_BDVER4; - break; // "bdver4"; 50h-6Fh: Excavator + break; // "bdver4"; 60h-7Fh: Excavator } if (Model >= 0x30 && Model <= 0x3f) { *Subtype = AMDFAM15H_BDVER3; @@ -1036,7 +1036,7 @@ StringRef sys::getHostCPUName() { case INTEL_CORE2_45: return "penryn"; default: - return "core2"; + llvm_unreachable("Unexpected subtype!"); } case INTEL_COREI7: switch (Subtype) { @@ -1057,7 +1057,7 @@ StringRef sys::getHostCPUName() { case INTEL_COREI7_SKYLAKE_AVX512: return "skylake-avx512"; default: - return "corei7"; + llvm_unreachable("Unexpected subtype!"); } case INTEL_ATOM: switch (Subtype) { @@ -1079,7 +1079,7 @@ StringRef sys::getHostCPUName() { case INTEL_PRESCOTT: return "prescott"; default: - return "generic"; + break; } } else if (Vendor == SIG_AMD) { getAMDProcessorTypeAndSubtype(Family, Model, Features, &Type, &Subtype); @@ -1116,7 +1116,7 @@ StringRef sys::getHostCPUName() { case AMDATHLON_64: return "athlon64"; default: - return "athlon"; + llvm_unreachable("Unexpected subtype!"); } case AMDFAM10H: return "amdfam10"; @@ -1124,6 +1124,7 @@ StringRef sys::getHostCPUName() { return "btver1"; case AMDFAM15H: switch (Subtype) { + default: // There are gaps in the subtype detection. case AMDFAM15H_BDVER1: return "bdver1"; case AMDFAM15H_BDVER2: @@ -1132,31 +1133,13 @@ StringRef sys::getHostCPUName() { return "bdver3"; case AMDFAM15H_BDVER4: return "bdver4"; - case AMD_BTVER1: - return "btver1"; - default: - return "amdfam15"; } case AMDFAM16H: - switch (Subtype) { - case AMD_BTVER1: - return "btver1"; - case AMD_BTVER2: - return "btver2"; - default: - return "amdfam16"; - } + return "btver2"; case AMDFAM17H: - switch (Subtype) { - case AMD_BTVER1: - return "btver1"; - case AMDFAM17H_ZNVER1: - return "znver1"; - default: - return "amdfam17"; - } + return "znver1"; default: - return "generic"; + break; } } return "generic"; |