1 // RUN: %clang_cc1 -triple i386-unknown-unknown -emit-llvm %s -o - | FileCheck %s
3 __asm__
volatile("" : "=&r"(len
), "+&r"(len
));
6 void t2(unsigned long long t
) {
7 __asm__
volatile("" : "+m"(t
));
10 void t3(unsigned char *src
, unsigned long long temp
) {
11 __asm__
volatile("" : "+m"(temp
), "+r"(src
));
16 struct reg
{ unsigned long long a
, b
; } b
;
18 __asm__
volatile ("":: "m"(a
), "m"(b
));
23 asm("nop" : "=r"(i
) : "0"(t5
));
28 __asm__
volatile("" : : "i" (t6
));
32 __asm__
volatile("T7 NAMED: %[input]" : "+r"(a
): [input
] "i" (4));
34 // CHECK: T7 NAMED: $1
38 __asm__
volatile("T8 NAMED MODIFIER: %c[input]" :: [input
] "i" (4));
40 // CHECK: T8 NAMED MODIFIER: ${0:c}
44 unsigned t9(unsigned int a
) {
45 asm("bswap %0 %1" : "+r" (a
));
51 __asm__("PR3908 %[lf] %[xx] %[li] %[r]" : [r
] "+r" (r
) : [lf
] "mx" (0), [li
] "mr" (0), [xx
] "x" ((double)(0)));
54 // CHECK:PR3908 $1 $3 $2 $0
59 unsigned t11(signed char input
) {
68 unsigned char t12(unsigned input
) {
76 unsigned char t13(unsigned input
) {
88 unsigned long t15(int x
, struct large
*P
) {
98 // bitfield destination of an asm.
103 void t14(struct S
*P
) {
104 __asm__("abc %0" : "=r"(P
->a
) );
121 __asm__ ( "nop": "=m"(i
));
124 // CHECK: call void asm "nop", "=*m,
127 // <rdar://problem/6841383>
128 int t18(unsigned data
) {
131 asm("xyz" :"=a"(a
), "=d"(b
) : "a"(data
));
134 // CHECK: = call {{.*}}asm "xyz"
135 // CHECK-NEXT: extractvalue
136 // CHECK-NEXT: extractvalue
141 int t19(unsigned data
) {
144 asm("x{abc|def|ghi}z" :"=r"(a
): "r"(data
));
147 // CHECK: = call {{.*}}asm "x$(abc$|def$|ghi$)z"
151 // PR6845 - Mismatching source/dest fp types.
152 double t20(double x
) {
153 register long double result
;
154 __asm
__volatile ("frndint" : "=t" (result
) : "0" (x
));
158 // CHECK: fpext double {{.*}} to x86_fp80
159 // CHECK-NEXT: call x86_fp80 asm sideeffect "frndint"
160 // CHECK: fptrunc x86_fp80 {{.*}} to double
163 float t21(long double x
) {
164 register float result
;
165 __asm
__volatile ("frndint" : "=t" (result
) : "0" (x
));
168 // CHECK: call x86_fp80 asm sideeffect "frndint"
169 // CHECK-NEXT: fptrunc x86_fp80 {{.*}} to float
172 // <rdar://problem/8348447> - accept 'l' constraint
173 unsigned char t22(unsigned char a
, unsigned char b
) {
178 __asm__ ("0:\n1:\n" : [bigres
] "=la"(bigres
) : [la
] "0"(la
), [lb
] "c"(lb
) :
184 // <rdar://problem/8348447> - accept 'l' constraint
185 unsigned char t23(unsigned char a
, unsigned char b
) {
189 __asm__ ("0:\n1:\n" : [res
] "=la"(res
) : [la
] "0"(la
), [lb
] "c"(lb
) :