mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-06 03:38:34 +00:00
330e5f16d1
Summary: With this change we are able to realign the stack dynamically, whenever it contains objects with alignment requirements that are larger than the alignment specified from the given ABI. We have to use the $fp register as the frame pointer when we perform dynamic stack realignment. In complex stack frames, with variably-sized objects, we reserve additionally the callee-saved register $s7 as the base pointer in order to reference locals. Reviewers: dsanders Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D8633 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238829 91177308-0d34-0410-b5e6-96231b3b80d8
33 lines
1.3 KiB
LLVM
33 lines
1.3 KiB
LLVM
; Check that register scavenging spill slot is close to $fp.
|
|
; RUN: llc -march=mipsel -O0 < %s | FileCheck %s
|
|
|
|
; CHECK: sw ${{.*}}, 4($sp)
|
|
; CHECK: lw ${{.*}}, 4($sp)
|
|
|
|
define i32 @main(i32 signext %argc, i8** %argv) "no-frame-pointer-elim"="true" {
|
|
entry:
|
|
%retval = alloca i32, align 4
|
|
%argc.addr = alloca i32, align 4
|
|
%argv.addr = alloca i8**, align 4
|
|
%v0 = alloca <16 x i8>, align 16
|
|
%.compoundliteral = alloca <16 x i8>, align 16
|
|
%v1 = alloca <16 x i8>, align 16
|
|
%.compoundliteral1 = alloca <16 x i8>, align 16
|
|
%unused_variable = alloca [16384 x i32], align 4
|
|
%result = alloca <16 x i8>, align 16
|
|
store i32 0, i32* %retval
|
|
store i32 %argc, i32* %argc.addr, align 4
|
|
store i8** %argv, i8*** %argv.addr, align 4
|
|
store <16 x i8> <i8 1, i8 2, i8 3, i8 4, i8 5, i8 6, i8 7, i8 8, i8 9, i8 10, i8 11, i8 12, i8 13, i8 14, i8 15, i8 16>, <16 x i8>* %.compoundliteral
|
|
%0 = load <16 x i8>, <16 x i8>* %.compoundliteral
|
|
store <16 x i8> %0, <16 x i8>* %v0, align 16
|
|
store <16 x i8> zeroinitializer, <16 x i8>* %.compoundliteral1
|
|
%1 = load <16 x i8>, <16 x i8>* %.compoundliteral1
|
|
store <16 x i8> %1, <16 x i8>* %v1, align 16
|
|
%2 = load <16 x i8>, <16 x i8>* %v0, align 16
|
|
%3 = load <16 x i8>, <16 x i8>* %v1, align 16
|
|
%mul = mul <16 x i8> %2, %3
|
|
store <16 x i8> %mul, <16 x i8>* %result, align 16
|
|
ret i32 0
|
|
}
|