blob: 507702887866b136df9a2c052fa587730f1993f2 [file] [log] [blame]
Chris Lattnerb9922592010-03-03 21:52:23 +00001// RUN: %clang_cc1 -triple i386-unknown-unknown -emit-llvm %s -o - | FileCheck %s
Chris Lattner10ca96a2009-03-10 06:33:24 +00002void t1(int len) {
Anders Carlsson9f2505b2009-01-11 21:23:27 +00003 __asm__ volatile("" : "=&r"(len), "+&r"(len));
Anders Carlsson2763b3a2009-01-11 19:46:50 +00004}
Anders Carlsson9f2505b2009-01-11 21:23:27 +00005
Chris Lattner10ca96a2009-03-10 06:33:24 +00006void t2(unsigned long long t) {
Anders Carlsson9f2505b2009-01-11 21:23:27 +00007 __asm__ volatile("" : "+m"(t));
8}
9
Chris Lattner10ca96a2009-03-10 06:33:24 +000010void t3(unsigned char *src, unsigned long long temp) {
Anders Carlsson9f2505b2009-01-11 21:23:27 +000011 __asm__ volatile("" : "+m"(temp), "+r"(src));
12}
13
Chris Lattner10ca96a2009-03-10 06:33:24 +000014void t4() {
Anders Carlssonebaae2a2009-01-12 02:22:13 +000015 unsigned long long a;
16 struct reg { unsigned long long a, b; } b;
17
Mike Stump1eb44332009-09-09 15:08:12 +000018 __asm__ volatile ("":: "m"(a), "m"(b));
Anders Carlssonebaae2a2009-01-12 02:22:13 +000019}
Anders Carlsson9f2505b2009-01-11 21:23:27 +000020
Anders Carlsson03eb5432009-01-27 20:38:24 +000021// PR3417
Chris Lattner10ca96a2009-03-10 06:33:24 +000022void t5(int i) {
Anders Carlsson03eb5432009-01-27 20:38:24 +000023 asm("nop" : "=r"(i) : "0"(t5));
24}
Anders Carlsson60329792009-02-22 02:11:23 +000025
26// PR3641
Chris Lattner10ca96a2009-03-10 06:33:24 +000027void t6(void) {
Anders Carlsson60329792009-02-22 02:11:23 +000028 __asm__ volatile("" : : "i" (t6));
29}
Chris Lattner10ca96a2009-03-10 06:33:24 +000030
Chris Lattner10ca96a2009-03-10 06:33:24 +000031void t7(int a) {
32 __asm__ volatile("T7 NAMED: %[input]" : "+r"(a): [input] "i" (4));
Chris Lattner29a40712010-03-04 00:38:16 +000033 // CHECK: @t7(i32
34 // CHECK: T7 NAMED: $1
Chris Lattner02af9742009-03-10 06:38:02 +000035}
36
Chris Lattner02af9742009-03-10 06:38:02 +000037void t8() {
38 __asm__ volatile("T8 NAMED MODIFIER: %c[input]" :: [input] "i" (4));
Chris Lattner29a40712010-03-04 00:38:16 +000039 // CHECK: @t8()
40 // CHECK: T8 NAMED MODIFIER: ${0:c}
Chris Lattner02af9742009-03-10 06:38:02 +000041}
Chris Lattner88beebe2009-03-10 06:42:37 +000042
43// PR3682
44unsigned t9(unsigned int a) {
45 asm("bswap %0 %1" : "+r" (a));
46 return a;
47}
Anders Carlssonec91dab2009-04-03 05:57:08 +000048
49// PR3908
Anders Carlssonec91dab2009-04-03 05:57:08 +000050void t10(int r) {
51 __asm__("PR3908 %[lf] %[xx] %[li] %[r]" : [r] "+r" (r) : [lf] "mx" (0), [li] "mr" (0), [xx] "x" ((double)(0)));
Chris Lattner29a40712010-03-04 00:38:16 +000052
53// CHECK: @t10(
54// CHECK:PR3908 $1 $3 $2 $0
Anders Carlssonec91dab2009-04-03 05:57:08 +000055}
Chris Lattner4df4ee02009-05-03 07:27:51 +000056
57
58// PR3373
59unsigned t11(signed char input) {
60 unsigned output;
61 __asm__("xyz"
62 : "=a" (output)
63 : "0" (input));
64 return output;
65}
Chris Lattnerede9d902009-05-03 07:53:25 +000066
Chris Lattnera077b5c2009-05-03 08:21:20 +000067// PR3373
68unsigned char t12(unsigned input) {
69 unsigned char output;
70 __asm__("xyz"
71 : "=a" (output)
72 : "0" (input));
73 return output;
74}
Chris Lattnerede9d902009-05-03 07:53:25 +000075
Chris Lattner3351f112009-05-03 08:32:32 +000076unsigned char t13(unsigned input) {
77 unsigned char output;
78 __asm__("xyz %1"
79 : "=a" (output)
80 : "0" (input));
81 return output;
82}
Chris Lattnerede9d902009-05-03 07:53:25 +000083
Chris Lattner0bdaa5b2009-05-03 09:05:53 +000084struct large {
85 int x[1000];
86};
87
88unsigned long t15(int x, struct large *P) {
89 __asm__("xyz "
90 : "=r" (x)
91 : "m" (*P), "0" (x));
92 return x;
93}
94
95
96
Chris Lattner3351f112009-05-03 08:32:32 +000097
98// bitfield destination of an asm.
Chris Lattnerede9d902009-05-03 07:53:25 +000099struct S {
100 int a : 4;
101};
102
Chris Lattner3351f112009-05-03 08:32:32 +0000103void t14(struct S *P) {
Chris Lattnerede9d902009-05-03 07:53:25 +0000104 __asm__("abc %0" : "=r"(P->a) );
105}
Chris Lattner3351f112009-05-03 08:32:32 +0000106
107
Chris Lattner40539832009-10-13 04:32:07 +0000108// PR4938
109int t16() {
110 int a,b;
111 asm ( "nop;"
112 :"=%c" (a)
113 : "r" (b)
114 );
115 return 0;
116}
Chris Lattnerb9922592010-03-03 21:52:23 +0000117
118// PR6475
119void t17() {
120 int i;
121 __asm__ ( "nop": "=m"(i));
122
123// CHECK: @t17()
124// CHECK: call void asm "nop", "=*m,
125}
126
Chris Lattnereeeb49a2010-03-03 21:56:57 +0000127// <rdar://problem/6841383>
128int t18(unsigned data) {
129 int a, b;
130
131 asm("xyz" :"=a"(a), "=d"(b) : "a"(data));
132 return a + b;
133// CHECK: t18(i32
134// CHECK: = call {{.*}}asm "xyz"
135// CHECK-NEXT: extractvalue
136// CHECK-NEXT: extractvalue
137}
Chris Lattner018b54e2010-04-05 18:44:00 +0000138
139
140// PR6780
141int t19(unsigned data) {
142 int a, b;
143
144 asm("x{abc|def|ghi}z" :"=r"(a): "r"(data));
145 return a + b;
146 // CHECK: t19(i32
147 // CHECK: = call {{.*}}asm "x$(abc$|def$|ghi$)z"
148}
149
Chris Lattneraab64d02010-04-23 17:27:29 +0000150
151// PR6845 - Mismatching source/dest fp types.
152double t20(double x) {
153 register long double result;
154 __asm __volatile ("frndint" : "=t" (result) : "0" (x));
155 return result;
156
157 // CHECK: @t20
158 // CHECK: fpext double {{.*}} to x86_fp80
159 // CHECK-NEXT: call x86_fp80 asm sideeffect "frndint"
160 // CHECK: fptrunc x86_fp80 {{.*}} to double
161}
162
163float t21(long double x) {
164 register float result;
165 __asm __volatile ("frndint" : "=t" (result) : "0" (x));
166 return result;
167 // CHECK: @t21
168 // CHECK: call x86_fp80 asm sideeffect "frndint"
169 // CHECK-NEXT: fptrunc x86_fp80 {{.*}} to float
170}