r179229 - Mips specific inline asm memory operand modifier test case
Jack Carter
jack.carter at imgtec.com
Wed Apr 10 15:10:45 PDT 2013
Author: jacksprat
Date: Wed Apr 10 17:10:45 2013
New Revision: 179229
URL: http://llvm.org/viewvc/llvm-project?rev=179229&view=rev
Log:
Mips specific inline asm memory operand modifier test case
These changes are based on commit responses for r179135.
Added:
cfe/trunk/test/CodeGen/mips-inline-asm-modifiers.c
Added: cfe/trunk/test/CodeGen/mips-inline-asm-modifiers.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/mips-inline-asm-modifiers.c?rev=179229&view=auto
==============================================================================
--- cfe/trunk/test/CodeGen/mips-inline-asm-modifiers.c (added)
+++ cfe/trunk/test/CodeGen/mips-inline-asm-modifiers.c Wed Apr 10 17:10:45 2013
@@ -0,0 +1,35 @@
+// RUN: %clang -target mipsel-unknown-linux -S -o - -emit-llvm %s \
+// RUN: | FileCheck %s
+
+// This checks that the frontend will accept inline asm operand modifiers
+
+#include "stdio.h"
+
+ // CHECK: %{{[0-9]+}} = call i32 asm ".set noreorder;\0Alw $0,$1;\0A.set reorder;\0A", "=r,*m"(i32* getelementptr inbounds ([8 x i32]* @b, i32 {{[0-9]+}}, i32 {{[0-9]+}})) #2, !srcloc !0
+ // CHECK: %{{[0-9]+}} = call i32 asm "lw $0,${1:D};\0A", "=r,*m"(i32* getelementptr inbounds ([8 x i32]* @b, i32 {{[0-9]+}}, i32 {{[0-9]+}})) #2, !srcloc !1
+int b[8] = {0,1,2,3,4,5,6,7};
+int main()
+{
+ int i;
+
+ // The first word. Notice, no 'D'
+ {asm (
+ ".set noreorder;\n"
+ "lw %0,%1;\n"
+ ".set reorder;\n"
+ : "=r" (i)
+ : "m" (*(b+4)));}
+
+ printf("%d\n",i);
+
+ // The second word
+ {asm (
+ "lw %0,%D1;\n"
+ : "=r" (i)
+ : "m" (*(b+4))
+ );}
+
+ printf("%d\n",i);
+
+ return 1;
+}
More information about the cfe-commits
mailing list