1 // Begin X86/GCC/Linux tests ---------------- 2 // 3 // RUN: %clang -march=i386 -m32 -E -dM %s -o - 2>&1 \ 4 // RUN: -target i386-unknown-linux \ 5 // RUN: | FileCheck %s -check-prefix=CHECK_I386_M32 6 // CHECK_I386_M32: #define __i386 1 7 // CHECK_I386_M32: #define __i386__ 1 8 // CHECK_I386_M32: #define __tune_i386__ 1 9 // CHECK_I386_M32: #define i386 1 10 // RUN: not %clang -march=i386 -m64 -E -dM %s -o - 2>&1 \ 11 // RUN: -target i386-unknown-linux \ 12 // RUN: | FileCheck %s -check-prefix=CHECK_I386_M64 13 // CHECK_I386_M64: error: 14 // 15 // RUN: %clang -march=i486 -m32 -E -dM %s -o - 2>&1 \ 16 // RUN: -target i386-unknown-linux \ 17 // RUN: | FileCheck %s -check-prefix=CHECK_I486_M32 18 // CHECK_I486_M32: #define __i386 1 19 // CHECK_I486_M32: #define __i386__ 1 20 // CHECK_I486_M32: #define __i486 1 21 // CHECK_I486_M32: #define __i486__ 1 22 // CHECK_I486_M32: #define __tune_i486__ 1 23 // CHECK_I486_M32: #define i386 1 24 // RUN: not %clang -march=i486 -m64 -E -dM %s -o - 2>&1 \ 25 // RUN: -target i386-unknown-linux \ 26 // RUN: | FileCheck %s -check-prefix=CHECK_I486_M64 27 // CHECK_I486_M64: error: 28 // 29 // RUN: %clang -march=i586 -m32 -E -dM %s -o - 2>&1 \ 30 // RUN: -target i386-unknown-linux \ 31 // RUN: | FileCheck %s -check-prefix=CHECK_I586_M32 32 // CHECK_I586_M32: #define __i386 1 33 // CHECK_I586_M32: #define __i386__ 1 34 // CHECK_I586_M32: #define __i586 1 35 // CHECK_I586_M32: #define __i586__ 1 36 // CHECK_I586_M32: #define __pentium 1 37 // CHECK_I586_M32: #define __pentium__ 1 38 // CHECK_I586_M32: #define __tune_i586__ 1 39 // CHECK_I586_M32: #define __tune_pentium__ 1 40 // CHECK_I586_M32: #define i386 1 41 // RUN: not %clang -march=i586 -m64 -E -dM %s -o - 2>&1 \ 42 // RUN: -target i386-unknown-linux \ 43 // RUN: | FileCheck %s -check-prefix=CHECK_I586_M64 44 // CHECK_I586_M64: error: 45 // 46 // RUN: %clang -march=pentium -m32 -E -dM %s -o - 2>&1 \ 47 // RUN: -target i386-unknown-linux \ 48 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_M32 49 // CHECK_PENTIUM_M32: #define __i386 1 50 // CHECK_PENTIUM_M32: #define __i386__ 1 51 // CHECK_PENTIUM_M32: #define __i586 1 52 // CHECK_PENTIUM_M32: #define __i586__ 1 53 // CHECK_PENTIUM_M32: #define __pentium 1 54 // CHECK_PENTIUM_M32: #define __pentium__ 1 55 // CHECK_PENTIUM_M32: #define __tune_i586__ 1 56 // CHECK_PENTIUM_M32: #define __tune_pentium__ 1 57 // CHECK_PENTIUM_M32: #define i386 1 58 // RUN: not %clang -march=pentium -m64 -E -dM %s -o - 2>&1 \ 59 // RUN: -target i386-unknown-linux \ 60 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_M64 61 // CHECK_PENTIUM_M64: error: 62 // 63 // RUN: %clang -march=pentium-mmx -m32 -E -dM %s -o - 2>&1 \ 64 // RUN: -target i386-unknown-linux \ 65 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_MMX_M32 66 // CHECK_PENTIUM_MMX_M32: #define __MMX__ 1 67 // CHECK_PENTIUM_MMX_M32: #define __i386 1 68 // CHECK_PENTIUM_MMX_M32: #define __i386__ 1 69 // CHECK_PENTIUM_MMX_M32: #define __i586 1 70 // CHECK_PENTIUM_MMX_M32: #define __i586__ 1 71 // CHECK_PENTIUM_MMX_M32: #define __pentium 1 72 // CHECK_PENTIUM_MMX_M32: #define __pentium__ 1 73 // CHECK_PENTIUM_MMX_M32: #define __pentium_mmx__ 1 74 // CHECK_PENTIUM_MMX_M32: #define __tune_i586__ 1 75 // CHECK_PENTIUM_MMX_M32: #define __tune_pentium__ 1 76 // CHECK_PENTIUM_MMX_M32: #define __tune_pentium_mmx__ 1 77 // CHECK_PENTIUM_MMX_M32: #define i386 1 78 // RUN: not %clang -march=pentium-mmx -m64 -E -dM %s -o - 2>&1 \ 79 // RUN: -target i386-unknown-linux \ 80 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_MMX_M64 81 // CHECK_PENTIUM_MMX_M64: error: 82 // 83 // RUN: %clang -march=winchip-c6 -m32 -E -dM %s -o - 2>&1 \ 84 // RUN: -target i386-unknown-linux \ 85 // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP_C6_M32 86 // CHECK_WINCHIP_C6_M32: #define __MMX__ 1 87 // CHECK_WINCHIP_C6_M32: #define __i386 1 88 // CHECK_WINCHIP_C6_M32: #define __i386__ 1 89 // CHECK_WINCHIP_C6_M32: #define __i486 1 90 // CHECK_WINCHIP_C6_M32: #define __i486__ 1 91 // CHECK_WINCHIP_C6_M32: #define __tune_i486__ 1 92 // CHECK_WINCHIP_C6_M32: #define i386 1 93 // RUN: not %clang -march=winchip-c6 -m64 -E -dM %s -o - 2>&1 \ 94 // RUN: -target i386-unknown-linux \ 95 // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP_C6_M64 96 // CHECK_WINCHIP_C6_M64: error: 97 // 98 // RUN: %clang -march=winchip2 -m32 -E -dM %s -o - 2>&1 \ 99 // RUN: -target i386-unknown-linux \ 100 // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP2_M32 101 // CHECK_WINCHIP2_M32: #define __3dNOW__ 1 102 // CHECK_WINCHIP2_M32: #define __MMX__ 1 103 // CHECK_WINCHIP2_M32: #define __i386 1 104 // CHECK_WINCHIP2_M32: #define __i386__ 1 105 // CHECK_WINCHIP2_M32: #define __i486 1 106 // CHECK_WINCHIP2_M32: #define __i486__ 1 107 // CHECK_WINCHIP2_M32: #define __tune_i486__ 1 108 // CHECK_WINCHIP2_M32: #define i386 1 109 // RUN: not %clang -march=winchip2 -m64 -E -dM %s -o - 2>&1 \ 110 // RUN: -target i386-unknown-linux \ 111 // RUN: | FileCheck %s -check-prefix=CHECK_WINCHIP2_M64 112 // CHECK_WINCHIP2_M64: error: 113 // 114 // RUN: %clang -march=c3 -m32 -E -dM %s -o - 2>&1 \ 115 // RUN: -target i386-unknown-linux \ 116 // RUN: | FileCheck %s -check-prefix=CHECK_C3_M32 117 // CHECK_C3_M32: #define __3dNOW__ 1 118 // CHECK_C3_M32: #define __MMX__ 1 119 // CHECK_C3_M32: #define __i386 1 120 // CHECK_C3_M32: #define __i386__ 1 121 // CHECK_C3_M32: #define __i486 1 122 // CHECK_C3_M32: #define __i486__ 1 123 // CHECK_C3_M32: #define __tune_i486__ 1 124 // CHECK_C3_M32: #define i386 1 125 // RUN: not %clang -march=c3 -m64 -E -dM %s -o - 2>&1 \ 126 // RUN: -target i386-unknown-linux \ 127 // RUN: | FileCheck %s -check-prefix=CHECK_C3_M64 128 // CHECK_C3_M64: error: 129 // 130 // RUN: %clang -march=c3-2 -m32 -E -dM %s -o - 2>&1 \ 131 // RUN: -target i386-unknown-linux \ 132 // RUN: | FileCheck %s -check-prefix=CHECK_C3_2_M32 133 // CHECK_C3_2_M32: #define __MMX__ 1 134 // CHECK_C3_2_M32: #define __SSE__ 1 135 // CHECK_C3_2_M32: #define __i386 1 136 // CHECK_C3_2_M32: #define __i386__ 1 137 // CHECK_C3_2_M32: #define __i686 1 138 // CHECK_C3_2_M32: #define __i686__ 1 139 // CHECK_C3_2_M32: #define __pentiumpro 1 140 // CHECK_C3_2_M32: #define __pentiumpro__ 1 141 // CHECK_C3_2_M32: #define __tune_i686__ 1 142 // CHECK_C3_2_M32: #define __tune_pentium2__ 1 143 // CHECK_C3_2_M32: #define __tune_pentiumpro__ 1 144 // CHECK_C3_2_M32: #define i386 1 145 // RUN: not %clang -march=c3-2 -m64 -E -dM %s -o - 2>&1 \ 146 // RUN: -target i386-unknown-linux \ 147 // RUN: | FileCheck %s -check-prefix=CHECK_C3_2_M64 148 // CHECK_C3_2_M64: error: 149 // 150 // RUN: %clang -march=i686 -m32 -E -dM %s -o - 2>&1 \ 151 // RUN: -target i386-unknown-linux \ 152 // RUN: | FileCheck %s -check-prefix=CHECK_I686_M32 153 // CHECK_I686_M32: #define __i386 1 154 // CHECK_I686_M32: #define __i386__ 1 155 // CHECK_I686_M32: #define __i686 1 156 // CHECK_I686_M32: #define __i686__ 1 157 // CHECK_I686_M32: #define __pentiumpro 1 158 // CHECK_I686_M32: #define __pentiumpro__ 1 159 // CHECK_I686_M32: #define i386 1 160 // RUN: not %clang -march=i686 -m64 -E -dM %s -o - 2>&1 \ 161 // RUN: -target i386-unknown-linux \ 162 // RUN: | FileCheck %s -check-prefix=CHECK_I686_M64 163 // CHECK_I686_M64: error: 164 // 165 // RUN: %clang -march=pentiumpro -m32 -E -dM %s -o - 2>&1 \ 166 // RUN: -target i386-unknown-linux \ 167 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUMPRO_M32 168 // CHECK_PENTIUMPRO_M32: #define __i386 1 169 // CHECK_PENTIUMPRO_M32: #define __i386__ 1 170 // CHECK_PENTIUMPRO_M32: #define __i686 1 171 // CHECK_PENTIUMPRO_M32: #define __i686__ 1 172 // CHECK_PENTIUMPRO_M32: #define __pentiumpro 1 173 // CHECK_PENTIUMPRO_M32: #define __pentiumpro__ 1 174 // CHECK_PENTIUMPRO_M32: #define __tune_i686__ 1 175 // CHECK_PENTIUMPRO_M32: #define __tune_pentiumpro__ 1 176 // CHECK_PENTIUMPRO_M32: #define i386 1 177 // RUN: not %clang -march=pentiumpro -m64 -E -dM %s -o - 2>&1 \ 178 // RUN: -target i386-unknown-linux \ 179 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUMPRO_M64 180 // CHECK_PENTIUMPRO_M64: error: 181 // 182 // RUN: %clang -march=pentium2 -m32 -E -dM %s -o - 2>&1 \ 183 // RUN: -target i386-unknown-linux \ 184 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM2_M32 185 // CHECK_PENTIUM2_M32: #define __MMX__ 1 186 // CHECK_PENTIUM2_M32: #define __i386 1 187 // CHECK_PENTIUM2_M32: #define __i386__ 1 188 // CHECK_PENTIUM2_M32: #define __i686 1 189 // CHECK_PENTIUM2_M32: #define __i686__ 1 190 // CHECK_PENTIUM2_M32: #define __pentiumpro 1 191 // CHECK_PENTIUM2_M32: #define __pentiumpro__ 1 192 // CHECK_PENTIUM2_M32: #define __tune_i686__ 1 193 // CHECK_PENTIUM2_M32: #define __tune_pentium2__ 1 194 // CHECK_PENTIUM2_M32: #define __tune_pentiumpro__ 1 195 // CHECK_PENTIUM2_M32: #define i386 1 196 // RUN: not %clang -march=pentium2 -m64 -E -dM %s -o - 2>&1 \ 197 // RUN: -target i386-unknown-linux \ 198 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM2_M64 199 // CHECK_PENTIUM2_M64: error: 200 // 201 // RUN: %clang -march=pentium3 -m32 -E -dM %s -o - 2>&1 \ 202 // RUN: -target i386-unknown-linux \ 203 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3_M32 204 // CHECK_PENTIUM3_M32: #define __MMX__ 1 205 // CHECK_PENTIUM3_M32: #define __SSE__ 1 206 // CHECK_PENTIUM3_M32: #define __i386 1 207 // CHECK_PENTIUM3_M32: #define __i386__ 1 208 // CHECK_PENTIUM3_M32: #define __i686 1 209 // CHECK_PENTIUM3_M32: #define __i686__ 1 210 // CHECK_PENTIUM3_M32: #define __pentiumpro 1 211 // CHECK_PENTIUM3_M32: #define __pentiumpro__ 1 212 // CHECK_PENTIUM3_M32: #define __tune_i686__ 1 213 // CHECK_PENTIUM3_M32: #define __tune_pentium2__ 1 214 // CHECK_PENTIUM3_M32: #define __tune_pentium3__ 1 215 // CHECK_PENTIUM3_M32: #define __tune_pentiumpro__ 1 216 // CHECK_PENTIUM3_M32: #define i386 1 217 // RUN: not %clang -march=pentium3 -m64 -E -dM %s -o - 2>&1 \ 218 // RUN: -target i386-unknown-linux \ 219 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3_M64 220 // CHECK_PENTIUM3_M64: error: 221 // 222 // RUN: %clang -march=pentium3m -m32 -E -dM %s -o - 2>&1 \ 223 // RUN: -target i386-unknown-linux \ 224 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3M_M32 225 // CHECK_PENTIUM3M_M32: #define __MMX__ 1 226 // CHECK_PENTIUM3M_M32: #define __SSE__ 1 227 // CHECK_PENTIUM3M_M32: #define __i386 1 228 // CHECK_PENTIUM3M_M32: #define __i386__ 1 229 // CHECK_PENTIUM3M_M32: #define __i686 1 230 // CHECK_PENTIUM3M_M32: #define __i686__ 1 231 // CHECK_PENTIUM3M_M32: #define __pentiumpro 1 232 // CHECK_PENTIUM3M_M32: #define __pentiumpro__ 1 233 // CHECK_PENTIUM3M_M32: #define __tune_i686__ 1 234 // CHECK_PENTIUM3M_M32: #define __tune_pentiumpro__ 1 235 // CHECK_PENTIUM3M_M32: #define i386 1 236 // RUN: not %clang -march=pentium3m -m64 -E -dM %s -o - 2>&1 \ 237 // RUN: -target i386-unknown-linux \ 238 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM3M_M64 239 // CHECK_PENTIUM3M_M64: error: 240 // 241 // RUN: %clang -march=pentium-m -m32 -E -dM %s -o - 2>&1 \ 242 // RUN: -target i386-unknown-linux \ 243 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_M_M32 244 // CHECK_PENTIUM_M_M32: #define __MMX__ 1 245 // CHECK_PENTIUM_M_M32: #define __SSE2__ 1 246 // CHECK_PENTIUM_M_M32: #define __SSE__ 1 247 // CHECK_PENTIUM_M_M32: #define __i386 1 248 // CHECK_PENTIUM_M_M32: #define __i386__ 1 249 // CHECK_PENTIUM_M_M32: #define __i686 1 250 // CHECK_PENTIUM_M_M32: #define __i686__ 1 251 // CHECK_PENTIUM_M_M32: #define __pentiumpro 1 252 // CHECK_PENTIUM_M_M32: #define __pentiumpro__ 1 253 // CHECK_PENTIUM_M_M32: #define __tune_i686__ 1 254 // CHECK_PENTIUM_M_M32: #define __tune_pentiumpro__ 1 255 // CHECK_PENTIUM_M_M32: #define i386 1 256 // RUN: not %clang -march=pentium-m -m64 -E -dM %s -o - 2>&1 \ 257 // RUN: -target i386-unknown-linux \ 258 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM_M_M64 259 // CHECK_PENTIUM_M_M64: error: 260 // 261 // RUN: %clang -march=pentium4 -m32 -E -dM %s -o - 2>&1 \ 262 // RUN: -target i386-unknown-linux \ 263 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4_M32 264 // CHECK_PENTIUM4_M32: #define __MMX__ 1 265 // CHECK_PENTIUM4_M32: #define __SSE2__ 1 266 // CHECK_PENTIUM4_M32: #define __SSE__ 1 267 // CHECK_PENTIUM4_M32: #define __i386 1 268 // CHECK_PENTIUM4_M32: #define __i386__ 1 269 // CHECK_PENTIUM4_M32: #define __pentium4 1 270 // CHECK_PENTIUM4_M32: #define __pentium4__ 1 271 // CHECK_PENTIUM4_M32: #define __tune_pentium4__ 1 272 // CHECK_PENTIUM4_M32: #define i386 1 273 // RUN: not %clang -march=pentium4 -m64 -E -dM %s -o - 2>&1 \ 274 // RUN: -target i386-unknown-linux \ 275 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4_M64 276 // CHECK_PENTIUM4_M64: error: 277 // 278 // RUN: %clang -march=pentium4m -m32 -E -dM %s -o - 2>&1 \ 279 // RUN: -target i386-unknown-linux \ 280 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4M_M32 281 // CHECK_PENTIUM4M_M32: #define __MMX__ 1 282 // CHECK_PENTIUM4M_M32: #define __SSE2__ 1 283 // CHECK_PENTIUM4M_M32: #define __SSE__ 1 284 // CHECK_PENTIUM4M_M32: #define __i386 1 285 // CHECK_PENTIUM4M_M32: #define __i386__ 1 286 // CHECK_PENTIUM4M_M32: #define __pentium4 1 287 // CHECK_PENTIUM4M_M32: #define __pentium4__ 1 288 // CHECK_PENTIUM4M_M32: #define __tune_pentium4__ 1 289 // CHECK_PENTIUM4M_M32: #define i386 1 290 // RUN: not %clang -march=pentium4m -m64 -E -dM %s -o - 2>&1 \ 291 // RUN: -target i386-unknown-linux \ 292 // RUN: | FileCheck %s -check-prefix=CHECK_PENTIUM4M_M64 293 // CHECK_PENTIUM4M_M64: error: 294 // 295 // RUN: %clang -march=prescott -m32 -E -dM %s -o - 2>&1 \ 296 // RUN: -target i386-unknown-linux \ 297 // RUN: | FileCheck %s -check-prefix=CHECK_PRESCOTT_M32 298 // CHECK_PRESCOTT_M32: #define __MMX__ 1 299 // CHECK_PRESCOTT_M32: #define __SSE2__ 1 300 // CHECK_PRESCOTT_M32: #define __SSE3__ 1 301 // CHECK_PRESCOTT_M32: #define __SSE__ 1 302 // CHECK_PRESCOTT_M32: #define __i386 1 303 // CHECK_PRESCOTT_M32: #define __i386__ 1 304 // CHECK_PRESCOTT_M32: #define __nocona 1 305 // CHECK_PRESCOTT_M32: #define __nocona__ 1 306 // CHECK_PRESCOTT_M32: #define __tune_nocona__ 1 307 // CHECK_PRESCOTT_M32: #define i386 1 308 // RUN: not %clang -march=prescott -m64 -E -dM %s -o - 2>&1 \ 309 // RUN: -target i386-unknown-linux \ 310 // RUN: | FileCheck %s -check-prefix=CHECK_PRESCOTT_M64 311 // CHECK_PRESCOTT_M64: error: 312 // 313 // RUN: %clang -march=nocona -m32 -E -dM %s -o - 2>&1 \ 314 // RUN: -target i386-unknown-linux \ 315 // RUN: | FileCheck %s -check-prefix=CHECK_NOCONA_M32 316 // CHECK_NOCONA_M32: #define __MMX__ 1 317 // CHECK_NOCONA_M32: #define __SSE2__ 1 318 // CHECK_NOCONA_M32: #define __SSE3__ 1 319 // CHECK_NOCONA_M32: #define __SSE__ 1 320 // CHECK_NOCONA_M32: #define __i386 1 321 // CHECK_NOCONA_M32: #define __i386__ 1 322 // CHECK_NOCONA_M32: #define __nocona 1 323 // CHECK_NOCONA_M32: #define __nocona__ 1 324 // CHECK_NOCONA_M32: #define __tune_nocona__ 1 325 // CHECK_NOCONA_M32: #define i386 1 326 // RUN: %clang -march=nocona -m64 -E -dM %s -o - 2>&1 \ 327 // RUN: -target i386-unknown-linux \ 328 // RUN: | FileCheck %s -check-prefix=CHECK_NOCONA_M64 329 // CHECK_NOCONA_M64: #define __MMX__ 1 330 // CHECK_NOCONA_M64: #define __SSE2_MATH__ 1 331 // CHECK_NOCONA_M64: #define __SSE2__ 1 332 // CHECK_NOCONA_M64: #define __SSE3__ 1 333 // CHECK_NOCONA_M64: #define __SSE_MATH__ 1 334 // CHECK_NOCONA_M64: #define __SSE__ 1 335 // CHECK_NOCONA_M64: #define __amd64 1 336 // CHECK_NOCONA_M64: #define __amd64__ 1 337 // CHECK_NOCONA_M64: #define __nocona 1 338 // CHECK_NOCONA_M64: #define __nocona__ 1 339 // CHECK_NOCONA_M64: #define __tune_nocona__ 1 340 // CHECK_NOCONA_M64: #define __x86_64 1 341 // CHECK_NOCONA_M64: #define __x86_64__ 1 342 // 343 // RUN: %clang -march=core2 -m32 -E -dM %s -o - 2>&1 \ 344 // RUN: -target i386-unknown-linux \ 345 // RUN: | FileCheck %s -check-prefix=CHECK_CORE2_M32 346 // CHECK_CORE2_M32: #define __MMX__ 1 347 // CHECK_CORE2_M32: #define __SSE2__ 1 348 // CHECK_CORE2_M32: #define __SSE3__ 1 349 // CHECK_CORE2_M32: #define __SSE__ 1 350 // CHECK_CORE2_M32: #define __SSSE3__ 1 351 // CHECK_CORE2_M32: #define __core2 1 352 // CHECK_CORE2_M32: #define __core2__ 1 353 // CHECK_CORE2_M32: #define __i386 1 354 // CHECK_CORE2_M32: #define __i386__ 1 355 // CHECK_CORE2_M32: #define __tune_core2__ 1 356 // CHECK_CORE2_M32: #define i386 1 357 // RUN: %clang -march=core2 -m64 -E -dM %s -o - 2>&1 \ 358 // RUN: -target i386-unknown-linux \ 359 // RUN: | FileCheck %s -check-prefix=CHECK_CORE2_M64 360 // CHECK_CORE2_M64: #define __MMX__ 1 361 // CHECK_CORE2_M64: #define __SSE2_MATH__ 1 362 // CHECK_CORE2_M64: #define __SSE2__ 1 363 // CHECK_CORE2_M64: #define __SSE3__ 1 364 // CHECK_CORE2_M64: #define __SSE_MATH__ 1 365 // CHECK_CORE2_M64: #define __SSE__ 1 366 // CHECK_CORE2_M64: #define __SSSE3__ 1 367 // CHECK_CORE2_M64: #define __amd64 1 368 // CHECK_CORE2_M64: #define __amd64__ 1 369 // CHECK_CORE2_M64: #define __core2 1 370 // CHECK_CORE2_M64: #define __core2__ 1 371 // CHECK_CORE2_M64: #define __tune_core2__ 1 372 // CHECK_CORE2_M64: #define __x86_64 1 373 // CHECK_CORE2_M64: #define __x86_64__ 1 374 // 375 // RUN: %clang -march=corei7 -m32 -E -dM %s -o - 2>&1 \ 376 // RUN: -target i386-unknown-linux \ 377 // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_M32 378 // CHECK_COREI7_M32: #define __MMX__ 1 379 // CHECK_COREI7_M32: #define __POPCNT__ 1 380 // CHECK_COREI7_M32: #define __SSE2__ 1 381 // CHECK_COREI7_M32: #define __SSE3__ 1 382 // CHECK_COREI7_M32: #define __SSE4_1__ 1 383 // CHECK_COREI7_M32: #define __SSE4_2__ 1 384 // CHECK_COREI7_M32: #define __SSE__ 1 385 // CHECK_COREI7_M32: #define __SSSE3__ 1 386 // CHECK_COREI7_M32: #define __corei7 1 387 // CHECK_COREI7_M32: #define __corei7__ 1 388 // CHECK_COREI7_M32: #define __i386 1 389 // CHECK_COREI7_M32: #define __i386__ 1 390 // CHECK_COREI7_M32: #define __tune_corei7__ 1 391 // CHECK_COREI7_M32: #define i386 1 392 // RUN: %clang -march=corei7 -m64 -E -dM %s -o - 2>&1 \ 393 // RUN: -target i386-unknown-linux \ 394 // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_M64 395 // CHECK_COREI7_M64: #define __MMX__ 1 396 // CHECK_COREI7_M64: #define __POPCNT__ 1 397 // CHECK_COREI7_M64: #define __SSE2_MATH__ 1 398 // CHECK_COREI7_M64: #define __SSE2__ 1 399 // CHECK_COREI7_M64: #define __SSE3__ 1 400 // CHECK_COREI7_M64: #define __SSE4_1__ 1 401 // CHECK_COREI7_M64: #define __SSE4_2__ 1 402 // CHECK_COREI7_M64: #define __SSE_MATH__ 1 403 // CHECK_COREI7_M64: #define __SSE__ 1 404 // CHECK_COREI7_M64: #define __SSSE3__ 1 405 // CHECK_COREI7_M64: #define __amd64 1 406 // CHECK_COREI7_M64: #define __amd64__ 1 407 // CHECK_COREI7_M64: #define __corei7 1 408 // CHECK_COREI7_M64: #define __corei7__ 1 409 // CHECK_COREI7_M64: #define __tune_corei7__ 1 410 // CHECK_COREI7_M64: #define __x86_64 1 411 // CHECK_COREI7_M64: #define __x86_64__ 1 412 // 413 // RUN: %clang -march=corei7-avx -m32 -E -dM %s -o - 2>&1 \ 414 // RUN: -target i386-unknown-linux \ 415 // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M32 416 // CHECK_COREI7_AVX_M32: #define __AES__ 1 417 // CHECK_COREI7_AVX_M32: #define __AVX__ 1 418 // CHECK_COREI7_AVX_M32: #define __MMX__ 1 419 // CHECK_COREI7_AVX_M32: #define __PCLMUL__ 1 420 // CHECK_COREI7_AVX_M32-NOT: __RDRND__ 421 // CHECK_COREI7_AVX_M32: #define __POPCNT__ 1 422 // CHECK_COREI7_AVX_M32: #define __SSE2__ 1 423 // CHECK_COREI7_AVX_M32: #define __SSE3__ 1 424 // CHECK_COREI7_AVX_M32: #define __SSE4_1__ 1 425 // CHECK_COREI7_AVX_M32: #define __SSE4_2__ 1 426 // CHECK_COREI7_AVX_M32: #define __SSE__ 1 427 // CHECK_COREI7_AVX_M32: #define __SSSE3__ 1 428 // CHECK_COREI7_AVX_M32: #define __corei7 1 429 // CHECK_COREI7_AVX_M32: #define __corei7__ 1 430 // CHECK_COREI7_AVX_M32: #define __i386 1 431 // CHECK_COREI7_AVX_M32: #define __i386__ 1 432 // CHECK_COREI7_AVX_M32: #define __tune_corei7__ 1 433 // CHECK_COREI7_AVX_M32: #define i386 1 434 // RUN: %clang -march=corei7-avx -m64 -E -dM %s -o - 2>&1 \ 435 // RUN: -target i386-unknown-linux \ 436 // RUN: | FileCheck %s -check-prefix=CHECK_COREI7_AVX_M64 437 // CHECK_COREI7_AVX_M64: #define __AES__ 1 438 // CHECK_COREI7_AVX_M64: #define __AVX__ 1 439 // CHECK_COREI7_AVX_M64: #define __MMX__ 1 440 // CHECK_COREI7_AVX_M64: #define __PCLMUL__ 1 441 // CHECK_COREI7_AVX_M64-NOT: __RDRND__ 442 // CHECK_COREI7_AVX_M64: #define __POPCNT__ 1 443 // CHECK_COREI7_AVX_M64: #define __SSE2_MATH__ 1 444 // CHECK_COREI7_AVX_M64: #define __SSE2__ 1 445 // CHECK_COREI7_AVX_M64: #define __SSE3__ 1 446 // CHECK_COREI7_AVX_M64: #define __SSE4_1__ 1 447 // CHECK_COREI7_AVX_M64: #define __SSE4_2__ 1 448 // CHECK_COREI7_AVX_M64: #define __SSE_MATH__ 1 449 // CHECK_COREI7_AVX_M64: #define __SSE__ 1 450 // CHECK_COREI7_AVX_M64: #define __SSSE3__ 1 451 // CHECK_COREI7_AVX_M64: #define __amd64 1 452 // CHECK_COREI7_AVX_M64: #define __amd64__ 1 453 // CHECK_COREI7_AVX_M64: #define __corei7 1 454 // CHECK_COREI7_AVX_M64: #define __corei7__ 1 455 // CHECK_COREI7_AVX_M64: #define __tune_corei7__ 1 456 // CHECK_COREI7_AVX_M64: #define __x86_64 1 457 // CHECK_COREI7_AVX_M64: #define __x86_64__ 1 458 // 459 // RUN: %clang -march=core-avx-i -m32 -E -dM %s -o - 2>&1 \ 460 // RUN: -target i386-unknown-linux \ 461 // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M32 462 // CHECK_CORE_AVX_I_M32: #define __AES__ 1 463 // CHECK_CORE_AVX_I_M32: #define __AVX__ 1 464 // CHECK_CORE_AVX_I_M32: #define __F16C__ 1 465 // CHECK_CORE_AVX_I_M32: #define __MMX__ 1 466 // CHECK_CORE_AVX_I_M32: #define __PCLMUL__ 1 467 // CHECK_CORE_AVX_I_M32: #define __RDRND__ 1 468 // CHECK_CORE_AVX_I_M32: #define __SSE2__ 1 469 // CHECK_CORE_AVX_I_M32: #define __SSE3__ 1 470 // CHECK_CORE_AVX_I_M32: #define __SSE4_1__ 1 471 // CHECK_CORE_AVX_I_M32: #define __SSE4_2__ 1 472 // CHECK_CORE_AVX_I_M32: #define __SSE__ 1 473 // CHECK_CORE_AVX_I_M32: #define __SSSE3__ 1 474 // CHECK_CORE_AVX_I_M32: #define __corei7 1 475 // CHECK_CORE_AVX_I_M32: #define __corei7__ 1 476 // CHECK_CORE_AVX_I_M32: #define __i386 1 477 // CHECK_CORE_AVX_I_M32: #define __i386__ 1 478 // CHECK_CORE_AVX_I_M32: #define __tune_corei7__ 1 479 // CHECK_CORE_AVX_I_M32: #define i386 1 480 // RUN: %clang -march=core-avx-i -m64 -E -dM %s -o - 2>&1 \ 481 // RUN: -target i386-unknown-linux \ 482 // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX_I_M64 483 // CHECK_CORE_AVX_I_M64: #define __AES__ 1 484 // CHECK_CORE_AVX_I_M64: #define __AVX__ 1 485 // CHECK_CORE_AVX_I_M64: #define __F16C__ 1 486 // CHECK_CORE_AVX_I_M64: #define __MMX__ 1 487 // CHECK_CORE_AVX_I_M64: #define __PCLMUL__ 1 488 // CHECK_CORE_AVX_I_M64: #define __RDRND__ 1 489 // CHECK_CORE_AVX_I_M64: #define __SSE2_MATH__ 1 490 // CHECK_CORE_AVX_I_M64: #define __SSE2__ 1 491 // CHECK_CORE_AVX_I_M64: #define __SSE3__ 1 492 // CHECK_CORE_AVX_I_M64: #define __SSE4_1__ 1 493 // CHECK_CORE_AVX_I_M64: #define __SSE4_2__ 1 494 // CHECK_CORE_AVX_I_M64: #define __SSE_MATH__ 1 495 // CHECK_CORE_AVX_I_M64: #define __SSE__ 1 496 // CHECK_CORE_AVX_I_M64: #define __SSSE3__ 1 497 // CHECK_CORE_AVX_I_M64: #define __amd64 1 498 // CHECK_CORE_AVX_I_M64: #define __amd64__ 1 499 // CHECK_CORE_AVX_I_M64: #define __corei7 1 500 // CHECK_CORE_AVX_I_M64: #define __corei7__ 1 501 // CHECK_CORE_AVX_I_M64: #define __tune_corei7__ 1 502 // CHECK_CORE_AVX_I_M64: #define __x86_64 1 503 // CHECK_CORE_AVX_I_M64: #define __x86_64__ 1 504 // 505 // RUN: %clang -march=core-avx2 -m32 -E -dM %s -o - 2>&1 \ 506 // RUN: -target i386-unknown-linux \ 507 // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX2_M32 508 // CHECK_CORE_AVX2_M32: #define __AES__ 1 509 // CHECK_CORE_AVX2_M32: #define __AVX2__ 1 510 // CHECK_CORE_AVX2_M32: #define __AVX__ 1 511 // CHECK_CORE_AVX2_M32: #define __BMI2__ 1 512 // CHECK_CORE_AVX2_M32: #define __BMI__ 1 513 // CHECK_CORE_AVX2_M32: #define __F16C__ 1 514 // CHECK_CORE_AVX2_M32: #define __FMA__ 1 515 // CHECK_CORE_AVX2_M32: #define __LZCNT__ 1 516 // CHECK_CORE_AVX2_M32: #define __MMX__ 1 517 // CHECK_CORE_AVX2_M32: #define __PCLMUL__ 1 518 // CHECK_CORE_AVX2_M32: #define __POPCNT__ 1 519 // CHECK_CORE_AVX2_M32: #define __RDRND__ 1 520 // CHECK_CORE_AVX2_M32: #define __RTM__ 1 521 // CHECK_CORE_AVX2_M32: #define __SSE2__ 1 522 // CHECK_CORE_AVX2_M32: #define __SSE3__ 1 523 // CHECK_CORE_AVX2_M32: #define __SSE4_1__ 1 524 // CHECK_CORE_AVX2_M32: #define __SSE4_2__ 1 525 // CHECK_CORE_AVX2_M32: #define __SSE__ 1 526 // CHECK_CORE_AVX2_M32: #define __SSSE3__ 1 527 // CHECK_CORE_AVX2_M32: #define __corei7 1 528 // CHECK_CORE_AVX2_M32: #define __corei7__ 1 529 // CHECK_CORE_AVX2_M32: #define __i386 1 530 // CHECK_CORE_AVX2_M32: #define __i386__ 1 531 // CHECK_CORE_AVX2_M32: #define __tune_corei7__ 1 532 // CHECK_CORE_AVX2_M32: #define i386 1 533 // RUN: %clang -march=core-avx2 -m64 -E -dM %s -o - 2>&1 \ 534 // RUN: -target i386-unknown-linux \ 535 // RUN: | FileCheck %s -check-prefix=CHECK_CORE_AVX2_M64 536 // CHECK_CORE_AVX2_M64: #define __AES__ 1 537 // CHECK_CORE_AVX2_M64: #define __AVX2__ 1 538 // CHECK_CORE_AVX2_M64: #define __AVX__ 1 539 // CHECK_CORE_AVX2_M64: #define __BMI2__ 1 540 // CHECK_CORE_AVX2_M64: #define __BMI__ 1 541 // CHECK_CORE_AVX2_M64: #define __F16C__ 1 542 // CHECK_CORE_AVX2_M64: #define __FMA__ 1 543 // CHECK_CORE_AVX2_M64: #define __LZCNT__ 1 544 // CHECK_CORE_AVX2_M64: #define __MMX__ 1 545 // CHECK_CORE_AVX2_M64: #define __PCLMUL__ 1 546 // CHECK_CORE_AVX2_M64: #define __POPCNT__ 1 547 // CHECK_CORE_AVX2_M64: #define __RDRND__ 1 548 // CHECK_CORE_AVX2_M64: #define __RTM__ 1 549 // CHECK_CORE_AVX2_M64: #define __SSE2_MATH__ 1 550 // CHECK_CORE_AVX2_M64: #define __SSE2__ 1 551 // CHECK_CORE_AVX2_M64: #define __SSE3__ 1 552 // CHECK_CORE_AVX2_M64: #define __SSE4_1__ 1 553 // CHECK_CORE_AVX2_M64: #define __SSE4_2__ 1 554 // CHECK_CORE_AVX2_M64: #define __SSE_MATH__ 1 555 // CHECK_CORE_AVX2_M64: #define __SSE__ 1 556 // CHECK_CORE_AVX2_M64: #define __SSSE3__ 1 557 // CHECK_CORE_AVX2_M64: #define __amd64 1 558 // CHECK_CORE_AVX2_M64: #define __amd64__ 1 559 // CHECK_CORE_AVX2_M64: #define __corei7 1 560 // CHECK_CORE_AVX2_M64: #define __corei7__ 1 561 // CHECK_CORE_AVX2_M64: #define __tune_corei7__ 1 562 // CHECK_CORE_AVX2_M64: #define __x86_64 1 563 // CHECK_CORE_AVX2_M64: #define __x86_64__ 1 564 // 565 // RUN: %clang -march=broadwell -m32 -E -dM %s -o - 2>&1 \ 566 // RUN: -target i386-unknown-linux \ 567 // RUN: | FileCheck %s -check-prefix=CHECK_BROADWELL_M32 568 // CHECK_BROADWELL_M32: #define __ADX__ 1 569 // CHECK_BROADWELL_M32: #define __AES__ 1 570 // CHECK_BROADWELL_M32: #define __AVX2__ 1 571 // CHECK_BROADWELL_M32: #define __AVX__ 1 572 // CHECK_BROADWELL_M32: #define __BMI2__ 1 573 // CHECK_BROADWELL_M32: #define __BMI__ 1 574 // CHECK_BROADWELL_M32: #define __F16C__ 1 575 // CHECK_BROADWELL_M32: #define __FMA__ 1 576 // CHECK_BROADWELL_M32: #define __LZCNT__ 1 577 // CHECK_BROADWELL_M32: #define __MMX__ 1 578 // CHECK_BROADWELL_M32: #define __PCLMUL__ 1 579 // CHECK_BROADWELL_M32: #define __POPCNT__ 1 580 // CHECK_BROADWELL_M32: #define __RDRND__ 1 581 // CHECK_BROADWELL_M32: #define __RDSEED__ 1 582 // CHECK_BROADWELL_M32: #define __RTM__ 1 583 // CHECK_BROADWELL_M32: #define __SSE2__ 1 584 // CHECK_BROADWELL_M32: #define __SSE3__ 1 585 // CHECK_BROADWELL_M32: #define __SSE4_1__ 1 586 // CHECK_BROADWELL_M32: #define __SSE4_2__ 1 587 // CHECK_BROADWELL_M32: #define __SSE__ 1 588 // CHECK_BROADWELL_M32: #define __SSSE3__ 1 589 // CHECK_BROADWELL_M32: #define __corei7 1 590 // CHECK_BROADWELL_M32: #define __corei7__ 1 591 // CHECK_BROADWELL_M32: #define __i386 1 592 // CHECK_BROADWELL_M32: #define __i386__ 1 593 // CHECK_BROADWELL_M32: #define __tune_corei7__ 1 594 // CHECK_BROADWELL_M32: #define i386 1 595 // RUN: %clang -march=broadwell -m64 -E -dM %s -o - 2>&1 \ 596 // RUN: -target i386-unknown-linux \ 597 // RUN: | FileCheck %s -check-prefix=CHECK_BROADWELL_M64 598 // CHECK_BROADWELL_M64: #define __ADX__ 1 599 // CHECK_BROADWELL_M64: #define __AES__ 1 600 // CHECK_BROADWELL_M64: #define __AVX2__ 1 601 // CHECK_BROADWELL_M64: #define __AVX__ 1 602 // CHECK_BROADWELL_M64: #define __BMI2__ 1 603 // CHECK_BROADWELL_M64: #define __BMI__ 1 604 // CHECK_BROADWELL_M64: #define __F16C__ 1 605 // CHECK_BROADWELL_M64: #define __FMA__ 1 606 // CHECK_BROADWELL_M64: #define __LZCNT__ 1 607 // CHECK_BROADWELL_M64: #define __MMX__ 1 608 // CHECK_BROADWELL_M64: #define __PCLMUL__ 1 609 // CHECK_BROADWELL_M64: #define __POPCNT__ 1 610 // CHECK_BROADWELL_M64: #define __RDRND__ 1 611 // CHECK_BROADWELL_M64: #define __RDSEED__ 1 612 // CHECK_BROADWELL_M64: #define __RTM__ 1 613 // CHECK_BROADWELL_M64: #define __SSE2_MATH__ 1 614 // CHECK_BROADWELL_M64: #define __SSE2__ 1 615 // CHECK_BROADWELL_M64: #define __SSE3__ 1 616 // CHECK_BROADWELL_M64: #define __SSE4_1__ 1 617 // CHECK_BROADWELL_M64: #define __SSE4_2__ 1 618 // CHECK_BROADWELL_M64: #define __SSE_MATH__ 1 619 // CHECK_BROADWELL_M64: #define __SSE__ 1 620 // CHECK_BROADWELL_M64: #define __SSSE3__ 1 621 // CHECK_BROADWELL_M64: #define __amd64 1 622 // CHECK_BROADWELL_M64: #define __amd64__ 1 623 // CHECK_BROADWELL_M64: #define __corei7 1 624 // CHECK_BROADWELL_M64: #define __corei7__ 1 625 // CHECK_BROADWELL_M64: #define __tune_corei7__ 1 626 // CHECK_BROADWELL_M64: #define __x86_64 1 627 // CHECK_BROADWELL_M64: #define __x86_64__ 1 628 // 629 // RUN: %clang -march=knl -m32 -E -dM %s -o - 2>&1 \ 630 // RUN: -target i386-unknown-linux \ 631 // RUN: | FileCheck %s -check-prefix=CHECK_KNL_M32 632 // CHECK_KNL_M32: #define __AES__ 1 633 // CHECK_KNL_M32: #define __AVX2__ 1 634 // CHECK_KNL_M32: #define __AVX512CD__ 1 635 // CHECK_KNL_M32: #define __AVX512ER__ 1 636 // CHECK_KNL_M32: #define __AVX512F__ 1 637 // CHECK_KNL_M32: #define __AVX512PF__ 1 638 // CHECK_KNL_M32: #define __AVX__ 1 639 // CHECK_KNL_M32: #define __BMI2__ 1 640 // CHECK_KNL_M32: #define __BMI__ 1 641 // CHECK_KNL_M32: #define __F16C__ 1 642 // CHECK_KNL_M32: #define __FMA__ 1 643 // CHECK_KNL_M32: #define __LZCNT__ 1 644 // CHECK_KNL_M32: #define __MMX__ 1 645 // CHECK_KNL_M32: #define __PCLMUL__ 1 646 // CHECK_KNL_M32: #define __POPCNT__ 1 647 // CHECK_KNL_M32: #define __RDRND__ 1 648 // CHECK_KNL_M32: #define __RTM__ 1 649 // CHECK_KNL_M32: #define __SSE2__ 1 650 // CHECK_KNL_M32: #define __SSE3__ 1 651 // CHECK_KNL_M32: #define __SSE4_1__ 1 652 // CHECK_KNL_M32: #define __SSE4_2__ 1 653 // CHECK_KNL_M32: #define __SSE__ 1 654 // CHECK_KNL_M32: #define __SSSE3__ 1 655 // CHECK_KNL_M32: #define __i386 1 656 // CHECK_KNL_M32: #define __i386__ 1 657 // CHECK_KNL_M32: #define __knl 1 658 // CHECK_KNL_M32: #define __knl__ 1 659 // CHECK_KNL_M32: #define __tune_knl__ 1 660 // CHECK_KNL_M32: #define i386 1 661 662 // RUN: %clang -march=knl -m64 -E -dM %s -o - 2>&1 \ 663 // RUN: -target i386-unknown-linux \ 664 // RUN: | FileCheck %s -check-prefix=CHECK_KNL_M64 665 // CHECK_KNL_M64: #define __AES__ 1 666 // CHECK_KNL_M64: #define __AVX2__ 1 667 // CHECK_KNL_M64: #define __AVX512CD__ 1 668 // CHECK_KNL_M64: #define __AVX512ER__ 1 669 // CHECK_KNL_M64: #define __AVX512F__ 1 670 // CHECK_KNL_M64: #define __AVX512PF__ 1 671 // CHECK_KNL_M64: #define __AVX__ 1 672 // CHECK_KNL_M64: #define __BMI2__ 1 673 // CHECK_KNL_M64: #define __BMI__ 1 674 // CHECK_KNL_M64: #define __F16C__ 1 675 // CHECK_KNL_M64: #define __FMA__ 1 676 // CHECK_KNL_M64: #define __LZCNT__ 1 677 // CHECK_KNL_M64: #define __MMX__ 1 678 // CHECK_KNL_M64: #define __PCLMUL__ 1 679 // CHECK_KNL_M64: #define __POPCNT__ 1 680 // CHECK_KNL_M64: #define __RDRND__ 1 681 // CHECK_KNL_M64: #define __RTM__ 1 682 // CHECK_KNL_M64: #define __SSE2_MATH__ 1 683 // CHECK_KNL_M64: #define __SSE2__ 1 684 // CHECK_KNL_M64: #define __SSE3__ 1 685 // CHECK_KNL_M64: #define __SSE4_1__ 1 686 // CHECK_KNL_M64: #define __SSE4_2__ 1 687 // CHECK_KNL_M64: #define __SSE_MATH__ 1 688 // CHECK_KNL_M64: #define __SSE__ 1 689 // CHECK_KNL_M64: #define __SSSE3__ 1 690 // CHECK_KNL_M64: #define __amd64 1 691 // CHECK_KNL_M64: #define __amd64__ 1 692 // CHECK_KNL_M64: #define __knl 1 693 // CHECK_KNL_M64: #define __knl__ 1 694 // CHECK_KNL_M64: #define __tune_knl__ 1 695 // CHECK_KNL_M64: #define __x86_64 1 696 // CHECK_KNL_M64: #define __x86_64__ 1 697 // 698 // RUN: %clang -march=skx -m32 -E -dM %s -o - 2>&1 \ 699 // RUN: -target i386-unknown-linux \ 700 // RUN: | FileCheck %s -check-prefix=CHECK_SKX_M32 701 // CHECK_SKX_M32: #define __AES__ 1 702 // CHECK_SKX_M32: #define __AVX2__ 1 703 // CHECK_SKX_M32: #define __AVX512BW__ 1 704 // CHECK_SKX_M32: #define __AVX512CD__ 1 705 // CHECK_SKX_M32: #define __AVX512DQ__ 1 706 // CHECK_SKX_M32: #define __AVX512F__ 1 707 // CHECK_SKX_M32: #define __AVX512VL__ 1 708 // CHECK_SKX_M32: #define __AVX__ 1 709 // CHECK_SKX_M32: #define __BMI2__ 1 710 // CHECK_SKX_M32: #define __BMI__ 1 711 // CHECK_SKX_M32: #define __F16C__ 1 712 // CHECK_SKX_M32: #define __FMA__ 1 713 // CHECK_SKX_M32: #define __LZCNT__ 1 714 // CHECK_SKX_M32: #define __MMX__ 1 715 // CHECK_SKX_M32: #define __PCLMUL__ 1 716 // CHECK_SKX_M32: #define __POPCNT__ 1 717 // CHECK_SKX_M32: #define __RDRND__ 1 718 // CHECK_SKX_M32: #define __RTM__ 1 719 // CHECK_SKX_M32: #define __SSE2__ 1 720 // CHECK_SKX_M32: #define __SSE3__ 1 721 // CHECK_SKX_M32: #define __SSE4_1__ 1 722 // CHECK_SKX_M32: #define __SSE4_2__ 1 723 // CHECK_SKX_M32: #define __SSE__ 1 724 // CHECK_SKX_M32: #define __SSSE3__ 1 725 // CHECK_SKX_M32: #define __i386 1 726 // CHECK_SKX_M32: #define __i386__ 1 727 // CHECK_SKX_M32: #define __skx 1 728 // CHECK_SKX_M32: #define __skx__ 1 729 // CHECK_SKX_M32: #define __tune_skx__ 1 730 // CHECK_SKX_M32: #define i386 1 731 732 // RUN: %clang -march=skx -m64 -E -dM %s -o - 2>&1 \ 733 // RUN: -target i386-unknown-linux \ 734 // RUN: | FileCheck %s -check-prefix=CHECK_SKX_M64 735 // CHECK_SKX_M64: #define __AES__ 1 736 // CHECK_SKX_M64: #define __AVX2__ 1 737 // CHECK_SKX_M64: #define __AVX512BW__ 1 738 // CHECK_SKX_M64: #define __AVX512CD__ 1 739 // CHECK_SKX_M64: #define __AVX512DQ__ 1 740 // CHECK_SKX_M64: #define __AVX512F__ 1 741 // CHECK_SKX_M64: #define __AVX512VL__ 1 742 // CHECK_SKX_M64: #define __AVX__ 1 743 // CHECK_SKX_M64: #define __BMI2__ 1 744 // CHECK_SKX_M64: #define __BMI__ 1 745 // CHECK_SKX_M64: #define __F16C__ 1 746 // CHECK_SKX_M64: #define __FMA__ 1 747 // CHECK_SKX_M64: #define __LZCNT__ 1 748 // CHECK_SKX_M64: #define __MMX__ 1 749 // CHECK_SKX_M64: #define __PCLMUL__ 1 750 // CHECK_SKX_M64: #define __POPCNT__ 1 751 // CHECK_SKX_M64: #define __RDRND__ 1 752 // CHECK_SKX_M64: #define __RTM__ 1 753 // CHECK_SKX_M64: #define __SSE2_MATH__ 1 754 // CHECK_SKX_M64: #define __SSE2__ 1 755 // CHECK_SKX_M64: #define __SSE3__ 1 756 // CHECK_SKX_M64: #define __SSE4_1__ 1 757 // CHECK_SKX_M64: #define __SSE4_2__ 1 758 // CHECK_SKX_M64: #define __SSE_MATH__ 1 759 // CHECK_SKX_M64: #define __SSE__ 1 760 // CHECK_SKX_M64: #define __SSSE3__ 1 761 // CHECK_SKX_M64: #define __amd64 1 762 // CHECK_SKX_M64: #define __amd64__ 1 763 // CHECK_SKX_M64: #define __skx 1 764 // CHECK_SKX_M64: #define __skx__ 1 765 // CHECK_SKX_M64: #define __tune_skx__ 1 766 // CHECK_SKX_M64: #define __x86_64 1 767 // CHECK_SKX_M64: #define __x86_64__ 1 768 // 769 // RUN: %clang -march=atom -m32 -E -dM %s -o - 2>&1 \ 770 // RUN: -target i386-unknown-linux \ 771 // RUN: | FileCheck %s -check-prefix=CHECK_ATOM_M32 772 // CHECK_ATOM_M32: #define __MMX__ 1 773 // CHECK_ATOM_M32: #define __SSE2__ 1 774 // CHECK_ATOM_M32: #define __SSE3__ 1 775 // CHECK_ATOM_M32: #define __SSE__ 1 776 // CHECK_ATOM_M32: #define __SSSE3__ 1 777 // CHECK_ATOM_M32: #define __atom 1 778 // CHECK_ATOM_M32: #define __atom__ 1 779 // CHECK_ATOM_M32: #define __i386 1 780 // CHECK_ATOM_M32: #define __i386__ 1 781 // CHECK_ATOM_M32: #define __tune_atom__ 1 782 // CHECK_ATOM_M32: #define i386 1 783 // RUN: %clang -march=atom -m64 -E -dM %s -o - 2>&1 \ 784 // RUN: -target i386-unknown-linux \ 785 // RUN: | FileCheck %s -check-prefix=CHECK_ATOM_M64 786 // CHECK_ATOM_M64: #define __MMX__ 1 787 // CHECK_ATOM_M64: #define __SSE2_MATH__ 1 788 // CHECK_ATOM_M64: #define __SSE2__ 1 789 // CHECK_ATOM_M64: #define __SSE3__ 1 790 // CHECK_ATOM_M64: #define __SSE_MATH__ 1 791 // CHECK_ATOM_M64: #define __SSE__ 1 792 // CHECK_ATOM_M64: #define __SSSE3__ 1 793 // CHECK_ATOM_M64: #define __amd64 1 794 // CHECK_ATOM_M64: #define __amd64__ 1 795 // CHECK_ATOM_M64: #define __atom 1 796 // CHECK_ATOM_M64: #define __atom__ 1 797 // CHECK_ATOM_M64: #define __tune_atom__ 1 798 // CHECK_ATOM_M64: #define __x86_64 1 799 // CHECK_ATOM_M64: #define __x86_64__ 1 800 // 801 // RUN: %clang -march=slm -m32 -E -dM %s -o - 2>&1 \ 802 // RUN: -target i386-unknown-linux \ 803 // RUN: | FileCheck %s -check-prefix=CHECK_SLM_M32 804 // CHECK_SLM_M32: #define __MMX__ 1 805 // CHECK_SLM_M32: #define __SSE2__ 1 806 // CHECK_SLM_M32: #define __SSE3__ 1 807 // CHECK_SLM_M32: #define __SSE4_1__ 1 808 // CHECK_SLM_M32: #define __SSE4_2__ 1 809 // CHECK_SLM_M32: #define __SSE__ 1 810 // CHECK_SLM_M32: #define __SSSE3__ 1 811 // CHECK_SLM_M32: #define __i386 1 812 // CHECK_SLM_M32: #define __i386__ 1 813 // CHECK_SLM_M32: #define __slm 1 814 // CHECK_SLM_M32: #define __slm__ 1 815 // CHECK_SLM_M32: #define __tune_slm__ 1 816 // CHECK_SLM_M32: #define i386 1 817 // RUN: %clang -march=slm -m64 -E -dM %s -o - 2>&1 \ 818 // RUN: -target i386-unknown-linux \ 819 // RUN: | FileCheck %s -check-prefix=CHECK_SLM_M64 820 // CHECK_SLM_M64: #define __MMX__ 1 821 // CHECK_SLM_M64: #define __SSE2_MATH__ 1 822 // CHECK_SLM_M64: #define __SSE2__ 1 823 // CHECK_SLM_M64: #define __SSE3__ 1 824 // CHECK_SLM_M64: #define __SSE4_1__ 1 825 // CHECK_SLM_M64: #define __SSE4_2__ 1 826 // CHECK_SLM_M64: #define __SSE_MATH__ 1 827 // CHECK_SLM_M64: #define __SSE__ 1 828 // CHECK_SLM_M64: #define __SSSE3__ 1 829 // CHECK_SLM_M64: #define __amd64 1 830 // CHECK_SLM_M64: #define __amd64__ 1 831 // CHECK_SLM_M64: #define __slm 1 832 // CHECK_SLM_M64: #define __slm__ 1 833 // CHECK_SLM_M64: #define __tune_slm__ 1 834 // CHECK_SLM_M64: #define __x86_64 1 835 // CHECK_SLM_M64: #define __x86_64__ 1 836 // 837 // RUN: %clang -march=geode -m32 -E -dM %s -o - 2>&1 \ 838 // RUN: -target i386-unknown-linux \ 839 // RUN: | FileCheck %s -check-prefix=CHECK_GEODE_M32 840 // CHECK_GEODE_M32: #define __3dNOW_A__ 1 841 // CHECK_GEODE_M32: #define __3dNOW__ 1 842 // CHECK_GEODE_M32: #define __MMX__ 1 843 // CHECK_GEODE_M32: #define __geode 1 844 // CHECK_GEODE_M32: #define __geode__ 1 845 // CHECK_GEODE_M32: #define __i386 1 846 // CHECK_GEODE_M32: #define __i386__ 1 847 // CHECK_GEODE_M32: #define __tune_geode__ 1 848 // CHECK_GEODE_M32: #define i386 1 849 // RUN: not %clang -march=geode -m64 -E -dM %s -o - 2>&1 \ 850 // RUN: -target i386-unknown-linux \ 851 // RUN: | FileCheck %s -check-prefix=CHECK_GEODE_M64 852 // CHECK_GEODE_M64: error: 853 // 854 // RUN: %clang -march=k6 -m32 -E -dM %s -o - 2>&1 \ 855 // RUN: -target i386-unknown-linux \ 856 // RUN: | FileCheck %s -check-prefix=CHECK_K6_M32 857 // CHECK_K6_M32: #define __MMX__ 1 858 // CHECK_K6_M32: #define __i386 1 859 // CHECK_K6_M32: #define __i386__ 1 860 // CHECK_K6_M32: #define __k6 1 861 // CHECK_K6_M32: #define __k6__ 1 862 // CHECK_K6_M32: #define __tune_k6__ 1 863 // CHECK_K6_M32: #define i386 1 864 // RUN: not %clang -march=k6 -m64 -E -dM %s -o - 2>&1 \ 865 // RUN: -target i386-unknown-linux \ 866 // RUN: | FileCheck %s -check-prefix=CHECK_K6_M64 867 // CHECK_K6_M64: error: 868 // 869 // RUN: %clang -march=k6-2 -m32 -E -dM %s -o - 2>&1 \ 870 // RUN: -target i386-unknown-linux \ 871 // RUN: | FileCheck %s -check-prefix=CHECK_K6_2_M32 872 // CHECK_K6_2_M32: #define __3dNOW__ 1 873 // CHECK_K6_2_M32: #define __MMX__ 1 874 // CHECK_K6_2_M32: #define __i386 1 875 // CHECK_K6_2_M32: #define __i386__ 1 876 // CHECK_K6_2_M32: #define __k6 1 877 // CHECK_K6_2_M32: #define __k6_2__ 1 878 // CHECK_K6_2_M32: #define __k6__ 1 879 // CHECK_K6_2_M32: #define __tune_k6_2__ 1 880 // CHECK_K6_2_M32: #define __tune_k6__ 1 881 // CHECK_K6_2_M32: #define i386 1 882 // RUN: not %clang -march=k6-2 -m64 -E -dM %s -o - 2>&1 \ 883 // RUN: -target i386-unknown-linux \ 884 // RUN: | FileCheck %s -check-prefix=CHECK_K6_2_M64 885 // CHECK_K6_2_M64: error: 886 // 887 // RUN: %clang -march=k6-3 -m32 -E -dM %s -o - 2>&1 \ 888 // RUN: -target i386-unknown-linux \ 889 // RUN: | FileCheck %s -check-prefix=CHECK_K6_3_M32 890 // CHECK_K6_3_M32: #define __3dNOW__ 1 891 // CHECK_K6_3_M32: #define __MMX__ 1 892 // CHECK_K6_3_M32: #define __i386 1 893 // CHECK_K6_3_M32: #define __i386__ 1 894 // CHECK_K6_3_M32: #define __k6 1 895 // CHECK_K6_3_M32: #define __k6_3__ 1 896 // CHECK_K6_3_M32: #define __k6__ 1 897 // CHECK_K6_3_M32: #define __tune_k6_3__ 1 898 // CHECK_K6_3_M32: #define __tune_k6__ 1 899 // CHECK_K6_3_M32: #define i386 1 900 // RUN: not %clang -march=k6-3 -m64 -E -dM %s -o - 2>&1 \ 901 // RUN: -target i386-unknown-linux \ 902 // RUN: | FileCheck %s -check-prefix=CHECK_K6_3_M64 903 // CHECK_K6_3_M64: error: 904 // 905 // RUN: %clang -march=athlon -m32 -E -dM %s -o - 2>&1 \ 906 // RUN: -target i386-unknown-linux \ 907 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_M32 908 // CHECK_ATHLON_M32: #define __3dNOW_A__ 1 909 // CHECK_ATHLON_M32: #define __3dNOW__ 1 910 // CHECK_ATHLON_M32: #define __MMX__ 1 911 // CHECK_ATHLON_M32: #define __athlon 1 912 // CHECK_ATHLON_M32: #define __athlon__ 1 913 // CHECK_ATHLON_M32: #define __i386 1 914 // CHECK_ATHLON_M32: #define __i386__ 1 915 // CHECK_ATHLON_M32: #define __tune_athlon__ 1 916 // CHECK_ATHLON_M32: #define i386 1 917 // RUN: not %clang -march=athlon -m64 -E -dM %s -o - 2>&1 \ 918 // RUN: -target i386-unknown-linux \ 919 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_M64 920 // CHECK_ATHLON_M64: error: 921 // 922 // RUN: %clang -march=athlon-tbird -m32 -E -dM %s -o - 2>&1 \ 923 // RUN: -target i386-unknown-linux \ 924 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_TBIRD_M32 925 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW_A__ 1 926 // CHECK_ATHLON_TBIRD_M32: #define __3dNOW__ 1 927 // CHECK_ATHLON_TBIRD_M32: #define __MMX__ 1 928 // CHECK_ATHLON_TBIRD_M32: #define __athlon 1 929 // CHECK_ATHLON_TBIRD_M32: #define __athlon__ 1 930 // CHECK_ATHLON_TBIRD_M32: #define __i386 1 931 // CHECK_ATHLON_TBIRD_M32: #define __i386__ 1 932 // CHECK_ATHLON_TBIRD_M32: #define __tune_athlon__ 1 933 // CHECK_ATHLON_TBIRD_M32: #define i386 1 934 // RUN: not %clang -march=athlon-tbird -m64 -E -dM %s -o - 2>&1 \ 935 // RUN: -target i386-unknown-linux \ 936 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_TBIRD_M64 937 // CHECK_ATHLON_TBIRD_M64: error: 938 // 939 // RUN: %clang -march=athlon-4 -m32 -E -dM %s -o - 2>&1 \ 940 // RUN: -target i386-unknown-linux \ 941 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_4_M32 942 // CHECK_ATHLON_4_M32: #define __3dNOW_A__ 1 943 // CHECK_ATHLON_4_M32: #define __3dNOW__ 1 944 // CHECK_ATHLON_4_M32: #define __MMX__ 1 945 // CHECK_ATHLON_4_M32: #define __SSE__ 1 946 // CHECK_ATHLON_4_M32: #define __athlon 1 947 // CHECK_ATHLON_4_M32: #define __athlon__ 1 948 // CHECK_ATHLON_4_M32: #define __athlon_sse__ 1 949 // CHECK_ATHLON_4_M32: #define __i386 1 950 // CHECK_ATHLON_4_M32: #define __i386__ 1 951 // CHECK_ATHLON_4_M32: #define __tune_athlon__ 1 952 // CHECK_ATHLON_4_M32: #define __tune_athlon_sse__ 1 953 // CHECK_ATHLON_4_M32: #define i386 1 954 // RUN: not %clang -march=athlon-4 -m64 -E -dM %s -o - 2>&1 \ 955 // RUN: -target i386-unknown-linux \ 956 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_4_M64 957 // CHECK_ATHLON_4_M64: error: 958 // 959 // RUN: %clang -march=athlon-xp -m32 -E -dM %s -o - 2>&1 \ 960 // RUN: -target i386-unknown-linux \ 961 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_XP_M32 962 // CHECK_ATHLON_XP_M32: #define __3dNOW_A__ 1 963 // CHECK_ATHLON_XP_M32: #define __3dNOW__ 1 964 // CHECK_ATHLON_XP_M32: #define __MMX__ 1 965 // CHECK_ATHLON_XP_M32: #define __SSE__ 1 966 // CHECK_ATHLON_XP_M32: #define __athlon 1 967 // CHECK_ATHLON_XP_M32: #define __athlon__ 1 968 // CHECK_ATHLON_XP_M32: #define __athlon_sse__ 1 969 // CHECK_ATHLON_XP_M32: #define __i386 1 970 // CHECK_ATHLON_XP_M32: #define __i386__ 1 971 // CHECK_ATHLON_XP_M32: #define __tune_athlon__ 1 972 // CHECK_ATHLON_XP_M32: #define __tune_athlon_sse__ 1 973 // CHECK_ATHLON_XP_M32: #define i386 1 974 // RUN: not %clang -march=athlon-xp -m64 -E -dM %s -o - 2>&1 \ 975 // RUN: -target i386-unknown-linux \ 976 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_XP_M64 977 // CHECK_ATHLON_XP_M64: error: 978 // 979 // RUN: %clang -march=athlon-mp -m32 -E -dM %s -o - 2>&1 \ 980 // RUN: -target i386-unknown-linux \ 981 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_MP_M32 982 // CHECK_ATHLON_MP_M32: #define __3dNOW_A__ 1 983 // CHECK_ATHLON_MP_M32: #define __3dNOW__ 1 984 // CHECK_ATHLON_MP_M32: #define __MMX__ 1 985 // CHECK_ATHLON_MP_M32: #define __SSE__ 1 986 // CHECK_ATHLON_MP_M32: #define __athlon 1 987 // CHECK_ATHLON_MP_M32: #define __athlon__ 1 988 // CHECK_ATHLON_MP_M32: #define __athlon_sse__ 1 989 // CHECK_ATHLON_MP_M32: #define __i386 1 990 // CHECK_ATHLON_MP_M32: #define __i386__ 1 991 // CHECK_ATHLON_MP_M32: #define __tune_athlon__ 1 992 // CHECK_ATHLON_MP_M32: #define __tune_athlon_sse__ 1 993 // CHECK_ATHLON_MP_M32: #define i386 1 994 // RUN: not %clang -march=athlon-mp -m64 -E -dM %s -o - 2>&1 \ 995 // RUN: -target i386-unknown-linux \ 996 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_MP_M64 997 // CHECK_ATHLON_MP_M64: error: 998 // 999 // RUN: %clang -march=x86-64 -m32 -E -dM %s -o - 2>&1 \ 1000 // RUN: -target i386-unknown-linux \ 1001 // RUN: | FileCheck %s -check-prefix=CHECK_X86_64_M32 1002 // CHECK_X86_64_M32: #define __MMX__ 1 1003 // CHECK_X86_64_M32: #define __SSE2__ 1 1004 // CHECK_X86_64_M32: #define __SSE__ 1 1005 // CHECK_X86_64_M32: #define __i386 1 1006 // CHECK_X86_64_M32: #define __i386__ 1 1007 // CHECK_X86_64_M32: #define __k8 1 1008 // CHECK_X86_64_M32: #define __k8__ 1 1009 // CHECK_X86_64_M32: #define i386 1 1010 // RUN: %clang -march=x86-64 -m64 -E -dM %s -o - 2>&1 \ 1011 // RUN: -target i386-unknown-linux \ 1012 // RUN: | FileCheck %s -check-prefix=CHECK_X86_64_M64 1013 // CHECK_X86_64_M64: #define __MMX__ 1 1014 // CHECK_X86_64_M64: #define __SSE2_MATH__ 1 1015 // CHECK_X86_64_M64: #define __SSE2__ 1 1016 // CHECK_X86_64_M64: #define __SSE_MATH__ 1 1017 // CHECK_X86_64_M64: #define __SSE__ 1 1018 // CHECK_X86_64_M64: #define __amd64 1 1019 // CHECK_X86_64_M64: #define __amd64__ 1 1020 // CHECK_X86_64_M64: #define __k8 1 1021 // CHECK_X86_64_M64: #define __k8__ 1 1022 // CHECK_X86_64_M64: #define __x86_64 1 1023 // CHECK_X86_64_M64: #define __x86_64__ 1 1024 // 1025 // RUN: %clang -march=k8 -m32 -E -dM %s -o - 2>&1 \ 1026 // RUN: -target i386-unknown-linux \ 1027 // RUN: | FileCheck %s -check-prefix=CHECK_K8_M32 1028 // CHECK_K8_M32: #define __3dNOW_A__ 1 1029 // CHECK_K8_M32: #define __3dNOW__ 1 1030 // CHECK_K8_M32: #define __MMX__ 1 1031 // CHECK_K8_M32: #define __SSE2__ 1 1032 // CHECK_K8_M32: #define __SSE__ 1 1033 // CHECK_K8_M32: #define __i386 1 1034 // CHECK_K8_M32: #define __i386__ 1 1035 // CHECK_K8_M32: #define __k8 1 1036 // CHECK_K8_M32: #define __k8__ 1 1037 // CHECK_K8_M32: #define __tune_k8__ 1 1038 // CHECK_K8_M32: #define i386 1 1039 // RUN: %clang -march=k8 -m64 -E -dM %s -o - 2>&1 \ 1040 // RUN: -target i386-unknown-linux \ 1041 // RUN: | FileCheck %s -check-prefix=CHECK_K8_M64 1042 // CHECK_K8_M64: #define __3dNOW_A__ 1 1043 // CHECK_K8_M64: #define __3dNOW__ 1 1044 // CHECK_K8_M64: #define __MMX__ 1 1045 // CHECK_K8_M64: #define __SSE2_MATH__ 1 1046 // CHECK_K8_M64: #define __SSE2__ 1 1047 // CHECK_K8_M64: #define __SSE_MATH__ 1 1048 // CHECK_K8_M64: #define __SSE__ 1 1049 // CHECK_K8_M64: #define __amd64 1 1050 // CHECK_K8_M64: #define __amd64__ 1 1051 // CHECK_K8_M64: #define __k8 1 1052 // CHECK_K8_M64: #define __k8__ 1 1053 // CHECK_K8_M64: #define __tune_k8__ 1 1054 // CHECK_K8_M64: #define __x86_64 1 1055 // CHECK_K8_M64: #define __x86_64__ 1 1056 // 1057 // RUN: %clang -march=k8-sse3 -m32 -E -dM %s -o - 2>&1 \ 1058 // RUN: -target i386-unknown-linux \ 1059 // RUN: | FileCheck %s -check-prefix=CHECK_K8_SSE3_M32 1060 // CHECK_K8_SSE3_M32: #define __3dNOW_A__ 1 1061 // CHECK_K8_SSE3_M32: #define __3dNOW__ 1 1062 // CHECK_K8_SSE3_M32: #define __MMX__ 1 1063 // CHECK_K8_SSE3_M32: #define __SSE2__ 1 1064 // CHECK_K8_SSE3_M32: #define __SSE3__ 1 1065 // CHECK_K8_SSE3_M32: #define __SSE__ 1 1066 // CHECK_K8_SSE3_M32: #define __i386 1 1067 // CHECK_K8_SSE3_M32: #define __i386__ 1 1068 // CHECK_K8_SSE3_M32: #define __k8 1 1069 // CHECK_K8_SSE3_M32: #define __k8__ 1 1070 // CHECK_K8_SSE3_M32: #define __tune_k8__ 1 1071 // CHECK_K8_SSE3_M32: #define i386 1 1072 // RUN: %clang -march=k8-sse3 -m64 -E -dM %s -o - 2>&1 \ 1073 // RUN: -target i386-unknown-linux \ 1074 // RUN: | FileCheck %s -check-prefix=CHECK_K8_SSE3_M64 1075 // CHECK_K8_SSE3_M64: #define __3dNOW_A__ 1 1076 // CHECK_K8_SSE3_M64: #define __3dNOW__ 1 1077 // CHECK_K8_SSE3_M64: #define __MMX__ 1 1078 // CHECK_K8_SSE3_M64: #define __SSE2_MATH__ 1 1079 // CHECK_K8_SSE3_M64: #define __SSE2__ 1 1080 // CHECK_K8_SSE3_M64: #define __SSE3__ 1 1081 // CHECK_K8_SSE3_M64: #define __SSE_MATH__ 1 1082 // CHECK_K8_SSE3_M64: #define __SSE__ 1 1083 // CHECK_K8_SSE3_M64: #define __amd64 1 1084 // CHECK_K8_SSE3_M64: #define __amd64__ 1 1085 // CHECK_K8_SSE3_M64: #define __k8 1 1086 // CHECK_K8_SSE3_M64: #define __k8__ 1 1087 // CHECK_K8_SSE3_M64: #define __tune_k8__ 1 1088 // CHECK_K8_SSE3_M64: #define __x86_64 1 1089 // CHECK_K8_SSE3_M64: #define __x86_64__ 1 1090 // 1091 // RUN: %clang -march=opteron -m32 -E -dM %s -o - 2>&1 \ 1092 // RUN: -target i386-unknown-linux \ 1093 // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_M32 1094 // CHECK_OPTERON_M32: #define __3dNOW_A__ 1 1095 // CHECK_OPTERON_M32: #define __3dNOW__ 1 1096 // CHECK_OPTERON_M32: #define __MMX__ 1 1097 // CHECK_OPTERON_M32: #define __SSE2__ 1 1098 // CHECK_OPTERON_M32: #define __SSE__ 1 1099 // CHECK_OPTERON_M32: #define __i386 1 1100 // CHECK_OPTERON_M32: #define __i386__ 1 1101 // CHECK_OPTERON_M32: #define __k8 1 1102 // CHECK_OPTERON_M32: #define __k8__ 1 1103 // CHECK_OPTERON_M32: #define __tune_k8__ 1 1104 // CHECK_OPTERON_M32: #define i386 1 1105 // RUN: %clang -march=opteron -m64 -E -dM %s -o - 2>&1 \ 1106 // RUN: -target i386-unknown-linux \ 1107 // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_M64 1108 // CHECK_OPTERON_M64: #define __3dNOW_A__ 1 1109 // CHECK_OPTERON_M64: #define __3dNOW__ 1 1110 // CHECK_OPTERON_M64: #define __MMX__ 1 1111 // CHECK_OPTERON_M64: #define __SSE2_MATH__ 1 1112 // CHECK_OPTERON_M64: #define __SSE2__ 1 1113 // CHECK_OPTERON_M64: #define __SSE_MATH__ 1 1114 // CHECK_OPTERON_M64: #define __SSE__ 1 1115 // CHECK_OPTERON_M64: #define __amd64 1 1116 // CHECK_OPTERON_M64: #define __amd64__ 1 1117 // CHECK_OPTERON_M64: #define __k8 1 1118 // CHECK_OPTERON_M64: #define __k8__ 1 1119 // CHECK_OPTERON_M64: #define __tune_k8__ 1 1120 // CHECK_OPTERON_M64: #define __x86_64 1 1121 // CHECK_OPTERON_M64: #define __x86_64__ 1 1122 // 1123 // RUN: %clang -march=opteron-sse3 -m32 -E -dM %s -o - 2>&1 \ 1124 // RUN: -target i386-unknown-linux \ 1125 // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M32 1126 // CHECK_OPTERON_SSE3_M32: #define __3dNOW_A__ 1 1127 // CHECK_OPTERON_SSE3_M32: #define __3dNOW__ 1 1128 // CHECK_OPTERON_SSE3_M32: #define __MMX__ 1 1129 // CHECK_OPTERON_SSE3_M32: #define __SSE2__ 1 1130 // CHECK_OPTERON_SSE3_M32: #define __SSE3__ 1 1131 // CHECK_OPTERON_SSE3_M32: #define __SSE__ 1 1132 // CHECK_OPTERON_SSE3_M32: #define __i386 1 1133 // CHECK_OPTERON_SSE3_M32: #define __i386__ 1 1134 // CHECK_OPTERON_SSE3_M32: #define __k8 1 1135 // CHECK_OPTERON_SSE3_M32: #define __k8__ 1 1136 // CHECK_OPTERON_SSE3_M32: #define __tune_k8__ 1 1137 // CHECK_OPTERON_SSE3_M32: #define i386 1 1138 // RUN: %clang -march=opteron-sse3 -m64 -E -dM %s -o - 2>&1 \ 1139 // RUN: -target i386-unknown-linux \ 1140 // RUN: | FileCheck %s -check-prefix=CHECK_OPTERON_SSE3_M64 1141 // CHECK_OPTERON_SSE3_M64: #define __3dNOW_A__ 1 1142 // CHECK_OPTERON_SSE3_M64: #define __3dNOW__ 1 1143 // CHECK_OPTERON_SSE3_M64: #define __MMX__ 1 1144 // CHECK_OPTERON_SSE3_M64: #define __SSE2_MATH__ 1 1145 // CHECK_OPTERON_SSE3_M64: #define __SSE2__ 1 1146 // CHECK_OPTERON_SSE3_M64: #define __SSE3__ 1 1147 // CHECK_OPTERON_SSE3_M64: #define __SSE_MATH__ 1 1148 // CHECK_OPTERON_SSE3_M64: #define __SSE__ 1 1149 // CHECK_OPTERON_SSE3_M64: #define __amd64 1 1150 // CHECK_OPTERON_SSE3_M64: #define __amd64__ 1 1151 // CHECK_OPTERON_SSE3_M64: #define __k8 1 1152 // CHECK_OPTERON_SSE3_M64: #define __k8__ 1 1153 // CHECK_OPTERON_SSE3_M64: #define __tune_k8__ 1 1154 // CHECK_OPTERON_SSE3_M64: #define __x86_64 1 1155 // CHECK_OPTERON_SSE3_M64: #define __x86_64__ 1 1156 // 1157 // RUN: %clang -march=athlon64 -m32 -E -dM %s -o - 2>&1 \ 1158 // RUN: -target i386-unknown-linux \ 1159 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_M32 1160 // CHECK_ATHLON64_M32: #define __3dNOW_A__ 1 1161 // CHECK_ATHLON64_M32: #define __3dNOW__ 1 1162 // CHECK_ATHLON64_M32: #define __MMX__ 1 1163 // CHECK_ATHLON64_M32: #define __SSE2__ 1 1164 // CHECK_ATHLON64_M32: #define __SSE__ 1 1165 // CHECK_ATHLON64_M32: #define __i386 1 1166 // CHECK_ATHLON64_M32: #define __i386__ 1 1167 // CHECK_ATHLON64_M32: #define __k8 1 1168 // CHECK_ATHLON64_M32: #define __k8__ 1 1169 // CHECK_ATHLON64_M32: #define __tune_k8__ 1 1170 // CHECK_ATHLON64_M32: #define i386 1 1171 // RUN: %clang -march=athlon64 -m64 -E -dM %s -o - 2>&1 \ 1172 // RUN: -target i386-unknown-linux \ 1173 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_M64 1174 // CHECK_ATHLON64_M64: #define __3dNOW_A__ 1 1175 // CHECK_ATHLON64_M64: #define __3dNOW__ 1 1176 // CHECK_ATHLON64_M64: #define __MMX__ 1 1177 // CHECK_ATHLON64_M64: #define __SSE2_MATH__ 1 1178 // CHECK_ATHLON64_M64: #define __SSE2__ 1 1179 // CHECK_ATHLON64_M64: #define __SSE_MATH__ 1 1180 // CHECK_ATHLON64_M64: #define __SSE__ 1 1181 // CHECK_ATHLON64_M64: #define __amd64 1 1182 // CHECK_ATHLON64_M64: #define __amd64__ 1 1183 // CHECK_ATHLON64_M64: #define __k8 1 1184 // CHECK_ATHLON64_M64: #define __k8__ 1 1185 // CHECK_ATHLON64_M64: #define __tune_k8__ 1 1186 // CHECK_ATHLON64_M64: #define __x86_64 1 1187 // CHECK_ATHLON64_M64: #define __x86_64__ 1 1188 // 1189 // RUN: %clang -march=athlon64-sse3 -m32 -E -dM %s -o - 2>&1 \ 1190 // RUN: -target i386-unknown-linux \ 1191 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M32 1192 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW_A__ 1 1193 // CHECK_ATHLON64_SSE3_M32: #define __3dNOW__ 1 1194 // CHECK_ATHLON64_SSE3_M32: #define __MMX__ 1 1195 // CHECK_ATHLON64_SSE3_M32: #define __SSE2__ 1 1196 // CHECK_ATHLON64_SSE3_M32: #define __SSE3__ 1 1197 // CHECK_ATHLON64_SSE3_M32: #define __SSE__ 1 1198 // CHECK_ATHLON64_SSE3_M32: #define __i386 1 1199 // CHECK_ATHLON64_SSE3_M32: #define __i386__ 1 1200 // CHECK_ATHLON64_SSE3_M32: #define __k8 1 1201 // CHECK_ATHLON64_SSE3_M32: #define __k8__ 1 1202 // CHECK_ATHLON64_SSE3_M32: #define __tune_k8__ 1 1203 // CHECK_ATHLON64_SSE3_M32: #define i386 1 1204 // RUN: %clang -march=athlon64-sse3 -m64 -E -dM %s -o - 2>&1 \ 1205 // RUN: -target i386-unknown-linux \ 1206 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON64_SSE3_M64 1207 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW_A__ 1 1208 // CHECK_ATHLON64_SSE3_M64: #define __3dNOW__ 1 1209 // CHECK_ATHLON64_SSE3_M64: #define __MMX__ 1 1210 // CHECK_ATHLON64_SSE3_M64: #define __SSE2_MATH__ 1 1211 // CHECK_ATHLON64_SSE3_M64: #define __SSE2__ 1 1212 // CHECK_ATHLON64_SSE3_M64: #define __SSE3__ 1 1213 // CHECK_ATHLON64_SSE3_M64: #define __SSE_MATH__ 1 1214 // CHECK_ATHLON64_SSE3_M64: #define __SSE__ 1 1215 // CHECK_ATHLON64_SSE3_M64: #define __amd64 1 1216 // CHECK_ATHLON64_SSE3_M64: #define __amd64__ 1 1217 // CHECK_ATHLON64_SSE3_M64: #define __k8 1 1218 // CHECK_ATHLON64_SSE3_M64: #define __k8__ 1 1219 // CHECK_ATHLON64_SSE3_M64: #define __tune_k8__ 1 1220 // CHECK_ATHLON64_SSE3_M64: #define __x86_64 1 1221 // CHECK_ATHLON64_SSE3_M64: #define __x86_64__ 1 1222 // 1223 // RUN: %clang -march=athlon-fx -m32 -E -dM %s -o - 2>&1 \ 1224 // RUN: -target i386-unknown-linux \ 1225 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M32 1226 // CHECK_ATHLON_FX_M32: #define __3dNOW_A__ 1 1227 // CHECK_ATHLON_FX_M32: #define __3dNOW__ 1 1228 // CHECK_ATHLON_FX_M32: #define __MMX__ 1 1229 // CHECK_ATHLON_FX_M32: #define __SSE2__ 1 1230 // CHECK_ATHLON_FX_M32: #define __SSE__ 1 1231 // CHECK_ATHLON_FX_M32: #define __i386 1 1232 // CHECK_ATHLON_FX_M32: #define __i386__ 1 1233 // CHECK_ATHLON_FX_M32: #define __k8 1 1234 // CHECK_ATHLON_FX_M32: #define __k8__ 1 1235 // CHECK_ATHLON_FX_M32: #define __tune_k8__ 1 1236 // CHECK_ATHLON_FX_M32: #define i386 1 1237 // RUN: %clang -march=athlon-fx -m64 -E -dM %s -o - 2>&1 \ 1238 // RUN: -target i386-unknown-linux \ 1239 // RUN: | FileCheck %s -check-prefix=CHECK_ATHLON_FX_M64 1240 // CHECK_ATHLON_FX_M64: #define __3dNOW_A__ 1 1241 // CHECK_ATHLON_FX_M64: #define __3dNOW__ 1 1242 // CHECK_ATHLON_FX_M64: #define __MMX__ 1 1243 // CHECK_ATHLON_FX_M64: #define __SSE2_MATH__ 1 1244 // CHECK_ATHLON_FX_M64: #define __SSE2__ 1 1245 // CHECK_ATHLON_FX_M64: #define __SSE_MATH__ 1 1246 // CHECK_ATHLON_FX_M64: #define __SSE__ 1 1247 // CHECK_ATHLON_FX_M64: #define __amd64 1 1248 // CHECK_ATHLON_FX_M64: #define __amd64__ 1 1249 // CHECK_ATHLON_FX_M64: #define __k8 1 1250 // CHECK_ATHLON_FX_M64: #define __k8__ 1 1251 // CHECK_ATHLON_FX_M64: #define __tune_k8__ 1 1252 // CHECK_ATHLON_FX_M64: #define __x86_64 1 1253 // CHECK_ATHLON_FX_M64: #define __x86_64__ 1 1254 // RUN: %clang -march=amdfam10 -m32 -E -dM %s -o - 2>&1 \ 1255 // RUN: -target i386-unknown-linux \ 1256 // RUN: | FileCheck %s -check-prefix=CHECK_AMDFAM10_M32 1257 // CHECK_AMDFAM10_M32: #define __3dNOW_A__ 1 1258 // CHECK_AMDFAM10_M32: #define __3dNOW__ 1 1259 // CHECK_AMDFAM10_M32: #define __LZCNT__ 1 1260 // CHECK_AMDFAM10_M32: #define __MMX__ 1 1261 // CHECK_AMDFAM10_M32: #define __POPCNT__ 1 1262 // CHECK_AMDFAM10_M32: #define __SSE2_MATH__ 1 1263 // CHECK_AMDFAM10_M32: #define __SSE2__ 1 1264 // CHECK_AMDFAM10_M32: #define __SSE3__ 1 1265 // CHECK_AMDFAM10_M32: #define __SSE4A__ 1 1266 // CHECK_AMDFAM10_M32: #define __SSE_MATH__ 1 1267 // CHECK_AMDFAM10_M32: #define __SSE__ 1 1268 // CHECK_AMDFAM10_M32: #define __amdfam10 1 1269 // CHECK_AMDFAM10_M32: #define __amdfam10__ 1 1270 // CHECK_AMDFAM10_M32: #define __i386 1 1271 // CHECK_AMDFAM10_M32: #define __i386__ 1 1272 // CHECK_AMDFAM10_M32: #define __tune_amdfam10__ 1 1273 // RUN: %clang -march=amdfam10 -m64 -E -dM %s -o - 2>&1 \ 1274 // RUN: -target i386-unknown-linux \ 1275 // RUN: | FileCheck %s -check-prefix=CHECK_AMDFAM10_M64 1276 // CHECK_AMDFAM10_M64: #define __3dNOW_A__ 1 1277 // CHECK_AMDFAM10_M64: #define __3dNOW__ 1 1278 // CHECK_AMDFAM10_M64: #define __LZCNT__ 1 1279 // CHECK_AMDFAM10_M64: #define __MMX__ 1 1280 // CHECK_AMDFAM10_M64: #define __POPCNT__ 1 1281 // CHECK_AMDFAM10_M64: #define __SSE2_MATH__ 1 1282 // CHECK_AMDFAM10_M64: #define __SSE2__ 1 1283 // CHECK_AMDFAM10_M64: #define __SSE3__ 1 1284 // CHECK_AMDFAM10_M64: #define __SSE4A__ 1 1285 // CHECK_AMDFAM10_M64: #define __SSE_MATH__ 1 1286 // CHECK_AMDFAM10_M64: #define __SSE__ 1 1287 // CHECK_AMDFAM10_M64: #define __amd64 1 1288 // CHECK_AMDFAM10_M64: #define __amd64__ 1 1289 // CHECK_AMDFAM10_M64: #define __amdfam10 1 1290 // CHECK_AMDFAM10_M64: #define __amdfam10__ 1 1291 // CHECK_AMDFAM10_M64: #define __tune_amdfam10__ 1 1292 // CHECK_AMDFAM10_M64: #define __x86_64 1 1293 // CHECK_AMDFAM10_M64: #define __x86_64__ 1 1294 // RUN: %clang -march=btver1 -m32 -E -dM %s -o - 2>&1 \ 1295 // RUN: -target i386-unknown-linux \ 1296 // RUN: | FileCheck %s -check-prefix=CHECK_BTVER1_M32 1297 // CHECK_BTVER1_M32-NOT: #define __3dNOW_A__ 1 1298 // CHECK_BTVER1_M32-NOT: #define __3dNOW__ 1 1299 // CHECK_BTVER1_M32: #define __LZCNT__ 1 1300 // CHECK_BTVER1_M32: #define __MMX__ 1 1301 // CHECK_BTVER1_M32: #define __POPCNT__ 1 1302 // CHECK_BTVER1_M32: #define __PRFCHW__ 1 1303 // CHECK_BTVER1_M32: #define __SSE2_MATH__ 1 1304 // CHECK_BTVER1_M32: #define __SSE2__ 1 1305 // CHECK_BTVER1_M32: #define __SSE3__ 1 1306 // CHECK_BTVER1_M32: #define __SSE4A__ 1 1307 // CHECK_BTVER1_M32: #define __SSE_MATH__ 1 1308 // CHECK_BTVER1_M32: #define __SSE__ 1 1309 // CHECK_BTVER1_M32: #define __SSSE3__ 1 1310 // CHECK_BTVER1_M32: #define __btver1 1 1311 // CHECK_BTVER1_M32: #define __btver1__ 1 1312 // CHECK_BTVER1_M32: #define __i386 1 1313 // CHECK_BTVER1_M32: #define __i386__ 1 1314 // CHECK_BTVER1_M32: #define __tune_btver1__ 1 1315 // RUN: %clang -march=btver1 -m64 -E -dM %s -o - 2>&1 \ 1316 // RUN: -target i386-unknown-linux \ 1317 // RUN: | FileCheck %s -check-prefix=CHECK_BTVER1_M64 1318 // CHECK_BTVER1_M64-NOT: #define __3dNOW_A__ 1 1319 // CHECK_BTVER1_M64-NOT: #define __3dNOW__ 1 1320 // CHECK_BTVER1_M64: #define __LZCNT__ 1 1321 // CHECK_BTVER1_M64: #define __MMX__ 1 1322 // CHECK_BTVER1_M64: #define __POPCNT__ 1 1323 // CHECK_BTVER1_M64: #define __PRFCHW__ 1 1324 // CHECK_BTVER1_M64: #define __SSE2_MATH__ 1 1325 // CHECK_BTVER1_M64: #define __SSE2__ 1 1326 // CHECK_BTVER1_M64: #define __SSE3__ 1 1327 // CHECK_BTVER1_M64: #define __SSE4A__ 1 1328 // CHECK_BTVER1_M64: #define __SSE_MATH__ 1 1329 // CHECK_BTVER1_M64: #define __SSE__ 1 1330 // CHECK_BTVER1_M64: #define __SSSE3__ 1 1331 // CHECK_BTVER1_M64: #define __amd64 1 1332 // CHECK_BTVER1_M64: #define __amd64__ 1 1333 // CHECK_BTVER1_M64: #define __btver1 1 1334 // CHECK_BTVER1_M64: #define __btver1__ 1 1335 // CHECK_BTVER1_M64: #define __tune_btver1__ 1 1336 // CHECK_BTVER1_M64: #define __x86_64 1 1337 // CHECK_BTVER1_M64: #define __x86_64__ 1 1338 // RUN: %clang -march=btver2 -m32 -E -dM %s -o - 2>&1 \ 1339 // RUN: -target i386-unknown-linux \ 1340 // RUN: | FileCheck %s -check-prefix=CHECK_BTVER2_M32 1341 // CHECK_BTVER2_M32-NOT: #define __3dNOW_A__ 1 1342 // CHECK_BTVER2_M32-NOT: #define __3dNOW__ 1 1343 // CHECK_BTVER2_M32: #define __AES__ 1 1344 // CHECK_BTVER2_M32: #define __AVX__ 1 1345 // CHECK_BTVER2_M32: #define __BMI__ 1 1346 // CHECK_BTVER2_M32: #define __F16C__ 1 1347 // CHECK_BTVER2_M32: #define __LZCNT__ 1 1348 // CHECK_BTVER2_M32: #define __MMX__ 1 1349 // CHECK_BTVER2_M32: #define __PCLMUL__ 1 1350 // CHECK_BTVER2_M32: #define __POPCNT__ 1 1351 // CHECK_BTVER2_M32: #define __PRFCHW__ 1 1352 // CHECK_BTVER2_M32: #define __SSE2_MATH__ 1 1353 // CHECK_BTVER2_M32: #define __SSE2__ 1 1354 // CHECK_BTVER2_M32: #define __SSE3__ 1 1355 // CHECK_BTVER2_M32: #define __SSE4A__ 1 1356 // CHECK_BTVER2_M32: #define __SSE_MATH__ 1 1357 // CHECK_BTVER2_M32: #define __SSE__ 1 1358 // CHECK_BTVER2_M32: #define __SSSE3__ 1 1359 // CHECK_BTVER2_M32: #define __btver2 1 1360 // CHECK_BTVER2_M32: #define __btver2__ 1 1361 // CHECK_BTVER2_M32: #define __i386 1 1362 // CHECK_BTVER2_M32: #define __i386__ 1 1363 // CHECK_BTVER2_M32: #define __tune_btver2__ 1 1364 // RUN: %clang -march=btver2 -m64 -E -dM %s -o - 2>&1 \ 1365 // RUN: -target i386-unknown-linux \ 1366 // RUN: | FileCheck %s -check-prefix=CHECK_BTVER2_M64 1367 // CHECK_BTVER2_M64-NOT: #define __3dNOW_A__ 1 1368 // CHECK_BTVER2_M64-NOT: #define __3dNOW__ 1 1369 // CHECK_BTVER2_M64: #define __AES__ 1 1370 // CHECK_BTVER2_M64: #define __AVX__ 1 1371 // CHECK_BTVER2_M64: #define __BMI__ 1 1372 // CHECK_BTVER2_M64: #define __F16C__ 1 1373 // CHECK_BTVER2_M64: #define __LZCNT__ 1 1374 // CHECK_BTVER2_M64: #define __MMX__ 1 1375 // CHECK_BTVER2_M64: #define __PCLMUL__ 1 1376 // CHECK_BTVER2_M64: #define __POPCNT__ 1 1377 // CHECK_BTVER2_M64: #define __PRFCHW__ 1 1378 // CHECK_BTVER2_M64: #define __SSE2_MATH__ 1 1379 // CHECK_BTVER2_M64: #define __SSE2__ 1 1380 // CHECK_BTVER2_M64: #define __SSE3__ 1 1381 // CHECK_BTVER2_M64: #define __SSE4A__ 1 1382 // CHECK_BTVER2_M64: #define __SSE_MATH__ 1 1383 // CHECK_BTVER2_M64: #define __SSE__ 1 1384 // CHECK_BTVER2_M64: #define __SSSE3__ 1 1385 // CHECK_BTVER2_M64: #define __amd64 1 1386 // CHECK_BTVER2_M64: #define __amd64__ 1 1387 // CHECK_BTVER2_M64: #define __btver2 1 1388 // CHECK_BTVER2_M64: #define __btver2__ 1 1389 // CHECK_BTVER2_M64: #define __tune_btver2__ 1 1390 // CHECK_BTVER2_M64: #define __x86_64 1 1391 // CHECK_BTVER2_M64: #define __x86_64__ 1 1392 // RUN: %clang -march=bdver1 -m32 -E -dM %s -o - 2>&1 \ 1393 // RUN: -target i386-unknown-linux \ 1394 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER1_M32 1395 // CHECK_BDVER1_M32-NOT: #define __3dNOW_A__ 1 1396 // CHECK_BDVER1_M32-NOT: #define __3dNOW__ 1 1397 // CHECK_BDVER1_M32: #define __AES__ 1 1398 // CHECK_BDVER1_M32: #define __AVX__ 1 1399 // CHECK_BDVER1_M32: #define __FMA4__ 1 1400 // CHECK_BDVER1_M32: #define __LZCNT__ 1 1401 // CHECK_BDVER1_M32: #define __MMX__ 1 1402 // CHECK_BDVER1_M32: #define __PCLMUL__ 1 1403 // CHECK_BDVER1_M32: #define __POPCNT__ 1 1404 // CHECK_BDVER1_M32: #define __PRFCHW__ 1 1405 // CHECK_BDVER1_M32: #define __SSE2_MATH__ 1 1406 // CHECK_BDVER1_M32: #define __SSE2__ 1 1407 // CHECK_BDVER1_M32: #define __SSE3__ 1 1408 // CHECK_BDVER1_M32: #define __SSE4A__ 1 1409 // CHECK_BDVER1_M32: #define __SSE4_1__ 1 1410 // CHECK_BDVER1_M32: #define __SSE4_2__ 1 1411 // CHECK_BDVER1_M32: #define __SSE_MATH__ 1 1412 // CHECK_BDVER1_M32: #define __SSE__ 1 1413 // CHECK_BDVER1_M32: #define __SSSE3__ 1 1414 // CHECK_BDVER1_M32: #define __XOP__ 1 1415 // CHECK_BDVER1_M32: #define __bdver1 1 1416 // CHECK_BDVER1_M32: #define __bdver1__ 1 1417 // CHECK_BDVER1_M32: #define __i386 1 1418 // CHECK_BDVER1_M32: #define __i386__ 1 1419 // CHECK_BDVER1_M32: #define __tune_bdver1__ 1 1420 // RUN: %clang -march=bdver1 -m64 -E -dM %s -o - 2>&1 \ 1421 // RUN: -target i386-unknown-linux \ 1422 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER1_M64 1423 // CHECK_BDVER1_M64-NOT: #define __3dNOW_A__ 1 1424 // CHECK_BDVER1_M64-NOT: #define __3dNOW__ 1 1425 // CHECK_BDVER1_M64: #define __AES__ 1 1426 // CHECK_BDVER1_M64: #define __AVX__ 1 1427 // CHECK_BDVER1_M64: #define __FMA4__ 1 1428 // CHECK_BDVER1_M64: #define __LZCNT__ 1 1429 // CHECK_BDVER1_M64: #define __MMX__ 1 1430 // CHECK_BDVER1_M64: #define __PCLMUL__ 1 1431 // CHECK_BDVER1_M64: #define __POPCNT__ 1 1432 // CHECK_BDVER1_M64: #define __PRFCHW__ 1 1433 // CHECK_BDVER1_M64: #define __SSE2_MATH__ 1 1434 // CHECK_BDVER1_M64: #define __SSE2__ 1 1435 // CHECK_BDVER1_M64: #define __SSE3__ 1 1436 // CHECK_BDVER1_M64: #define __SSE4A__ 1 1437 // CHECK_BDVER1_M64: #define __SSE4_1__ 1 1438 // CHECK_BDVER1_M64: #define __SSE4_2__ 1 1439 // CHECK_BDVER1_M64: #define __SSE_MATH__ 1 1440 // CHECK_BDVER1_M64: #define __SSE__ 1 1441 // CHECK_BDVER1_M64: #define __SSSE3__ 1 1442 // CHECK_BDVER1_M64: #define __XOP__ 1 1443 // CHECK_BDVER1_M64: #define __amd64 1 1444 // CHECK_BDVER1_M64: #define __amd64__ 1 1445 // CHECK_BDVER1_M64: #define __bdver1 1 1446 // CHECK_BDVER1_M64: #define __bdver1__ 1 1447 // CHECK_BDVER1_M64: #define __tune_bdver1__ 1 1448 // CHECK_BDVER1_M64: #define __x86_64 1 1449 // CHECK_BDVER1_M64: #define __x86_64__ 1 1450 // RUN: %clang -march=bdver2 -m32 -E -dM %s -o - 2>&1 \ 1451 // RUN: -target i386-unknown-linux \ 1452 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER2_M32 1453 // CHECK_BDVER2_M32-NOT: #define __3dNOW_A__ 1 1454 // CHECK_BDVER2_M32-NOT: #define __3dNOW__ 1 1455 // CHECK_BDVER2_M32: #define __AES__ 1 1456 // CHECK_BDVER2_M32: #define __AVX__ 1 1457 // CHECK_BDVER2_M32: #define __BMI__ 1 1458 // CHECK_BDVER2_M32: #define __F16C__ 1 1459 // CHECK_BDVER2_M32: #define __FMA4__ 1 1460 // CHECK_BDVER2_M32: #define __FMA__ 1 1461 // CHECK_BDVER2_M32: #define __LZCNT__ 1 1462 // CHECK_BDVER2_M32: #define __MMX__ 1 1463 // CHECK_BDVER2_M32: #define __PCLMUL__ 1 1464 // CHECK_BDVER2_M32: #define __POPCNT__ 1 1465 // CHECK_BDVER2_M32: #define __PRFCHW__ 1 1466 // CHECK_BDVER2_M32: #define __SSE2_MATH__ 1 1467 // CHECK_BDVER2_M32: #define __SSE2__ 1 1468 // CHECK_BDVER2_M32: #define __SSE3__ 1 1469 // CHECK_BDVER2_M32: #define __SSE4A__ 1 1470 // CHECK_BDVER2_M32: #define __SSE4_1__ 1 1471 // CHECK_BDVER2_M32: #define __SSE4_2__ 1 1472 // CHECK_BDVER2_M32: #define __SSE_MATH__ 1 1473 // CHECK_BDVER2_M32: #define __SSE__ 1 1474 // CHECK_BDVER2_M32: #define __SSSE3__ 1 1475 // CHECK_BDVER2_M32: #define __TBM__ 1 1476 // CHECK_BDVER2_M32: #define __XOP__ 1 1477 // CHECK_BDVER2_M32: #define __bdver2 1 1478 // CHECK_BDVER2_M32: #define __bdver2__ 1 1479 // CHECK_BDVER2_M32: #define __i386 1 1480 // CHECK_BDVER2_M32: #define __i386__ 1 1481 // CHECK_BDVER2_M32: #define __tune_bdver2__ 1 1482 // RUN: %clang -march=bdver2 -m64 -E -dM %s -o - 2>&1 \ 1483 // RUN: -target i386-unknown-linux \ 1484 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER2_M64 1485 // CHECK_BDVER2_M64-NOT: #define __3dNOW_A__ 1 1486 // CHECK_BDVER2_M64-NOT: #define __3dNOW__ 1 1487 // CHECK_BDVER2_M64: #define __AES__ 1 1488 // CHECK_BDVER2_M64: #define __AVX__ 1 1489 // CHECK_BDVER2_M64: #define __BMI__ 1 1490 // CHECK_BDVER2_M64: #define __F16C__ 1 1491 // CHECK_BDVER2_M64: #define __FMA4__ 1 1492 // CHECK_BDVER2_M64: #define __FMA__ 1 1493 // CHECK_BDVER2_M64: #define __LZCNT__ 1 1494 // CHECK_BDVER2_M64: #define __MMX__ 1 1495 // CHECK_BDVER2_M64: #define __PCLMUL__ 1 1496 // CHECK_BDVER2_M64: #define __POPCNT__ 1 1497 // CHECK_BDVER2_M64: #define __PRFCHW__ 1 1498 // CHECK_BDVER2_M64: #define __SSE2_MATH__ 1 1499 // CHECK_BDVER2_M64: #define __SSE2__ 1 1500 // CHECK_BDVER2_M64: #define __SSE3__ 1 1501 // CHECK_BDVER2_M64: #define __SSE4A__ 1 1502 // CHECK_BDVER2_M64: #define __SSE4_1__ 1 1503 // CHECK_BDVER2_M64: #define __SSE4_2__ 1 1504 // CHECK_BDVER2_M64: #define __SSE_MATH__ 1 1505 // CHECK_BDVER2_M64: #define __SSE__ 1 1506 // CHECK_BDVER2_M64: #define __SSSE3__ 1 1507 // CHECK_BDVER2_M64: #define __TBM__ 1 1508 // CHECK_BDVER2_M64: #define __XOP__ 1 1509 // CHECK_BDVER2_M64: #define __amd64 1 1510 // CHECK_BDVER2_M64: #define __amd64__ 1 1511 // CHECK_BDVER2_M64: #define __bdver2 1 1512 // CHECK_BDVER2_M64: #define __bdver2__ 1 1513 // CHECK_BDVER2_M64: #define __tune_bdver2__ 1 1514 // CHECK_BDVER2_M64: #define __x86_64 1 1515 // CHECK_BDVER2_M64: #define __x86_64__ 1 1516 // RUN: %clang -march=bdver3 -m32 -E -dM %s -o - 2>&1 \ 1517 // RUN: -target i386-unknown-linux \ 1518 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER3_M32 1519 // CHECK_BDVER3_M32-NOT: #define __3dNOW_A__ 1 1520 // CHECK_BDVER3_M32-NOT: #define __3dNOW__ 1 1521 // CHECK_BDVER3_M32: #define __AES__ 1 1522 // CHECK_BDVER3_M32: #define __AVX__ 1 1523 // CHECK_BDVER3_M32: #define __BMI__ 1 1524 // CHECK_BDVER3_M32: #define __F16C__ 1 1525 // CHECK_BDVER3_M32: #define __FMA4__ 1 1526 // CHECK_BDVER3_M32: #define __FMA__ 1 1527 // CHECK_BDVER3_M32: #define __FSGSBASE__ 1 1528 // CHECK_BDVER3_M32: #define __LZCNT__ 1 1529 // CHECK_BDVER3_M32: #define __MMX__ 1 1530 // CHECK_BDVER3_M32: #define __PCLMUL__ 1 1531 // CHECK_BDVER3_M32: #define __POPCNT__ 1 1532 // CHECK_BDVER3_M32: #define __PRFCHW__ 1 1533 // CHECK_BDVER3_M32: #define __SSE2_MATH__ 1 1534 // CHECK_BDVER3_M32: #define __SSE2__ 1 1535 // CHECK_BDVER3_M32: #define __SSE3__ 1 1536 // CHECK_BDVER3_M32: #define __SSE4A__ 1 1537 // CHECK_BDVER3_M32: #define __SSE4_1__ 1 1538 // CHECK_BDVER3_M32: #define __SSE4_2__ 1 1539 // CHECK_BDVER3_M32: #define __SSE_MATH__ 1 1540 // CHECK_BDVER3_M32: #define __SSE__ 1 1541 // CHECK_BDVER3_M32: #define __SSSE3__ 1 1542 // CHECK_BDVER3_M32: #define __TBM__ 1 1543 // CHECK_BDVER3_M32: #define __XOP__ 1 1544 // CHECK_BDVER3_M32: #define __bdver3 1 1545 // CHECK_BDVER3_M32: #define __bdver3__ 1 1546 // CHECK_BDVER3_M32: #define __i386 1 1547 // CHECK_BDVER3_M32: #define __i386__ 1 1548 // CHECK_BDVER3_M32: #define __tune_bdver3__ 1 1549 // RUN: %clang -march=bdver3 -m64 -E -dM %s -o - 2>&1 \ 1550 // RUN: -target i386-unknown-linux \ 1551 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER3_M64 1552 // CHECK_BDVER3_M64-NOT: #define __3dNOW_A__ 1 1553 // CHECK_BDVER3_M64-NOT: #define __3dNOW__ 1 1554 // CHECK_BDVER3_M64: #define __AES__ 1 1555 // CHECK_BDVER3_M64: #define __AVX__ 1 1556 // CHECK_BDVER3_M64: #define __BMI__ 1 1557 // CHECK_BDVER3_M64: #define __F16C__ 1 1558 // CHECK_BDVER3_M64: #define __FMA4__ 1 1559 // CHECK_BDVER3_M64: #define __FMA__ 1 1560 // CHECK_BDVER3_M64: #define __FSGSBASE__ 1 1561 // CHECK_BDVER3_M64: #define __LZCNT__ 1 1562 // CHECK_BDVER3_M64: #define __MMX__ 1 1563 // CHECK_BDVER3_M64: #define __PCLMUL__ 1 1564 // CHECK_BDVER3_M64: #define __POPCNT__ 1 1565 // CHECK_BDVER3_M64: #define __PRFCHW__ 1 1566 // CHECK_BDVER3_M64: #define __SSE2_MATH__ 1 1567 // CHECK_BDVER3_M64: #define __SSE2__ 1 1568 // CHECK_BDVER3_M64: #define __SSE3__ 1 1569 // CHECK_BDVER3_M64: #define __SSE4A__ 1 1570 // CHECK_BDVER3_M64: #define __SSE4_1__ 1 1571 // CHECK_BDVER3_M64: #define __SSE4_2__ 1 1572 // CHECK_BDVER3_M64: #define __SSE_MATH__ 1 1573 // CHECK_BDVER3_M64: #define __SSE__ 1 1574 // CHECK_BDVER3_M64: #define __SSSE3__ 1 1575 // CHECK_BDVER3_M64: #define __TBM__ 1 1576 // CHECK_BDVER3_M64: #define __XOP__ 1 1577 // CHECK_BDVER3_M64: #define __amd64 1 1578 // CHECK_BDVER3_M64: #define __amd64__ 1 1579 // CHECK_BDVER3_M64: #define __bdver3 1 1580 // CHECK_BDVER3_M64: #define __bdver3__ 1 1581 // CHECK_BDVER3_M64: #define __tune_bdver3__ 1 1582 // CHECK_BDVER3_M64: #define __x86_64 1 1583 // CHECK_BDVER3_M64: #define __x86_64__ 1 1584 // RUN: %clang -march=bdver4 -m32 -E -dM %s -o - 2>&1 \ 1585 // RUN: -target i386-unknown-linux \ 1586 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER4_M32 1587 // CHECK_BDVER4_M32-NOT: #define __3dNOW_A__ 1 1588 // CHECK_BDVER4_M32-NOT: #define __3dNOW__ 1 1589 // CHECK_BDVER4_M32: #define __AES__ 1 1590 // CHECK_BDVER4_M32: #define __AVX2__ 1 1591 // CHECK_BDVER4_M32: #define __AVX__ 1 1592 // CHECK_BDVER4_M32: #define __BMI2__ 1 1593 // CHECK_BDVER4_M32: #define __BMI__ 1 1594 // CHECK_BDVER4_M32: #define __F16C__ 1 1595 // CHECK_BDVER4_M32: #define __FMA4__ 1 1596 // CHECK_BDVER4_M32: #define __FMA__ 1 1597 // CHECK_BDVER4_M32: #define __FSGSBASE__ 1 1598 // CHECK_BDVER4_M32: #define __LZCNT__ 1 1599 // CHECK_BDVER4_M32: #define __MMX__ 1 1600 // CHECK_BDVER4_M32: #define __PCLMUL__ 1 1601 // CHECK_BDVER4_M32: #define __POPCNT__ 1 1602 // CHECK_BDVER4_M32: #define __PRFCHW__ 1 1603 // CHECK_BDVER4_M32: #define __SSE2_MATH__ 1 1604 // CHECK_BDVER4_M32: #define __SSE2__ 1 1605 // CHECK_BDVER4_M32: #define __SSE3__ 1 1606 // CHECK_BDVER4_M32: #define __SSE4A__ 1 1607 // CHECK_BDVER4_M32: #define __SSE4_1__ 1 1608 // CHECK_BDVER4_M32: #define __SSE4_2__ 1 1609 // CHECK_BDVER4_M32: #define __SSE_MATH__ 1 1610 // CHECK_BDVER4_M32: #define __SSE__ 1 1611 // CHECK_BDVER4_M32: #define __SSSE3__ 1 1612 // CHECK_BDVER4_M32: #define __TBM__ 1 1613 // CHECK_BDVER4_M32: #define __XOP__ 1 1614 // CHECK_BDVER4_M32: #define __bdver4 1 1615 // CHECK_BDVER4_M32: #define __bdver4__ 1 1616 // CHECK_BDVER4_M32: #define __i386 1 1617 // CHECK_BDVER4_M32: #define __i386__ 1 1618 // CHECK_BDVER4_M32: #define __tune_bdver4__ 1 1619 // RUN: %clang -march=bdver4 -m64 -E -dM %s -o - 2>&1 \ 1620 // RUN: -target i386-unknown-linux \ 1621 // RUN: | FileCheck %s -check-prefix=CHECK_BDVER4_M64 1622 // CHECK_BDVER4_M64-NOT: #define __3dNOW_A__ 1 1623 // CHECK_BDVER4_M64-NOT: #define __3dNOW__ 1 1624 // CHECK_BDVER4_M64: #define __AES__ 1 1625 // CHECK_BDVER4_M64: #define __AVX2__ 1 1626 // CHECK_BDVER4_M64: #define __AVX__ 1 1627 // CHECK_BDVER4_M64: #define __BMI2__ 1 1628 // CHECK_BDVER4_M64: #define __BMI__ 1 1629 // CHECK_BDVER4_M64: #define __F16C__ 1 1630 // CHECK_BDVER4_M64: #define __FMA4__ 1 1631 // CHECK_BDVER4_M64: #define __FMA__ 1 1632 // CHECK_BDVER4_M64: #define __FSGSBASE__ 1 1633 // CHECK_BDVER4_M64: #define __LZCNT__ 1 1634 // CHECK_BDVER4_M64: #define __MMX__ 1 1635 // CHECK_BDVER4_M64: #define __PCLMUL__ 1 1636 // CHECK_BDVER4_M64: #define __POPCNT__ 1 1637 // CHECK_BDVER4_M64: #define __PRFCHW__ 1 1638 // CHECK_BDVER4_M64: #define __SSE2_MATH__ 1 1639 // CHECK_BDVER4_M64: #define __SSE2__ 1 1640 // CHECK_BDVER4_M64: #define __SSE3__ 1 1641 // CHECK_BDVER4_M64: #define __SSE4A__ 1 1642 // CHECK_BDVER4_M64: #define __SSE4_1__ 1 1643 // CHECK_BDVER4_M64: #define __SSE4_2__ 1 1644 // CHECK_BDVER4_M64: #define __SSE_MATH__ 1 1645 // CHECK_BDVER4_M64: #define __SSE__ 1 1646 // CHECK_BDVER4_M64: #define __SSSE3__ 1 1647 // CHECK_BDVER4_M64: #define __TBM__ 1 1648 // CHECK_BDVER4_M64: #define __XOP__ 1 1649 // CHECK_BDVER4_M64: #define __amd64 1 1650 // CHECK_BDVER4_M64: #define __amd64__ 1 1651 // CHECK_BDVER4_M64: #define __bdver4 1 1652 // CHECK_BDVER4_M64: #define __bdver4__ 1 1653 // CHECK_BDVER4_M64: #define __tune_bdver4__ 1 1654 // CHECK_BDVER4_M64: #define __x86_64 1 1655 // CHECK_BDVER4_M64: #define __x86_64__ 1 1656 // 1657 // End X86/GCC/Linux tests ------------------ 1658 1659 // Begin PPC/GCC/Linux tests ---------------- 1660 // RUN: %clang -mvsx -E -dM %s -o - 2>&1 \ 1661 // RUN: -target powerpc64-unknown-linux \ 1662 // RUN: | FileCheck %s -check-prefix=CHECK_PPC_VSX_M64 1663 // 1664 // CHECK_PPC_VSX_M64: #define __VSX__ 1665 // 1666 // RUN: %clang -mpower8-vector -E -dM %s -o - 2>&1 \ 1667 // RUN: -target powerpc64-unknown-linux \ 1668 // RUN: | FileCheck %s -check-prefix=CHECK_PPC_POWER8_VECTOR_M64 1669 // 1670 // CHECK_PPC_POWER8_VECTOR_M64: #define __POWER8_VECTOR__ 1671 // 1672