mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-05 19:29:01 +00:00
892af54a91
This improves the logic in several ways and is a preparation for followup patches: - First perform an analysis and create a list of merge candidates, then transform. This simplifies the code in that you have don't have to care to much anymore that you may be holding iterators to MachineInstrs that get removed. - Analyze/Transform basic blocks in reverse order. This allows to use LivePhysRegs to find free registers instead of the RegisterScavenger. The RegisterScavenger will become less precise in the future as it relies on the deprecated kill-flags. - Return the newly created node in MergeOps so there's no need to look around in the schedule to find it. - Rename some MBBI iterators to InsertBefore to make their role clear. - General code cleanup. Differential Revision: http://reviews.llvm.org/D10140 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241920 91177308-0d34-0410-b5e6-96231b3b80d8
26 lines
667 B
LLVM
26 lines
667 B
LLVM
;PR15293: ARM codegen ice - expected larger existing stack allocation
|
|
;RUN: llc -mtriple=arm-linux-gnueabihf < %s | FileCheck %s
|
|
|
|
%struct4bytes = type { i32 }
|
|
%struct20bytes = type { i32, i32, i32, i32, i32 }
|
|
|
|
define void @foo(%struct4bytes* byval %p0, ; --> R0
|
|
%struct20bytes* byval %p1 ; --> R1,R2,R3, [SP+0 .. SP+8)
|
|
) {
|
|
;CHECK: sub sp, sp, #16
|
|
;CHECK: push {r11, lr}
|
|
;CHECK: add r12, sp, #8
|
|
;CHECK: stm r12, {r0, r1, r2, r3}
|
|
;CHECK: add r0, sp, #12
|
|
;CHECK: bl useInt
|
|
;CHECK: pop {r11, lr}
|
|
;CHECK: add sp, sp, #16
|
|
|
|
%1 = ptrtoint %struct20bytes* %p1 to i32
|
|
tail call void @useInt(i32 %1)
|
|
ret void
|
|
}
|
|
|
|
declare void @useInt(i32)
|
|
|