forked from OSchip/llvm-project
[PowerPC] Fix wrong codegen when stack pointer has to realign in prologue
Current powerpc backend generates wrong code sequence if stack pointer has to realign if -fstack-clash-protection enabled. When probing in prologue, backend should generate a subtraction instruction rather than a `stux` instruction to realign the stack pointer. This patch is part of fix of https://bugs.llvm.org/show_bug.cgi?id=46759. Differential Revision: https://reviews.llvm.org/D84218
This commit is contained in:
parent
e9f5ca0b79
commit
8912252252
|
@ -1466,11 +1466,10 @@ void PPCFrameLowering::inlineStackProbe(MachineFunction &MF,
|
||||||
.addImm(0)
|
.addImm(0)
|
||||||
.addImm(32 - Log2(MaxAlign))
|
.addImm(32 - Log2(MaxAlign))
|
||||||
.addImm(31);
|
.addImm(31);
|
||||||
BuildMI(PrologMBB, {MI}, DL, TII.get(isPPC64 ? PPC::STDUX : PPC::STWUX),
|
BuildMI(PrologMBB, {MI}, DL, TII.get(isPPC64 ? PPC::SUBFC8 : PPC::SUBFC),
|
||||||
SPReg)
|
SPReg)
|
||||||
.addReg(FPReg)
|
.addReg(ScratchReg)
|
||||||
.addReg(SPReg)
|
.addReg(SPReg);
|
||||||
.addReg(ScratchReg);
|
|
||||||
}
|
}
|
||||||
// Probe residual part.
|
// Probe residual part.
|
||||||
if (NegResidualSize) {
|
if (NegResidualSize) {
|
||||||
|
|
|
@ -12,7 +12,7 @@ define void @foo(i32 %vla_size) #0 {
|
||||||
; CHECK-LE-NEXT: mr r12, r1
|
; CHECK-LE-NEXT: mr r12, r1
|
||||||
; CHECK-LE-NEXT: .cfi_def_cfa r12, 0
|
; CHECK-LE-NEXT: .cfi_def_cfa r12, 0
|
||||||
; CHECK-LE-NEXT: clrldi r0, r12, 53
|
; CHECK-LE-NEXT: clrldi r0, r12, 53
|
||||||
; CHECK-LE-NEXT: stdux r12, r1, r0
|
; CHECK-LE-NEXT: subc r1, r1, r0
|
||||||
; CHECK-LE-NEXT: stdu r12, -2048(r1)
|
; CHECK-LE-NEXT: stdu r12, -2048(r1)
|
||||||
; CHECK-LE-NEXT: stdu r12, -4096(r1)
|
; CHECK-LE-NEXT: stdu r12, -4096(r1)
|
||||||
; CHECK-LE-NEXT: .cfi_def_cfa_register r1
|
; CHECK-LE-NEXT: .cfi_def_cfa_register r1
|
||||||
|
|
Loading…
Reference in New Issue