These patches are all great. Thanks Chandler! -eric
On Sep 28, 2011, at 3:36 AM, Chandler Carruth wrote: > Author: chandlerc > Date: Wed Sep 28 05:36:46 2011 > New Revision: 140692 > > URL: http://llvm.org/viewvc/llvm-project?rev=140692&view=rev > Log: > Generate tests for all of the x86 SIMD instruction feature set > predefines based on the output of GCC as well as the CPU predefines. > > Invert tests for __AVX__, Clang's AVX feature is hard coded off still. > > Switch Atom from 'SSE3' to 'SSSE3'. This matches GCC's behavior, Intel's > documentation, and ICC's documentation (such as I could dig up). > > Switch Athlon and Geode to enable 3dnowa rather than just 3dnow and > nothing (resp.). > > Modified: > cfe/trunk/lib/Basic/Targets.cpp > cfe/trunk/test/Preprocessor/predefined-arch-macros.c > > Modified: cfe/trunk/lib/Basic/Targets.cpp > URL: > http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Targets.cpp?rev=140692&r1=140691&r2=140692&view=diff > ============================================================================== > --- cfe/trunk/lib/Basic/Targets.cpp (original) > +++ cfe/trunk/lib/Basic/Targets.cpp Wed Sep 28 05:36:46 2011 > @@ -1471,7 +1471,6 @@ > case CK_Pentium: > case CK_i686: > case CK_PentiumPro: > - case CK_Geode: > break; > case CK_PentiumMMX: > case CK_Pentium2: > @@ -1506,7 +1505,7 @@ > break; > case CK_Atom: > setFeatureEnabled(Features, "mmx", true); > - setFeatureEnabled(Features, "sse3", true); > + setFeatureEnabled(Features, "ssse3", true); > break; > case CK_Corei7: > setFeatureEnabled(Features, "mmx", true); > @@ -1526,12 +1525,15 @@ > break; > case CK_K6_2: > case CK_K6_3: > - case CK_Athlon: > - case CK_AthlonThunderbird: > case CK_WinChip2: > case CK_C3: > setFeatureEnabled(Features, "3dnow", true); > break; > + case CK_Athlon: > + case CK_AthlonThunderbird: > + case CK_Geode: > + setFeatureEnabled(Features, "3dnowa", true); > + break; > case CK_Athlon4: > case CK_AthlonXP: > case CK_AthlonMP: > > Modified: cfe/trunk/test/Preprocessor/predefined-arch-macros.c > URL: > http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Preprocessor/predefined-arch-macros.c?rev=140692&r1=140691&r2=140692&view=diff > ============================================================================== > --- cfe/trunk/test/Preprocessor/predefined-arch-macros.c (original) > +++ cfe/trunk/test/Preprocessor/predefined-arch-macros.c Wed Sep 28 05:36:46 > 2011 > @@ -57,6 +57,7 @@ > // > // RUN: %clang -march=pentium-mmx -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_MMX_M32 > +// CHECK_PENTIUM_MMX_M32: #define __MMX__ 1 > // CHECK_PENTIUM_MMX_M32: #define __i386 1 > // CHECK_PENTIUM_MMX_M32: #define __i386__ 1 > // CHECK_PENTIUM_MMX_M32: #define __i586 1 > @@ -74,6 +75,7 @@ > // > // RUN: %clang -march=winchip-c6 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP_C6_M32 > +// CHECK_WINCHIP_C6_M32: #define __MMX__ 1 > // CHECK_WINCHIP_C6_M32: #define __i386 1 > // CHECK_WINCHIP_C6_M32: #define __i386__ 1 > // CHECK_WINCHIP_C6_M32: #define __i486 1 > @@ -86,6 +88,8 @@ > // > // RUN: %clang -march=winchip2 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP2_M32 > +// CHECK_WINCHIP2_M32: #define __3dNOW__ 1 > +// CHECK_WINCHIP2_M32: #define __MMX__ 1 > // CHECK_WINCHIP2_M32: #define __i386 1 > // CHECK_WINCHIP2_M32: #define __i386__ 1 > // CHECK_WINCHIP2_M32: #define __i486 1 > @@ -98,6 +102,8 @@ > // > // RUN: %clang -march=c3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_C3_M32 > +// CHECK_C3_M32: #define __3dNOW__ 1 > +// CHECK_C3_M32: #define __MMX__ 1 > // CHECK_C3_M32: #define __i386 1 > // CHECK_C3_M32: #define __i386__ 1 > // CHECK_C3_M32: #define __i486 1 > @@ -110,6 +116,8 @@ > // > // RUN: %clang -march=c3-2 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_C3_2_M32 > +// CHECK_C3_2_M32: #define __MMX__ 1 > +// CHECK_C3_2_M32: #define __SSE__ 1 > // CHECK_C3_2_M32: #define __i386 1 > // CHECK_C3_2_M32: #define __i386__ 1 > // CHECK_C3_2_M32: #define __i686 1 > @@ -154,6 +162,7 @@ > // > // RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM2_M32 > +// CHECK_PENTIUM2_M32: #define __MMX__ 1 > // CHECK_PENTIUM2_M32: #define __i386 1 > // CHECK_PENTIUM2_M32: #define __i386__ 1 > // CHECK_PENTIUM2_M32: #define __i686 1 > @@ -170,6 +179,8 @@ > // > // RUN: %clang -march=pentium3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3_M32 > +// CHECK_PENTIUM3_M32: #define __MMX__ 1 > +// CHECK_PENTIUM3_M32: #define __SSE__ 1 > // CHECK_PENTIUM3_M32: #define __i386 1 > // CHECK_PENTIUM3_M32: #define __i386__ 1 > // CHECK_PENTIUM3_M32: #define __i686 1 > @@ -187,6 +198,8 @@ > // > // RUN: %clang -march=pentium3m -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3M_M32 > +// CHECK_PENTIUM3M_M32: #define __MMX__ 1 > +// CHECK_PENTIUM3M_M32: #define __SSE__ 1 > // CHECK_PENTIUM3M_M32: #define __i386 1 > // CHECK_PENTIUM3M_M32: #define __i386__ 1 > // CHECK_PENTIUM3M_M32: #define __i686 1 > @@ -202,6 +215,9 @@ > // > // RUN: %clang -march=pentium-m -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_M_M32 > +// CHECK_PENTIUM_M_M32: #define __MMX__ 1 > +// CHECK_PENTIUM_M_M32: #define __SSE2__ 1 > +// CHECK_PENTIUM_M_M32: #define __SSE__ 1 > // CHECK_PENTIUM_M_M32: #define __i386 1 > // CHECK_PENTIUM_M_M32: #define __i386__ 1 > // CHECK_PENTIUM_M_M32: #define __i686 1 > @@ -217,6 +233,9 @@ > // > // RUN: %clang -march=pentium4 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4_M32 > +// CHECK_PENTIUM4_M32: #define __MMX__ 1 > +// CHECK_PENTIUM4_M32: #define __SSE2__ 1 > +// CHECK_PENTIUM4_M32: #define __SSE__ 1 > // CHECK_PENTIUM4_M32: #define __i386 1 > // CHECK_PENTIUM4_M32: #define __i386__ 1 > // CHECK_PENTIUM4_M32: #define __pentium4 1 > @@ -229,6 +248,9 @@ > // > // RUN: %clang -march=pentium4m -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4M_M32 > +// CHECK_PENTIUM4M_M32: #define __MMX__ 1 > +// CHECK_PENTIUM4M_M32: #define __SSE2__ 1 > +// CHECK_PENTIUM4M_M32: #define __SSE__ 1 > // CHECK_PENTIUM4M_M32: #define __i386 1 > // CHECK_PENTIUM4M_M32: #define __i386__ 1 > // CHECK_PENTIUM4M_M32: #define __pentium4 1 > @@ -241,6 +263,10 @@ > // > // RUN: %clang -march=prescott -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_PRESCOTT_M32 > +// CHECK_PRESCOTT_M32: #define __MMX__ 1 > +// CHECK_PRESCOTT_M32: #define __SSE2__ 1 > +// CHECK_PRESCOTT_M32: #define __SSE3__ 1 > +// CHECK_PRESCOTT_M32: #define __SSE__ 1 > // CHECK_PRESCOTT_M32: #define __i386 1 > // CHECK_PRESCOTT_M32: #define __i386__ 1 > // CHECK_PRESCOTT_M32: #define __nocona 1 > @@ -253,6 +279,10 @@ > // > // RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_NOCONA_M32 > +// CHECK_NOCONA_M32: #define __MMX__ 1 > +// CHECK_NOCONA_M32: #define __SSE2__ 1 > +// CHECK_NOCONA_M32: #define __SSE3__ 1 > +// CHECK_NOCONA_M32: #define __SSE__ 1 > // CHECK_NOCONA_M32: #define __i386 1 > // CHECK_NOCONA_M32: #define __i386__ 1 > // CHECK_NOCONA_M32: #define __nocona 1 > @@ -261,6 +291,12 @@ > // CHECK_NOCONA_M32: #define i386 1 > // RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_NOCONA_M64 > +// CHECK_NOCONA_M64: #define __MMX__ 1 > +// CHECK_NOCONA_M64: #define __SSE2_MATH__ 1 > +// CHECK_NOCONA_M64: #define __SSE2__ 1 > +// CHECK_NOCONA_M64: #define __SSE3__ 1 > +// CHECK_NOCONA_M64: #define __SSE_MATH__ 1 > +// CHECK_NOCONA_M64: #define __SSE__ 1 > // CHECK_NOCONA_M64: #define __amd64 1 > // CHECK_NOCONA_M64: #define __amd64__ 1 > // CHECK_NOCONA_M64: #define __nocona 1 > @@ -271,6 +307,11 @@ > // > // RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_CORE2_M32 > +// CHECK_CORE2_M32: #define __MMX__ 1 > +// CHECK_CORE2_M32: #define __SSE2__ 1 > +// CHECK_CORE2_M32: #define __SSE3__ 1 > +// CHECK_CORE2_M32: #define __SSE__ 1 > +// CHECK_CORE2_M32: #define __SSSE3__ 1 > // CHECK_CORE2_M32: #define __core2 1 > // CHECK_CORE2_M32: #define __core2__ 1 > // CHECK_CORE2_M32: #define __i386 1 > @@ -279,6 +320,13 @@ > // CHECK_CORE2_M32: #define i386 1 > // RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_CORE2_M64 > +// CHECK_CORE2_M64: #define __MMX__ 1 > +// CHECK_CORE2_M64: #define __SSE2_MATH__ 1 > +// CHECK_CORE2_M64: #define __SSE2__ 1 > +// CHECK_CORE2_M64: #define __SSE3__ 1 > +// CHECK_CORE2_M64: #define __SSE_MATH__ 1 > +// CHECK_CORE2_M64: #define __SSE__ 1 > +// CHECK_CORE2_M64: #define __SSSE3__ 1 > // CHECK_CORE2_M64: #define __amd64 1 > // CHECK_CORE2_M64: #define __amd64__ 1 > // CHECK_CORE2_M64: #define __core2 1 > @@ -289,6 +337,13 @@ > // > // RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_M32 > +// CHECK_COREI7_M32: #define __MMX__ 1 > +// CHECK_COREI7_M32: #define __SSE2__ 1 > +// CHECK_COREI7_M32: #define __SSE3__ 1 > +// CHECK_COREI7_M32: #define __SSE4_1__ 1 > +// CHECK_COREI7_M32: #define __SSE4_2__ 1 > +// CHECK_COREI7_M32: #define __SSE__ 1 > +// CHECK_COREI7_M32: #define __SSSE3__ 1 > // CHECK_COREI7_M32: #define __corei7 1 > // CHECK_COREI7_M32: #define __corei7__ 1 > // CHECK_COREI7_M32: #define __i386 1 > @@ -297,6 +352,15 @@ > // CHECK_COREI7_M32: #define i386 1 > // RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_M64 > +// CHECK_COREI7_M64: #define __MMX__ 1 > +// CHECK_COREI7_M64: #define __SSE2_MATH__ 1 > +// CHECK_COREI7_M64: #define __SSE2__ 1 > +// CHECK_COREI7_M64: #define __SSE3__ 1 > +// CHECK_COREI7_M64: #define __SSE4_1__ 1 > +// CHECK_COREI7_M64: #define __SSE4_2__ 1 > +// CHECK_COREI7_M64: #define __SSE_MATH__ 1 > +// CHECK_COREI7_M64: #define __SSE__ 1 > +// CHECK_COREI7_M64: #define __SSSE3__ 1 > // CHECK_COREI7_M64: #define __amd64 1 > // CHECK_COREI7_M64: #define __amd64__ 1 > // CHECK_COREI7_M64: #define __corei7 1 > @@ -307,6 +371,16 @@ > // > // RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M32 > +// CHECK_COREI7_AVX_M32: #define __AES__ 1 > +// FIXME: AVX is not yet enabled with Clang. > +// CHECK_COREI7_AVX_M32-NOT: #define __AVX__ 1 > +// CHECK_COREI7_AVX_M32: #define __MMX__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSE2__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSE3__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSE__ 1 > +// CHECK_COREI7_AVX_M32: #define __SSSE3__ 1 > // CHECK_COREI7_AVX_M32: #define __corei7 1 > // CHECK_COREI7_AVX_M32: #define __corei7__ 1 > // CHECK_COREI7_AVX_M32: #define __i386 1 > @@ -315,6 +389,18 @@ > // CHECK_COREI7_AVX_M32: #define i386 1 > // RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M64 > +// CHECK_COREI7_AVX_M64: #define __AES__ 1 > +// FIXME: AVX is not yet enabled with Clang. > +// CHECK_COREI7_AVX_M64-NOT: #define __AVX__ 1 > +// CHECK_COREI7_AVX_M64: #define __MMX__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE2__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE3__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSE__ 1 > +// CHECK_COREI7_AVX_M64: #define __SSSE3__ 1 > // CHECK_COREI7_AVX_M64: #define __amd64 1 > // CHECK_COREI7_AVX_M64: #define __amd64__ 1 > // CHECK_COREI7_AVX_M64: #define __corei7 1 > @@ -325,6 +411,16 @@ > // > // RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M32 > +// CHECK_CORE_AVX_I_M32: #define __AES__ 1 > +// FIXME: AVX is not yet enabled with Clang. > +// CHECK_CORE_AVX_I_M32-NOT: #define __AVX__ 1 > +// CHECK_CORE_AVX_I_M32: #define __MMX__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSE2__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSE3__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSE__ 1 > +// CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1 > // CHECK_CORE_AVX_I_M32: #define __corei7 1 > // CHECK_CORE_AVX_I_M32: #define __corei7__ 1 > // CHECK_CORE_AVX_I_M32: #define __i386 1 > @@ -333,6 +429,18 @@ > // CHECK_CORE_AVX_I_M32: #define i386 1 > // RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M64 > +// CHECK_CORE_AVX_I_M64: #define __AES__ 1 > +// FIXME: AVX is not yet enabled with Clang. > +// CHECK_CORE_AVX_I_M64-NOT: #define __AVX__ 1 > +// CHECK_CORE_AVX_I_M64: #define __MMX__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE2__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE3__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSE__ 1 > +// CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1 > // CHECK_CORE_AVX_I_M64: #define __amd64 1 > // CHECK_CORE_AVX_I_M64: #define __amd64__ 1 > // CHECK_CORE_AVX_I_M64: #define __corei7 1 > @@ -343,6 +451,11 @@ > // > // RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATOM_M32 > +// CHECK_ATOM_M32: #define __MMX__ 1 > +// CHECK_ATOM_M32: #define __SSE2__ 1 > +// CHECK_ATOM_M32: #define __SSE3__ 1 > +// CHECK_ATOM_M32: #define __SSE__ 1 > +// CHECK_ATOM_M32: #define __SSSE3__ 1 > // CHECK_ATOM_M32: #define __atom 1 > // CHECK_ATOM_M32: #define __atom__ 1 > // CHECK_ATOM_M32: #define __i386 1 > @@ -351,6 +464,13 @@ > // CHECK_ATOM_M32: #define i386 1 > // RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATOM_M64 > +// CHECK_ATOM_M64: #define __MMX__ 1 > +// CHECK_ATOM_M64: #define __SSE2_MATH__ 1 > +// CHECK_ATOM_M64: #define __SSE2__ 1 > +// CHECK_ATOM_M64: #define __SSE3__ 1 > +// CHECK_ATOM_M64: #define __SSE_MATH__ 1 > +// CHECK_ATOM_M64: #define __SSE__ 1 > +// CHECK_ATOM_M64: #define __SSSE3__ 1 > // CHECK_ATOM_M64: #define __amd64 1 > // CHECK_ATOM_M64: #define __amd64__ 1 > // CHECK_ATOM_M64: #define __atom 1 > @@ -361,6 +481,9 @@ > // > // RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_GEODE_M32 > +// CHECK_GEODE_M32: #define __3dNOW_A__ 1 > +// CHECK_GEODE_M32: #define __3dNOW__ 1 > +// CHECK_GEODE_M32: #define __MMX__ 1 > // CHECK_GEODE_M32: #define __geode 1 > // CHECK_GEODE_M32: #define __geode__ 1 > // CHECK_GEODE_M32: #define __i386 1 > @@ -373,6 +496,7 @@ > // > // RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K6_M32 > +// CHECK_K6_M32: #define __MMX__ 1 > // CHECK_K6_M32: #define __i386 1 > // CHECK_K6_M32: #define __i386__ 1 > // CHECK_K6_M32: #define __k6 1 > @@ -385,6 +509,8 @@ > // > // RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K6_2_M32 > +// CHECK_K6_2_M32: #define __3dNOW__ 1 > +// CHECK_K6_2_M32: #define __MMX__ 1 > // CHECK_K6_2_M32: #define __i386 1 > // CHECK_K6_2_M32: #define __i386__ 1 > // CHECK_K6_2_M32: #define __k6 1 > @@ -399,6 +525,8 @@ > // > // RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K6_3_M32 > +// CHECK_K6_3_M32: #define __3dNOW__ 1 > +// CHECK_K6_3_M32: #define __MMX__ 1 > // CHECK_K6_3_M32: #define __i386 1 > // CHECK_K6_3_M32: #define __i386__ 1 > // CHECK_K6_3_M32: #define __k6 1 > @@ -413,6 +541,9 @@ > // > // RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_M32 > +// CHECK_ATHLON_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_M32: #define __MMX__ 1 > // CHECK_ATHLON_M32: #define __athlon 1 > // CHECK_ATHLON_M32: #define __athlon__ 1 > // CHECK_ATHLON_M32: #define __i386 1 > @@ -425,6 +556,9 @@ > // > // RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_TBIRD_M32 > +// CHECK_ATHLON_TBIRD_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_TBIRD_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1 > // CHECK_ATHLON_TBIRD_M32: #define __athlon 1 > // CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1 > // CHECK_ATHLON_TBIRD_M32: #define __i386 1 > @@ -437,6 +571,10 @@ > // > // RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_4_M32 > +// CHECK_ATHLON_4_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_4_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_4_M32: #define __MMX__ 1 > +// CHECK_ATHLON_4_M32: #define __SSE__ 1 > // CHECK_ATHLON_4_M32: #define __athlon 1 > // CHECK_ATHLON_4_M32: #define __athlon__ 1 > // CHECK_ATHLON_4_M32: #define __athlon_sse__ 1 > @@ -451,6 +589,10 @@ > // > // RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_XP_M32 > +// CHECK_ATHLON_XP_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_XP_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_XP_M32: #define __MMX__ 1 > +// CHECK_ATHLON_XP_M32: #define __SSE__ 1 > // CHECK_ATHLON_XP_M32: #define __athlon 1 > // CHECK_ATHLON_XP_M32: #define __athlon__ 1 > // CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1 > @@ -465,6 +607,10 @@ > // > // RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_MP_M32 > +// CHECK_ATHLON_MP_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_MP_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_MP_M32: #define __MMX__ 1 > +// CHECK_ATHLON_MP_M32: #define __SSE__ 1 > // CHECK_ATHLON_MP_M32: #define __athlon 1 > // CHECK_ATHLON_MP_M32: #define __athlon__ 1 > // CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1 > @@ -479,6 +625,9 @@ > // > // RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_X86_64_M32 > +// CHECK_X86_64_M32: #define __MMX__ 1 > +// CHECK_X86_64_M32: #define __SSE2__ 1 > +// CHECK_X86_64_M32: #define __SSE__ 1 > // CHECK_X86_64_M32: #define __i386 1 > // CHECK_X86_64_M32: #define __i386__ 1 > // CHECK_X86_64_M32: #define __k8 1 > @@ -486,6 +635,11 @@ > // CHECK_X86_64_M32: #define i386 1 > // RUN: %clang -march=x86-64 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_X86_64_M64 > +// CHECK_X86_64_M64: #define __MMX__ 1 > +// CHECK_X86_64_M64: #define __SSE2_MATH__ 1 > +// CHECK_X86_64_M64: #define __SSE2__ 1 > +// CHECK_X86_64_M64: #define __SSE_MATH__ 1 > +// CHECK_X86_64_M64: #define __SSE__ 1 > // CHECK_X86_64_M64: #define __amd64 1 > // CHECK_X86_64_M64: #define __amd64__ 1 > // CHECK_X86_64_M64: #define __k8 1 > @@ -495,6 +649,11 @@ > // > // RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K8_M32 > +// CHECK_K8_M32: #define __3dNOW_A__ 1 > +// CHECK_K8_M32: #define __3dNOW__ 1 > +// CHECK_K8_M32: #define __MMX__ 1 > +// CHECK_K8_M32: #define __SSE2__ 1 > +// CHECK_K8_M32: #define __SSE__ 1 > // CHECK_K8_M32: #define __i386 1 > // CHECK_K8_M32: #define __i386__ 1 > // CHECK_K8_M32: #define __k8 1 > @@ -503,6 +662,13 @@ > // CHECK_K8_M32: #define i386 1 > // RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K8_M64 > +// CHECK_K8_M64: #define __3dNOW_A__ 1 > +// CHECK_K8_M64: #define __3dNOW__ 1 > +// CHECK_K8_M64: #define __MMX__ 1 > +// CHECK_K8_M64: #define __SSE2_MATH__ 1 > +// CHECK_K8_M64: #define __SSE2__ 1 > +// CHECK_K8_M64: #define __SSE_MATH__ 1 > +// CHECK_K8_M64: #define __SSE__ 1 > // CHECK_K8_M64: #define __amd64 1 > // CHECK_K8_M64: #define __amd64__ 1 > // CHECK_K8_M64: #define __k8 1 > @@ -513,6 +679,12 @@ > // > // RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K8_SSE3_M32 > +// CHECK_K8_SSE3_M32: #define __3dNOW_A__ 1 > +// CHECK_K8_SSE3_M32: #define __3dNOW__ 1 > +// CHECK_K8_SSE3_M32: #define __MMX__ 1 > +// CHECK_K8_SSE3_M32: #define __SSE2__ 1 > +// CHECK_K8_SSE3_M32: #define __SSE3__ 1 > +// CHECK_K8_SSE3_M32: #define __SSE__ 1 > // CHECK_K8_SSE3_M32: #define __i386 1 > // CHECK_K8_SSE3_M32: #define __i386__ 1 > // CHECK_K8_SSE3_M32: #define __k8 1 > @@ -521,6 +693,14 @@ > // CHECK_K8_SSE3_M32: #define i386 1 > // RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_K8_SSE3_M64 > +// CHECK_K8_SSE3_M64: #define __3dNOW_A__ 1 > +// CHECK_K8_SSE3_M64: #define __3dNOW__ 1 > +// CHECK_K8_SSE3_M64: #define __MMX__ 1 > +// CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1 > +// CHECK_K8_SSE3_M64: #define __SSE2__ 1 > +// CHECK_K8_SSE3_M64: #define __SSE3__ 1 > +// CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1 > +// CHECK_K8_SSE3_M64: #define __SSE__ 1 > // CHECK_K8_SSE3_M64: #define __amd64 1 > // CHECK_K8_SSE3_M64: #define __amd64__ 1 > // CHECK_K8_SSE3_M64: #define __k8 1 > @@ -531,6 +711,11 @@ > // > // RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_M32 > +// CHECK_OPTERON_M32: #define __3dNOW_A__ 1 > +// CHECK_OPTERON_M32: #define __3dNOW__ 1 > +// CHECK_OPTERON_M32: #define __MMX__ 1 > +// CHECK_OPTERON_M32: #define __SSE2__ 1 > +// CHECK_OPTERON_M32: #define __SSE__ 1 > // CHECK_OPTERON_M32: #define __i386 1 > // CHECK_OPTERON_M32: #define __i386__ 1 > // CHECK_OPTERON_M32: #define __k8 1 > @@ -539,6 +724,13 @@ > // CHECK_OPTERON_M32: #define i386 1 > // RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_M64 > +// CHECK_OPTERON_M64: #define __3dNOW_A__ 1 > +// CHECK_OPTERON_M64: #define __3dNOW__ 1 > +// CHECK_OPTERON_M64: #define __MMX__ 1 > +// CHECK_OPTERON_M64: #define __SSE2_MATH__ 1 > +// CHECK_OPTERON_M64: #define __SSE2__ 1 > +// CHECK_OPTERON_M64: #define __SSE_MATH__ 1 > +// CHECK_OPTERON_M64: #define __SSE__ 1 > // CHECK_OPTERON_M64: #define __amd64 1 > // CHECK_OPTERON_M64: #define __amd64__ 1 > // CHECK_OPTERON_M64: #define __k8 1 > @@ -549,6 +741,12 @@ > // > // RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M32 > +// CHECK_OPTERON_SSE3_M32: #define __3dNOW_A__ 1 > +// CHECK_OPTERON_SSE3_M32: #define __3dNOW__ 1 > +// CHECK_OPTERON_SSE3_M32: #define __MMX__ 1 > +// CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1 > +// CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1 > +// CHECK_OPTERON_SSE3_M32: #define __SSE__ 1 > // CHECK_OPTERON_SSE3_M32: #define __i386 1 > // CHECK_OPTERON_SSE3_M32: #define __i386__ 1 > // CHECK_OPTERON_SSE3_M32: #define __k8 1 > @@ -557,6 +755,14 @@ > // CHECK_OPTERON_SSE3_M32: #define i386 1 > // RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M64 > +// CHECK_OPTERON_SSE3_M64: #define __3dNOW_A__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __3dNOW__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __MMX__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1 > +// CHECK_OPTERON_SSE3_M64: #define __SSE__ 1 > // CHECK_OPTERON_SSE3_M64: #define __amd64 1 > // CHECK_OPTERON_SSE3_M64: #define __amd64__ 1 > // CHECK_OPTERON_SSE3_M64: #define __k8 1 > @@ -567,6 +773,11 @@ > // > // RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_M32 > +// CHECK_ATHLON64_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON64_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON64_M32: #define __MMX__ 1 > +// CHECK_ATHLON64_M32: #define __SSE2__ 1 > +// CHECK_ATHLON64_M32: #define __SSE__ 1 > // CHECK_ATHLON64_M32: #define __i386 1 > // CHECK_ATHLON64_M32: #define __i386__ 1 > // CHECK_ATHLON64_M32: #define __k8 1 > @@ -575,6 +786,13 @@ > // CHECK_ATHLON64_M32: #define i386 1 > // RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_M64 > +// CHECK_ATHLON64_M64: #define __3dNOW_A__ 1 > +// CHECK_ATHLON64_M64: #define __3dNOW__ 1 > +// CHECK_ATHLON64_M64: #define __MMX__ 1 > +// CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1 > +// CHECK_ATHLON64_M64: #define __SSE2__ 1 > +// CHECK_ATHLON64_M64: #define __SSE_MATH__ 1 > +// CHECK_ATHLON64_M64: #define __SSE__ 1 > // CHECK_ATHLON64_M64: #define __amd64 1 > // CHECK_ATHLON64_M64: #define __amd64__ 1 > // CHECK_ATHLON64_M64: #define __k8 1 > @@ -585,6 +803,12 @@ > // > // RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M32 > +// CHECK_ATHLON64_SSE3_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON64_SSE3_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1 > +// CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1 > +// CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1 > +// CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1 > // CHECK_ATHLON64_SSE3_M32: #define __i386 1 > // CHECK_ATHLON64_SSE3_M32: #define __i386__ 1 > // CHECK_ATHLON64_SSE3_M32: #define __k8 1 > @@ -593,6 +817,14 @@ > // CHECK_ATHLON64_SSE3_M32: #define i386 1 > // RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M64 > +// CHECK_ATHLON64_SSE3_M64: #define __3dNOW_A__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __3dNOW__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1 > +// CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1 > // CHECK_ATHLON64_SSE3_M64: #define __amd64 1 > // CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1 > // CHECK_ATHLON64_SSE3_M64: #define __k8 1 > @@ -603,6 +835,11 @@ > // > // RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M32 > +// CHECK_ATHLON_FX_M32: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_FX_M32: #define __3dNOW__ 1 > +// CHECK_ATHLON_FX_M32: #define __MMX__ 1 > +// CHECK_ATHLON_FX_M32: #define __SSE2__ 1 > +// CHECK_ATHLON_FX_M32: #define __SSE__ 1 > // CHECK_ATHLON_FX_M32: #define __i386 1 > // CHECK_ATHLON_FX_M32: #define __i386__ 1 > // CHECK_ATHLON_FX_M32: #define __k8 1 > @@ -611,6 +848,13 @@ > // CHECK_ATHLON_FX_M32: #define i386 1 > // RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \ > // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M64 > +// CHECK_ATHLON_FX_M64: #define __3dNOW_A__ 1 > +// CHECK_ATHLON_FX_M64: #define __3dNOW__ 1 > +// CHECK_ATHLON_FX_M64: #define __MMX__ 1 > +// CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1 > +// CHECK_ATHLON_FX_M64: #define __SSE2__ 1 > +// CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1 > +// CHECK_ATHLON_FX_M64: #define __SSE__ 1 > // CHECK_ATHLON_FX_M64: #define __amd64 1 > // CHECK_ATHLON_FX_M64: #define __amd64__ 1 > // CHECK_ATHLON_FX_M64: #define __k8 1 > > > _______________________________________________ > cfe-commits mailing list > [email protected] > http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits _______________________________________________ cfe-commits mailing list [email protected] http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
