Index: cfe/trunk/lib/Basic/Targets.cpp =================================================================== --- cfe/trunk/lib/Basic/Targets.cpp +++ cfe/trunk/lib/Basic/Targets.cpp @@ -2663,6 +2663,12 @@ CK_BDVER4, //@} + /// \name zen + /// Zen architecture processors. + //@{ + CK_ZNVER1, + //@} + /// This specification is deprecated and will be removed in the future. /// Users should prefer \see CK_K8. // FIXME: Warn on this when the CPU is set to it. @@ -2744,6 +2750,7 @@ .Case("bdver2", CK_BDVER2) .Case("bdver3", CK_BDVER3) .Case("bdver4", CK_BDVER4) + .Case("znver1", CK_ZNVER1) .Case("x86-64", CK_x86_64) .Case("geode", CK_Geode) .Default(CK_Generic); @@ -2943,6 +2950,7 @@ case CK_BDVER2: case CK_BDVER3: case CK_BDVER4: + case CK_ZNVER1: case CK_x86_64: return true; } @@ -3190,6 +3198,33 @@ setFeatureEnabledImpl(Features, "cx16", true); setFeatureEnabledImpl(Features, "fxsr", true); break; + case CK_ZNVER1: + setFeatureEnabledImpl(Features, "adx", true); + setFeatureEnabledImpl(Features, "aes", true); + setFeatureEnabledImpl(Features, "avx2", true); + setFeatureEnabledImpl(Features, "bmi", true); + setFeatureEnabledImpl(Features, "bmi2", true); + setFeatureEnabledImpl(Features, "clflushopt", true); + setFeatureEnabledImpl(Features, "cx16", true); + setFeatureEnabledImpl(Features, "f16c", true); + setFeatureEnabledImpl(Features, "fma", true); + setFeatureEnabledImpl(Features, "fsgsbase", true); + setFeatureEnabledImpl(Features, "fxsr", true); + setFeatureEnabledImpl(Features, "lzcnt", true); + setFeatureEnabledImpl(Features, "mwaitx", true); + setFeatureEnabledImpl(Features, "movbe", true); + setFeatureEnabledImpl(Features, "pclmul", true); + setFeatureEnabledImpl(Features, "popcnt", true); + setFeatureEnabledImpl(Features, "prfchw", true); + setFeatureEnabledImpl(Features, "rdrnd", true); + setFeatureEnabledImpl(Features, "rdseed", true); + setFeatureEnabledImpl(Features, "sha", true); + setFeatureEnabledImpl(Features, "sse4a", true); + setFeatureEnabledImpl(Features, "xsave", true); + setFeatureEnabledImpl(Features, "xsavec", true); + setFeatureEnabledImpl(Features, "xsaveopt", true); + setFeatureEnabledImpl(Features, "xsaves", true); + break; case CK_BDVER4: setFeatureEnabledImpl(Features, "avx2", true); setFeatureEnabledImpl(Features, "bmi2", true); @@ -3741,6 +3776,9 @@ case CK_BDVER4: defineCPUMacros(Builder, "bdver4"); break; + case CK_ZNVER1: + defineCPUMacros(Builder, "znver1"); + break; case CK_Geode: defineCPUMacros(Builder, "geode"); break; Index: cfe/trunk/test/Driver/x86-march.c =================================================================== --- cfe/trunk/test/Driver/x86-march.c +++ cfe/trunk/test/Driver/x86-march.c @@ -103,3 +103,7 @@ // RUN: %clang -target x86_64-unknown-unknown -c -### %s -march=btver2 2>&1 \ // RUN: | FileCheck %s -check-prefix=btver2 // btver2: "-target-cpu" "btver2" +// +// RUN: %clang -target x86_64-unknown-unknown -c -### %s -march=znver1 2>&1 \ +// RUN: | FileCheck %s -check-prefix=znver1 +// znver1: "-target-cpu" "znver1" Index: cfe/trunk/test/Frontend/x86-target-cpu.c =================================================================== --- cfe/trunk/test/Frontend/x86-target-cpu.c +++ cfe/trunk/test/Frontend/x86-target-cpu.c @@ -26,5 +26,6 @@ // RUN: %clang_cc1 -triple x86_64-unknown-unknown -target-cpu bdver4 -verify %s // RUN: %clang_cc1 -triple x86_64-unknown-unknown -target-cpu btver1 -verify %s // RUN: %clang_cc1 -triple x86_64-unknown-unknown -target-cpu btver2 -verify %s +// RUN: %clang_cc1 -triple x86_64-unknown-unknown -target-cpu znver1 -verify %s // // expected-no-diagnostics Index: cfe/trunk/test/Preprocessor/predefined-arch-macros.c =================================================================== --- cfe/trunk/test/Preprocessor/predefined-arch-macros.c +++ cfe/trunk/test/Preprocessor/predefined-arch-macros.c @@ -1849,6 +1849,88 @@ // CHECK_BDVER4_M64: #define __tune_bdver4__ 1 // CHECK_BDVER4_M64: #define __x86_64 1 // CHECK_BDVER4_M64: #define __x86_64__ 1 +// RUN: %clang -march=znver1 -m32 -E -dM %s -o - 2>&1 \ +// RUN: -target i386-unknown-linux \ +// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M32 +// CHECK_ZNVER1_M32-NOT: #define __3dNOW_A__ 1 +// CHECK_ZNVER1_M32-NOT: #define __3dNOW__ 1 +// CHECK_ZNVER1_M32: #define __ADX__ 1 +// CHECK_ZNVER1_M32: #define __AES__ 1 +// CHECK_ZNVER1_M32: #define __AVX2__ 1 +// CHECK_ZNVER1_M32: #define __AVX__ 1 +// CHECK_ZNVER1_M32: #define __BMI2__ 1 +// CHECK_ZNVER1_M32: #define __BMI__ 1 +// CHECK_ZNVER1_M32: #define __F16C__ 1 +// CHECK_ZNVER1_M32: #define __FMA__ 1 +// CHECK_ZNVER1_M32: #define __FSGSBASE__ 1 +// CHECK_ZNVER1_M32: #define __LZCNT__ 1 +// CHECK_ZNVER1_M32: #define __MMX__ 1 +// CHECK_ZNVER1_M32: #define __PCLMUL__ 1 +// CHECK_ZNVER1_M32: #define __POPCNT__ 1 +// CHECK_ZNVER1_M32: #define __PRFCHW__ 1 +// CHECK_ZNVER1_M32: #define __RDRND__ 1 +// CHECK_ZNVER1_M32: #define __RDSEED__ 1 +// CHECK_ZNVER1_M32: #define __SHA__ 1 +// CHECK_ZNVER1_M32: #define __SSE2_MATH__ 1 +// CHECK_ZNVER1_M32: #define __SSE2__ 1 +// CHECK_ZNVER1_M32: #define __SSE3__ 1 +// CHECK_ZNVER1_M32: #define __SSE4A__ 1 +// CHECK_ZNVER1_M32: #define __SSE4_1__ 1 +// CHECK_ZNVER1_M32: #define __SSE4_2__ 1 +// CHECK_ZNVER1_M32: #define __SSE_MATH__ 1 +// CHECK_ZNVER1_M32: #define __SSE__ 1 +// CHECK_ZNVER1_M32: #define __SSSE3__ 1 +// CHECK_ZNVER1_M32: #define __XSAVEC__ 1 +// CHECK_ZNVER1_M32: #define __XSAVEOPT__ 1 +// CHECK_ZNVER1_M32: #define __XSAVES__ 1 +// CHECK_ZNVER1_M32: #define __XSAVE__ 1 +// CHECK_ZNVER1_M32: #define __i386 1 +// CHECK_ZNVER1_M32: #define __i386__ 1 +// CHECK_ZNVER1_M32: #define __tune_znver1__ 1 +// CHECK_ZNVER1_M32: #define __znver1 1 +// CHECK_ZNVER1_M32: #define __znver1__ 1 +// RUN: %clang -march=znver1 -m64 -E -dM %s -o - 2>&1 \ +// RUN: -target i386-unknown-linux \ +// RUN: | FileCheck -match-full-lines %s -check-prefix=CHECK_ZNVER1_M64 +// CHECK_ZNVER1_M64-NOT: #define __3dNOW_A__ 1 +// CHECK_ZNVER1_M64-NOT: #define __3dNOW__ 1 +// CHECK_ZNVER1_M64: #define __ADX__ 1 +// CHECK_ZNVER1_M64: #define __AES__ 1 +// CHECK_ZNVER1_M64: #define __AVX2__ 1 +// CHECK_ZNVER1_M64: #define __AVX__ 1 +// CHECK_ZNVER1_M64: #define __BMI2__ 1 +// CHECK_ZNVER1_M64: #define __BMI__ 1 +// CHECK_ZNVER1_M64: #define __F16C__ 1 +// CHECK_ZNVER1_M64: #define __FMA__ 1 +// CHECK_ZNVER1_M64: #define __FSGSBASE__ 1 +// CHECK_ZNVER1_M64: #define __LZCNT__ 1 +// CHECK_ZNVER1_M64: #define __MMX__ 1 +// CHECK_ZNVER1_M64: #define __PCLMUL__ 1 +// CHECK_ZNVER1_M64: #define __POPCNT__ 1 +// CHECK_ZNVER1_M64: #define __PRFCHW__ 1 +// CHECK_ZNVER1_M64: #define __RDRND__ 1 +// CHECK_ZNVER1_M64: #define __RDSEED__ 1 +// CHECK_ZNVER1_M64: #define __SHA__ 1 +// CHECK_ZNVER1_M64: #define __SSE2_MATH__ 1 +// CHECK_ZNVER1_M64: #define __SSE2__ 1 +// CHECK_ZNVER1_M64: #define __SSE3__ 1 +// CHECK_ZNVER1_M64: #define __SSE4A__ 1 +// CHECK_ZNVER1_M64: #define __SSE4_1__ 1 +// CHECK_ZNVER1_M64: #define __SSE4_2__ 1 +// CHECK_ZNVER1_M64: #define __SSE_MATH__ 1 +// CHECK_ZNVER1_M64: #define __SSE__ 1 +// CHECK_ZNVER1_M64: #define __SSSE3__ 1 +// CHECK_ZNVER1_M64: #define __XSAVEC__ 1 +// CHECK_ZNVER1_M64: #define __XSAVEOPT__ 1 +// CHECK_ZNVER1_M64: #define __XSAVES__ 1 +// CHECK_ZNVER1_M64: #define __XSAVE__ 1 +// CHECK_ZNVER1_M64: #define __amd64 1 +// CHECK_ZNVER1_M64: #define __amd64__ 1 +// CHECK_ZNVER1_M64: #define __tune_znver1__ 1 +// CHECK_ZNVER1_M64: #define __x86_64 1 +// CHECK_ZNVER1_M64: #define __x86_64__ 1 +// CHECK_ZNVER1_M64: #define __znver1 1 +// CHECK_ZNVER1_M64: #define __znver1__ 1 // // End X86/GCC/Linux tests ------------------