diff options
| author | Craig Topper <craig.topper@gmail.com> | 2013-08-22 04:32:55 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2013-08-22 04:32:55 +0000 |
| commit | 258a86802a36f9a728c28b716fdccfda78b0db33 (patch) | |
| tree | 1ff3f581be357429247cabbde7f2d6de1c61bbef | |
| parent | 5677e433d627fbcc41898162a97de7e19f787779 (diff) | |
| download | bcm5719-llvm-258a86802a36f9a728c28b716fdccfda78b0db33.tar.gz bcm5719-llvm-258a86802a36f9a728c28b716fdccfda78b0db33.zip | |
Add test cases for avx512 feature flags. Fix typo in avx512pf options.
llvm-svn: 188984
| -rw-r--r-- | clang/include/clang/Driver/Options.td | 4 | ||||
| -rw-r--r-- | clang/test/Preprocessor/x86_target_features.c | 75 |
2 files changed, 76 insertions, 3 deletions
diff --git a/clang/include/clang/Driver/Options.td b/clang/include/clang/Driver/Options.td index 5bb63cb522d..33a14a4b1bf 100644 --- a/clang/include/clang/Driver/Options.td +++ b/clang/include/clang/Driver/Options.td @@ -971,7 +971,7 @@ def mno_avx2 : Flag<["-"], "mno-avx2">, Group<m_x86_Features_Group>; def mno_avx512f : Flag<["-"], "mno-avx512f">, Group<m_x86_Features_Group>; def mno_avx512cd : Flag<["-"], "mno-avx512cd">, Group<m_x86_Features_Group>; def mno_avx512er : Flag<["-"], "mno-avx512er">, Group<m_x86_Features_Group>; -def mno_avx512pd : Flag<["-"], "mno-avx512pd">, Group<m_x86_Features_Group>; +def mno_avx512pf : Flag<["-"], "mno-avx512pf">, Group<m_x86_Features_Group>; def mno_pclmul : Flag<["-"], "mno-pclmul">, Group<m_x86_Features_Group>; def mno_lzcnt : Flag<["-"], "mno-lzcnt">, Group<m_x86_Features_Group>; def mno_rdrnd : Flag<["-"], "mno-rdrnd">, Group<m_x86_Features_Group>; @@ -1021,7 +1021,7 @@ def mavx2 : Flag<["-"], "mavx2">, Group<m_x86_Features_Group>; def mavx512f : Flag<["-"], "mavx512f">, Group<m_x86_Features_Group>; def mavx512cd : Flag<["-"], "mavx512cd">, Group<m_x86_Features_Group>; def mavx512er : Flag<["-"], "mavx512er">, Group<m_x86_Features_Group>; -def mavx512pd : Flag<["-"], "mavx512pd">, Group<m_x86_Features_Group>; +def mavx512pf : Flag<["-"], "mavx512pf">, Group<m_x86_Features_Group>; def mpclmul : Flag<["-"], "mpclmul">, Group<m_x86_Features_Group>; def mlzcnt : Flag<["-"], "mlzcnt">, Group<m_x86_Features_Group>; def mrdrnd : Flag<["-"], "mrdrnd">, Group<m_x86_Features_Group>; diff --git a/clang/test/Preprocessor/x86_target_features.c b/clang/test/Preprocessor/x86_target_features.c index 7d6a6d8a7c0..d6ddc01b53e 100644 --- a/clang/test/Preprocessor/x86_target_features.c +++ b/clang/test/Preprocessor/x86_target_features.c @@ -43,7 +43,6 @@ // AVX: #define __SSE__ 1 // AVX: #define __SSSE3__ 1 - // RUN: %clang -target i386-unknown-unknown -march=pentium-m -mxop -mno-avx -x c -E -dM -o - %s | FileCheck --check-prefix=SSE4A %s // SSE4A: #define __SSE2_MATH__ 1 @@ -55,3 +54,77 @@ // SSE4A: #define __SSE_MATH__ 1 // SSE4A: #define __SSE__ 1 // SSE4A: #define __SSSE3__ 1 + +// RUN: %clang -target i386-unknown-unknown -march=atom -mavx512f -x c -E -dM -o - %s | FileCheck --check-prefix=AVX512F %s + +// AVX512F: #define __AVX2__ 1 +// AVX512F: #define __AVX512F__ 1 +// AVX512F: #define __AVX__ 1 +// AVX512F: #define __SSE2_MATH__ 1 +// AVX512F: #define __SSE2__ 1 +// AVX512F: #define __SSE3__ 1 +// AVX512F: #define __SSE4_1__ 1 +// AVX512F: #define __SSE4_2__ 1 +// AVX512F: #define __SSE_MATH__ 1 +// AVX512F: #define __SSE__ 1 +// AVX512F: #define __SSSE3__ 1 + +// RUN: %clang -target i386-unknown-unknown -march=atom -mavx512cd -x c -E -dM -o - %s | FileCheck --check-prefix=AVX512CD %s + +// AVX512CD: #define __AVX2__ 1 +// AVX512CD: #define __AVX512CD__ 1 +// AVX512CD: #define __AVX512F__ 1 +// AVX512CD: #define __AVX__ 1 +// AVX512CD: #define __SSE2_MATH__ 1 +// AVX512CD: #define __SSE2__ 1 +// AVX512CD: #define __SSE3__ 1 +// AVX512CD: #define __SSE4_1__ 1 +// AVX512CD: #define __SSE4_2__ 1 +// AVX512CD: #define __SSE_MATH__ 1 +// AVX512CD: #define __SSE__ 1 +// AVX512CD: #define __SSSE3__ 1 + +// RUN: %clang -target i386-unknown-unknown -march=atom -mavx512er -x c -E -dM -o - %s | FileCheck --check-prefix=AVX512ER %s + +// AVX512ER: #define __AVX2__ 1 +// AVX512ER: #define __AVX512ER__ 1 +// AVX512ER: #define __AVX512F__ 1 +// AVX512ER: #define __AVX__ 1 +// AVX512ER: #define __SSE2_MATH__ 1 +// AVX512ER: #define __SSE2__ 1 +// AVX512ER: #define __SSE3__ 1 +// AVX512ER: #define __SSE4_1__ 1 +// AVX512ER: #define __SSE4_2__ 1 +// AVX512ER: #define __SSE_MATH__ 1 +// AVX512ER: #define __SSE__ 1 +// AVX512ER: #define __SSSE3__ 1 + +// RUN: %clang -target i386-unknown-unknown -march=atom -mavx512pf -x c -E -dM -o - %s | FileCheck --check-prefix=AVX512PF %s + +// AVX512PF: #define __AVX2__ 1 +// AVX512PF: #define __AVX512F__ 1 +// AVX512PF: #define __AVX512PF__ 1 +// AVX512PF: #define __AVX__ 1 +// AVX512PF: #define __SSE2_MATH__ 1 +// AVX512PF: #define __SSE2__ 1 +// AVX512PF: #define __SSE3__ 1 +// AVX512PF: #define __SSE4_1__ 1 +// AVX512PF: #define __SSE4_2__ 1 +// AVX512PF: #define __SSE_MATH__ 1 +// AVX512PF: #define __SSE__ 1 +// AVX512PF: #define __SSSE3__ 1 + +// RUN: %clang -target i386-unknown-unknown -march=atom -mavx512pf -mno-avx512f -x c -E -dM -o - %s | FileCheck --check-prefix=AVX512F2 %s + +// AVX512F2: #define __AVX2__ 1 +// AVX512F2-NOT: #define __AVX512F__ 1 +// AVX512F2-NOT: #define __AVX512PF__ 1 +// AVX512F2: #define __AVX__ 1 +// AVX512F2: #define __SSE2_MATH__ 1 +// AVX512F2: #define __SSE2__ 1 +// AVX512F2: #define __SSE3__ 1 +// AVX512F2: #define __SSE4_1__ 1 +// AVX512F2: #define __SSE4_2__ 1 +// AVX512F2: #define __SSE_MATH__ 1 +// AVX512F2: #define __SSE__ 1 +// AVX512F2: #define __SSSE3__ 1 |

