aboutsummaryrefslogtreecommitdiff
path: root/test/CodeGen/asm.c
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-03-10 06:33:24 +0000
committerChris Lattner <sabre@nondot.org>2009-03-10 06:33:24 +0000
commit10ca96ae9aed6906c3302403ef1a146a8d4c6b74 (patch)
tree5b363ae980aee4bc3a1552ca642a50ef2d2f9184 /test/CodeGen/asm.c
parentbb57265fdba1e8af05dd917b8bf243d49cfb3465 (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.c25
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