blob: c1fba0eee942f20eeec4b0fc0cf58fc38921980d [file] [log] [blame]
Bill Wendling887b4852012-11-12 06:42:51 +00001// RUN: %clang_cc1 -triple i386-apple-darwin9 -verify %s
Akira Hatanakae867e422014-09-18 21:58:54 +00002// RUN: %clang_cc1 -triple i386-apple-darwin9 -target-feature +avx -verify %s
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00003
Bill Wendling887b4852012-11-12 06:42:51 +00004// <rdar://problem/12415959>
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +00005// rdar://problem/11846140
6// rdar://problem/17476970
Bill Wendling887b4852012-11-12 06:42:51 +00007
8typedef unsigned int u_int32_t;
9typedef u_int32_t uint32_t;
10
11typedef unsigned long long u_int64_t;
12typedef u_int64_t uint64_t;
13
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +000014typedef float __m128 __attribute__ ((vector_size (16)));
15typedef float __m256 __attribute__ ((vector_size (32)));
Hans Wennborg3c619a42014-09-18 20:24:04 +000016typedef float __m512 __attribute__ ((vector_size (64)));
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +000017
18__m128 val128;
19__m256 val256;
Hans Wennborg3c619a42014-09-18 20:24:04 +000020__m512 val512;
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +000021
Bill Wendlingb3b4a372013-03-22 21:33:46 +000022int func1() {
Bill Wendling03913662012-11-12 21:13:35 +000023 // Error out if size is > 32-bits.
Bill Wendling887b4852012-11-12 06:42:51 +000024 uint32_t msr = 0x8b;
25 uint64_t val = 0;
26 __asm__ volatile("wrmsr"
27 :
28 : "c" (msr),
29 "a" ((val & 0xFFFFFFFFUL)), // expected-error {{invalid input size for constraint 'a'}}
30 "d" (((val >> 32) & 0xFFFFFFFFUL)));
Bill Wendling03913662012-11-12 21:13:35 +000031
32 // Don't error out if the size of the destination is <= 32 bits.
33 unsigned char data;
34 unsigned int port;
35 __asm__ volatile("outb %0, %w1" : : "a" (data), "Nd" (port)); // No error expected.
Akira Hatanaka31c6d3b2014-09-17 23:35:14 +000036
37 __asm__ volatile("outb %0, %w1" : : "R" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'R'}}
38 __asm__ volatile("outb %0, %w1" : : "q" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'q'}}
39 __asm__ volatile("outb %0, %w1" : : "Q" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'Q'}}
40 __asm__ volatile("outb %0, %w1" : : "b" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'b'}}
41 __asm__ volatile("outb %0, %w1" : : "c" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'c'}}
42 __asm__ volatile("outb %0, %w1" : : "d" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'd'}}
43 __asm__ volatile("outb %0, %w1" : : "S" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'S'}}
44 __asm__ volatile("outb %0, %w1" : : "D" (val), "Nd" (port)); // expected-error {{invalid input size for constraint 'D'}}
45 __asm__ volatile("foo1 %0" : : "A" (val128)); // expected-error {{invalid input size for constraint 'A'}}
46 __asm__ volatile("foo1 %0" : : "f" (val256)); // expected-error {{invalid input size for constraint 'f'}}
47 __asm__ volatile("foo1 %0" : : "t" (val256)); // expected-error {{invalid input size for constraint 't'}}
48 __asm__ volatile("foo1 %0" : : "u" (val256)); // expected-error {{invalid input size for constraint 'u'}}
Hans Wennborg3c619a42014-09-18 20:24:04 +000049 __asm__ volatile("foo1 %0" : : "x" (val512)); // expected-error {{invalid input size for constraint 'x'}}
Akira Hatanaka974131e2014-09-18 18:17:18 +000050
51 __asm__ volatile("foo1 %0" : "=R" (val)); // expected-error {{invalid output size for constraint '=R'}}
52 __asm__ volatile("foo1 %0" : "=q" (val)); // expected-error {{invalid output size for constraint '=q'}}
53 __asm__ volatile("foo1 %0" : "=Q" (val)); // expected-error {{invalid output size for constraint '=Q'}}
54 __asm__ volatile("foo1 %0" : "=a" (val)); // expected-error {{invalid output size for constraint '=a'}}
55 __asm__ volatile("foo1 %0" : "=b" (val)); // expected-error {{invalid output size for constraint '=b'}}
56 __asm__ volatile("foo1 %0" : "=c" (val)); // expected-error {{invalid output size for constraint '=c'}}
57 __asm__ volatile("foo1 %0" : "=d" (val)); // expected-error {{invalid output size for constraint '=d'}}
58 __asm__ volatile("foo1 %0" : "=S" (val)); // expected-error {{invalid output size for constraint '=S'}}
59 __asm__ volatile("foo1 %0" : "=D" (val)); // expected-error {{invalid output size for constraint '=D'}}
60 __asm__ volatile("foo1 %0" : "=A" (val128)); // expected-error {{invalid output size for constraint '=A'}}
61 __asm__ volatile("foo1 %0" : "=t" (val256)); // expected-error {{invalid output size for constraint '=t'}}
62 __asm__ volatile("foo1 %0" : "=u" (val256)); // expected-error {{invalid output size for constraint '=u'}}
Hans Wennborg3c619a42014-09-18 20:24:04 +000063 __asm__ volatile("foo1 %0" : "=x" (val512)); // expected-error {{invalid output size for constraint '=x'}}
Akira Hatanakae867e422014-09-18 21:58:54 +000064
65#ifdef __AVX__
66 __asm__ volatile("foo1 %0" : : "x" (val256)); // No error.
67 __asm__ volatile("foo1 %0" : "=x" (val256)); // No error.
68#else
69 __asm__ volatile("foo1 %0" : : "x" (val256)); // expected-error {{invalid input size for constraint 'x'}}
70 __asm__ volatile("foo1 %0" : "=x" (val256)); // expected-error {{invalid output size for constraint '=x'}}
71#endif
Bill Wendling887b4852012-11-12 06:42:51 +000072}