// RUN: clang -emit-llvm %s -o %t -arch=i386 | |
void t1(int len) | |
{ | |
__asm__ volatile("" : "=&r"(len), "+&r"(len)); | |
} | |
void t2(unsigned long long t) | |
{ | |
__asm__ volatile("" : "+m"(t)); | |
} | |
void t3(unsigned char *src, unsigned long long temp) | |
{ | |
__asm__ volatile("" : "+m"(temp), "+r"(src)); | |
} | |
void t4() | |
{ | |
unsigned long long a; | |
struct reg { unsigned long long a, b; } b; | |
__asm__ volatile ("":: "m"(a), "m"(b)); | |
} | |
// PR3417 | |
void t5(int i) | |
{ | |
asm("nop" : "=r"(i) : "0"(t5)); | |
} |