From e7476fadc94b87293e7192c419125cf446d454ce Mon Sep 17 00:00:00 2001 From: Craig Topper Date: Sat, 16 Sep 2017 16:44:39 +0000 Subject: [PATCH] [X86] Remove unnecessary extra encodings from the CPU name enum in clang Summary: For a lot of older CPUs we have a 1:1 mapping between CPU name and enum name. But many of them are effectively aliases of each other and as a result are always repeated together at every usage This patch removes most of the duplication. It also uses StringSwitch::Cases to make the many to one mapping in the StringSwitch more obvious. Reviewers: RKSimon, spatel, zvi, igorb Reviewed By: RKSimon Subscribers: cfe-commits Differential Revision: https://reviews.llvm.org/D37938 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@313462 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Basic/Targets/X86.cpp | 66 +++++++++------------------------------ lib/Basic/Targets/X86.h | 20 ------------ 2 files changed, 14 insertions(+), 72 deletions(-) diff --git a/lib/Basic/Targets/X86.cpp b/lib/Basic/Targets/X86.cpp index dce346f7ee..25da3fd78a 100644 --- a/lib/Basic/Targets/X86.cpp +++ b/lib/Basic/Targets/X86.cpp @@ -130,14 +130,12 @@ bool X86TargetInfo::initFeatureMap( setFeatureEnabledImpl(Features, "mmx", true); break; case CK_Pentium3: - case CK_Pentium3M: case CK_C3_2: setFeatureEnabledImpl(Features, "sse", true); setFeatureEnabledImpl(Features, "fxsr", true); break; case CK_PentiumM: case CK_Pentium4: - case CK_Pentium4M: case CK_x86_64: setFeatureEnabledImpl(Features, "sse2", true); setFeatureEnabledImpl(Features, "fxsr", true); @@ -265,21 +263,15 @@ bool X86TargetInfo::initFeatureMap( setFeatureEnabledImpl(Features, "3dnow", true); break; case CK_Athlon: - case CK_AthlonThunderbird: case CK_Geode: setFeatureEnabledImpl(Features, "3dnowa", true); break; - case CK_Athlon4: case CK_AthlonXP: - case CK_AthlonMP: setFeatureEnabledImpl(Features, "sse", true); setFeatureEnabledImpl(Features, "3dnowa", true); setFeatureEnabledImpl(Features, "fxsr", true); break; case CK_K8: - case CK_Opteron: - case CK_Athlon64: - case CK_AthlonFX: setFeatureEnabledImpl(Features, "sse2", true); setFeatureEnabledImpl(Features, "3dnowa", true); setFeatureEnabledImpl(Features, "fxsr", true); @@ -290,8 +282,6 @@ bool X86TargetInfo::initFeatureMap( setFeatureEnabledImpl(Features, "popcnt", true); LLVM_FALLTHROUGH; case CK_K8SSE3: - case CK_OpteronSSE3: - case CK_Athlon64SSE3: setFeatureEnabledImpl(Features, "sse3", true); setFeatureEnabledImpl(Features, "3dnowa", true); setFeatureEnabledImpl(Features, "fxsr", true); @@ -807,7 +797,6 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts, defineCPUMacros(Builder, "pentium"); break; case CK_Pentium3: - case CK_Pentium3M: case CK_PentiumM: Builder.defineMacro("__tune_pentium3__"); LLVM_FALLTHROUGH; @@ -827,7 +816,6 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts, Builder.defineMacro("__pentiumpro__"); break; case CK_Pentium4: - case CK_Pentium4M: defineCPUMacros(Builder, "pentium4"); break; case CK_Yonah: @@ -888,10 +876,7 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts, defineCPUMacros(Builder, "k6"); break; case CK_Athlon: - case CK_AthlonThunderbird: - case CK_Athlon4: case CK_AthlonXP: - case CK_AthlonMP: defineCPUMacros(Builder, "athlon"); if (SSELevel != NoSSE) { Builder.defineMacro("__athlon_sse__"); @@ -901,11 +886,6 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts, case CK_K8: case CK_K8SSE3: case CK_x86_64: - case CK_Opteron: - case CK_OpteronSSE3: - case CK_Athlon64: - case CK_Athlon64SSE3: - case CK_AthlonFX: defineCPUMacros(Builder, "k8"); break; case CK_AMDFAM10: @@ -1553,55 +1533,37 @@ X86TargetInfo::CPUKind X86TargetInfo::getCPUKind(StringRef CPU) const { .Case("i686", CK_i686) .Case("pentiumpro", CK_PentiumPro) .Case("pentium2", CK_Pentium2) - .Case("pentium3", CK_Pentium3) - .Case("pentium3m", CK_Pentium3M) + .Cases("pentium3", "pentium3m", CK_Pentium3) .Case("pentium-m", CK_PentiumM) .Case("c3-2", CK_C3_2) .Case("yonah", CK_Yonah) - .Case("pentium4", CK_Pentium4) - .Case("pentium4m", CK_Pentium4M) + .Cases("pentium4", "pentium4m", CK_Pentium4) .Case("prescott", CK_Prescott) .Case("nocona", CK_Nocona) .Case("core2", CK_Core2) .Case("penryn", CK_Penryn) - .Case("bonnell", CK_Bonnell) - .Case("atom", CK_Bonnell) // Legacy name. - .Case("silvermont", CK_Silvermont) - .Case("slm", CK_Silvermont) // Legacy name. + .Cases("bonnell", "atom", CK_Bonnell) + .Cases("silvermont", "slm", CK_Silvermont) .Case("goldmont", CK_Goldmont) - .Case("nehalem", CK_Nehalem) - .Case("corei7", CK_Nehalem) // Legacy name. + .Cases("nehalem", "corei7", CK_Nehalem) .Case("westmere", CK_Westmere) - .Case("sandybridge", CK_SandyBridge) - .Case("corei7-avx", CK_SandyBridge) // Legacy name. - .Case("ivybridge", CK_IvyBridge) - .Case("core-avx-i", CK_IvyBridge) // Legacy name. - .Case("haswell", CK_Haswell) - .Case("core-avx2", CK_Haswell) // Legacy name. + .Cases("sandybridge", "corei7-avx", CK_SandyBridge) + .Cases("ivybridge", "core-avx-i", CK_IvyBridge) + .Cases("haswell", "core-avx2", CK_Haswell) .Case("broadwell", CK_Broadwell) .Case("skylake", CK_SkylakeClient) - .Case("skylake-avx512", CK_SkylakeServer) - .Case("skx", CK_SkylakeServer) // Legacy name. + .Cases("skylake-avx512", "skx", CK_SkylakeServer) .Case("cannonlake", CK_Cannonlake) .Case("knl", CK_KNL) .Case("lakemont", CK_Lakemont) .Case("k6", CK_K6) .Case("k6-2", CK_K6_2) .Case("k6-3", CK_K6_3) - .Case("athlon", CK_Athlon) - .Case("athlon-tbird", CK_AthlonThunderbird) - .Case("athlon-4", CK_Athlon4) - .Case("athlon-xp", CK_AthlonXP) - .Case("athlon-mp", CK_AthlonMP) - .Case("athlon64", CK_Athlon64) - .Case("athlon64-sse3", CK_Athlon64SSE3) - .Case("athlon-fx", CK_AthlonFX) - .Case("k8", CK_K8) - .Case("k8-sse3", CK_K8SSE3) - .Case("opteron", CK_Opteron) - .Case("opteron-sse3", CK_OpteronSSE3) - .Case("barcelona", CK_AMDFAM10) - .Case("amdfam10", CK_AMDFAM10) + .Cases("athlon", "athlon-tbird", CK_Athlon) + .Cases("athlon-xp", "athlon-mp", "athlon-4", CK_AthlonXP) + .Cases("k8", "athlon64", "athlon-fx", "opteron", CK_K8) + .Cases("k8-sse3", "athlon64-sse3", "opteron-sse3", CK_K8SSE3) + .Cases("amdfam10", "barcelona", CK_AMDFAM10) .Case("btver1", CK_BTVER1) .Case("btver2", CK_BTVER2) .Case("bdver1", CK_BDVER1) diff --git a/lib/Basic/Targets/X86.h b/lib/Basic/Targets/X86.h index c3e2cdb357..21ae4ff4e6 100644 --- a/lib/Basic/Targets/X86.h +++ b/lib/Basic/Targets/X86.h @@ -126,7 +126,6 @@ class LLVM_LIBRARY_VISIBILITY X86TargetInfo : public TargetInfo { CK_PentiumPro, CK_Pentium2, CK_Pentium3, - CK_Pentium3M, CK_PentiumM, CK_C3_2, @@ -140,7 +139,6 @@ class LLVM_LIBRARY_VISIBILITY X86TargetInfo : public TargetInfo { /// Netburst microarchitecture based processors. //@{ CK_Pentium4, - CK_Pentium4M, CK_Prescott, CK_Nocona, //@} @@ -221,22 +219,14 @@ class LLVM_LIBRARY_VISIBILITY X86TargetInfo : public TargetInfo { /// K7 architecture processors. //@{ CK_Athlon, - CK_AthlonThunderbird, - CK_Athlon4, CK_AthlonXP, - CK_AthlonMP, //@} /// \name K8 /// K8 architecture processors. //@{ - CK_Athlon64, - CK_Athlon64SSE3, - CK_AthlonFX, CK_K8, CK_K8SSE3, - CK_Opteron, - CK_OpteronSSE3, CK_AMDFAM10, //@} @@ -298,22 +288,17 @@ class LLVM_LIBRARY_VISIBILITY X86TargetInfo : public TargetInfo { case CK_PentiumPro: case CK_Pentium2: case CK_Pentium3: - case CK_Pentium3M: case CK_PentiumM: case CK_Yonah: case CK_C3_2: case CK_Pentium4: - case CK_Pentium4M: case CK_Lakemont: case CK_Prescott: case CK_K6: case CK_K6_2: case CK_K6_3: case CK_Athlon: - case CK_AthlonThunderbird: - case CK_Athlon4: case CK_AthlonXP: - case CK_AthlonMP: case CK_Geode: // Only accept certain architectures when compiling in 32-bit mode. if (getTriple().getArch() != llvm::Triple::x86) @@ -336,13 +321,8 @@ class LLVM_LIBRARY_VISIBILITY X86TargetInfo : public TargetInfo { case CK_SkylakeServer: case CK_Cannonlake: case CK_KNL: - case CK_Athlon64: - case CK_Athlon64SSE3: - case CK_AthlonFX: case CK_K8: case CK_K8SSE3: - case CK_Opteron: - case CK_OpteronSSE3: case CK_AMDFAM10: case CK_BTVER1: case CK_BTVER2: -- 2.40.0