[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:
Kai Luo 2020-07-22 04:13:18 +00:00
parent e9f5ca0b79
commit 8912252252
2 changed files with 4 additions and 5 deletions

View File

@ -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) {

View File

@ -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