From 12d3a9138694541f8b2443501def6b72fedfa86b Mon Sep 17 00:00:00 2001 From: Evan Cheng Date: Thu, 8 Mar 2007 22:45:31 +0000 Subject: [PATCH] Test inline asm modifier 'c'. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35036 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/CodeGen/ARM/inlineasm.ll | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/test/CodeGen/ARM/inlineasm.ll b/test/CodeGen/ARM/inlineasm.ll index a75c7469c01..fd9498704bb 100644 --- a/test/CodeGen/ARM/inlineasm.ll +++ b/test/CodeGen/ARM/inlineasm.ll @@ -1,15 +1,19 @@ -; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 +; RUN: llvm-as < %s | llc -march=arm -mattr=+v6 -uint %test1(uint %tmp54) { - %tmp56 = tail call uint asm "uxtb16 $0,$1", "=r,r"( uint %tmp54 ) - ret uint %tmp56 +define i32 @test1(i32 %tmp54) { + %tmp56 = tail call i32 asm "uxtb16 $0,$1", "=r,r"( i32 %tmp54 ) ; [#uses=1] + ret i32 %tmp56 } -void %test2() { - %tmp1 = call long asm "ldmia $1!, {$0, ${0:H}}", "=r,==r,1"( int** null, int* null ) - %tmp1 = cast long %tmp1 to ulong - %tmp2 = shr ulong %tmp1, ubyte 32 - %tmp3 = cast ulong %tmp2 to int - %tmp4 = call int asm "pkhbt $0, $1, $2, lsl #16", "=r,r,r"( int 0, int %tmp3 ) - ret void +define void @test2() { + %tmp1 = call i64 asm "ldmia $1!, {$0, ${0:H}}", "=r,==r,1"( i32** null, i32* null ) ; [#uses=2] + %tmp2 = lshr i64 %tmp1, 32 ; [#uses=1] + %tmp3 = trunc i64 %tmp2 to i32 ; [#uses=1] + %tmp4 = call i32 asm "pkhbt $0, $1, $2, lsl #16", "=r,r,r"( i32 0, i32 %tmp3 ) ; [#uses=0] + ret void +} + +define void @test3() { + tail call void asm sideeffect "/* number: ${0:c} */", "i"( i32 1 ) + ret void } -- 2.34.1