mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
8afb08e5b5
Summary: This patch is necessary so that they do not fail on MIPS32r6/MIPS64r6 when -integrated-as is enabled by default and we correctly detect the host CPU. No functional change since these tests are testing the behaviour of the constraint used for the third operand rather than the mnemonic. Depends on D3842 Reviewers: zoran.jovanovic, jkolek, vmedic Reviewed By: vmedic Differential Revision: http://reviews.llvm.org/D3843 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@209421 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
1.3 KiB
LLVM
45 lines
1.3 KiB
LLVM
; Positive test for inline register constraints
|
|
;
|
|
; RUN: llc -march=mipsel < %s | FileCheck %s
|
|
|
|
define i32 @main() nounwind {
|
|
entry:
|
|
|
|
; r with char
|
|
;CHECK: #APP
|
|
;CHECK: addiu ${{[0-9]+}},${{[0-9]+}},23
|
|
;CHECK: #NO_APP
|
|
tail call i8 asm sideeffect "addiu $0,$1,$2", "=r,r,n"(i8 27, i8 23) nounwind
|
|
|
|
; r with short
|
|
;CHECK: #APP
|
|
;CHECK: addiu ${{[0-9]+}},${{[0-9]+}},13
|
|
;CHECK: #NO_APP
|
|
tail call i16 asm sideeffect "addiu $0,$1,$2", "=r,r,n"(i16 17, i16 13) nounwind
|
|
|
|
; r with int
|
|
;CHECK: #APP
|
|
;CHECK: addiu ${{[0-9]+}},${{[0-9]+}},3
|
|
;CHECK: #NO_APP
|
|
tail call i32 asm sideeffect "addiu $0,$1,$2", "=r,r,n"(i32 7, i32 3) nounwind
|
|
|
|
; Now c with 1024: make sure register $25 is picked
|
|
; CHECK: #APP
|
|
; CHECK: addiu $25,${{[0-9]+}},1024
|
|
; CHECK: #NO_APP
|
|
tail call i32 asm sideeffect "addiu $0,$1,$2", "=c,c,I"(i32 4194304, i32 1024) nounwind
|
|
|
|
; Now l with 1024: make sure register lo is picked. We do this by checking the instruction
|
|
; after the inline expression for a mflo to pull the value out of lo.
|
|
; CHECK: #APP
|
|
; CHECK-NEXT: mtlo ${{[0-9]+}}
|
|
; CHECK-NEXT: madd ${{[0-9]+}},${{[0-9]+}}
|
|
; CHECK-NEXT: #NO_APP
|
|
; CHECK-NEXT: mflo ${{[0-9]+}}
|
|
%bosco = alloca i32, align 4
|
|
call i32 asm sideeffect "\09mtlo $3 \0A\09\09madd $1,$2 ", "=l,r,r,r"(i32 7, i32 6, i32 44) nounwind
|
|
store volatile i32 %4, i32* %bosco, align 4
|
|
|
|
ret i32 0
|
|
}
|