diff options
author | Chris Lattner <sabre@nondot.org> | 2009-03-10 06:33:24 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-03-10 06:33:24 +0000 |
commit | 10ca96ae9aed6906c3302403ef1a146a8d4c6b74 (patch) | |
tree | 5b363ae980aee4bc3a1552ca642a50ef2d2f9184 /test/CodeGen/asm.c | |
parent | bb57265fdba1e8af05dd917b8bf243d49cfb3465 (diff) |
move matching of named operands into AsmStmt class. At the same
time handle + operands in operand counting, fixing asm.c:t7 to
expand into $2 instead of $1.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66531 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/asm.c')
-rw-r--r-- | test/CodeGen/asm.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/test/CodeGen/asm.c b/test/CodeGen/asm.c index e8088d40b1..4e6ff4da90 100644 --- a/test/CodeGen/asm.c +++ b/test/CodeGen/asm.c @@ -1,21 +1,17 @@ -// RUN: clang -emit-llvm %s -o %t -arch=i386 -void t1(int len) -{ +// 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) -{ +void t2(unsigned long long t) { __asm__ volatile("" : "+m"(t)); } -void t3(unsigned char *src, unsigned long long temp) -{ +void t3(unsigned char *src, unsigned long long temp) { __asm__ volatile("" : "+m"(temp), "+r"(src)); } -void t4() -{ +void t4() { unsigned long long a; struct reg { unsigned long long a, b; } b; @@ -23,13 +19,16 @@ void t4() } // PR3417 -void t5(int i) -{ +void t5(int i) { asm("nop" : "=r"(i) : "0"(t5)); } // PR3641 -void t6(void) -{ +void t6(void) { __asm__ volatile("" : : "i" (t6)); } + +// RUN: grep "T7 NAMED: \$2" %t +void t7(int a) { + __asm__ volatile("T7 NAMED: %[input]" : "+r"(a): [input] "i" (4)); +}
\ No newline at end of file |