mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
487e504edd
The dsp register class is an alias of the gpr register class, so we have to define instructions for spilling and reloading. Reviewers: atanasyan Differential Revision: https://reviews.llvm.org/D38038 llvm-svn: 314798
53 lines
1.4 KiB
LLVM
53 lines
1.4 KiB
LLVM
; RUN: llc -march=mips -mattr=+dsp < %s -asm-show-inst -O0 | FileCheck %s \
|
|
; RUN: --check-prefixes=ASM,ALL
|
|
; RUN: llc -march=mips -mattr=+dsp,+micromips < %s -O0 -filetype=obj | \
|
|
; RUN: llvm-objdump -d - | FileCheck %s --check-prefixes=MM-OBJ,ALL
|
|
|
|
; Test that spill and reloads use the dsp "variant" instructions. We use -O0
|
|
; to use the simple register allocator.
|
|
|
|
; To test the micromips output, we have to take a round trip through the
|
|
; object file encoder/decoder as the instruction mapping tables are used to
|
|
; support micromips.
|
|
|
|
; FIXME: We should be able to get rid of those instructions with the variable
|
|
; value registers.
|
|
|
|
; ALL-LABEL: spill_reload:
|
|
|
|
define <4 x i8> @spill_reload(<4 x i8> %a, <4 x i8> %b, i32 %g) {
|
|
entry:
|
|
%c = tail call <4 x i8> @llvm.mips.addu.qb(<4 x i8> %a, <4 x i8> %b)
|
|
%cond = icmp eq i32 %g, 0
|
|
br i1 %cond, label %true, label %end
|
|
|
|
; ASM: SWDSP
|
|
; ASM: SWDSP
|
|
; ASM: SWDSP
|
|
|
|
; MM-OBJ: sw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
; MM-OBJ: sw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
; MM-OBJ: sw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
; MM-OBJ: sw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
|
|
true:
|
|
ret <4 x i8> %c
|
|
|
|
; ASM: LWDSP
|
|
|
|
; MM-OBJ: lw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
|
|
end:
|
|
%d = tail call <4 x i8> @llvm.mips.addu.qb(<4 x i8> %c, <4 x i8> %a)
|
|
ret <4 x i8> %d
|
|
|
|
; ASM: LWDSP
|
|
; ASM: LWDSP
|
|
|
|
; MM-OBJ: lw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
; MM-OBJ: lw ${{[0-9]+}}, {{[0-9]+}}($sp)
|
|
|
|
}
|
|
|
|
declare <4 x i8> @llvm.mips.addu.qb(<4 x i8>, <4 x i8>) nounwind
|