llvm-project/llvm/test/CodeGen/PowerPC/inlineasm-copy.ll

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

22 lines
961 B
LLVM
Raw Normal View History

; RUN: llc < %s -mtriple=ppc32-- -no-integrated-as -verify-machineinstrs | FileCheck %s
2006-11-02 09:45:28 +08:00
; CHECK-NOT: mr
define i32 @test(i32 %Y, i32 %X) {
2006-11-02 09:45:28 +08:00
entry:
%tmp = tail call i32 asm "foo $0", "=r"( ) ; <i32> [#uses=1]
ret i32 %tmp
2006-11-02 09:45:28 +08:00
}
define i32 @test2(i32 %Y, i32 %X) {
2006-11-02 09:45:28 +08:00
entry:
%tmp1 = tail call i32 asm "foo $0, $1", "=r,r"( i32 %X ) ; <i32> [#uses=1]
ret i32 %tmp1
2006-11-02 09:45:28 +08:00
}
; CHECK: test3
define i32 @test3(i32 %Y, i32 %X) {
entry:
%tmp1 = tail call { i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32, i32 } asm sideeffect "foo $0, $1", "=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,=r,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19"( i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y, i32 %X, i32 %Y ) ; <i32> [#uses=1]
ret i32 1
}