llvm-project/llvm/test/CodeGen/X86/sjlj-baseptr.ll
Luo, Yuanke ba8a520512 [X86] Fix the base pointer save/restore bug
Previous the stack slot for spilling base pointer register is allocated
after the stack realignment. When the stack is naturally aligned the
stack slot is share with other data that allocated from stack and cause
data corrupt. Another issue is the stack slot for save/restore the
callee saved register is not fixed for each function. It depends on the
register usage of them in each function.

This patch is to recalculate the offset the stack slot for base pointer
register during the prolog/epilog insert pass, and allocate the stack
slot when spilling callee saved registers.

Differential Revision: https://reviews.llvm.org/D144625
2023-02-25 20:52:13 +08:00

45 lines
1.3 KiB
LLVM

; RUN: llc < %s -mtriple=i386-pc-linux -mcpu=corei7 -relocation-model=static | FileCheck --check-prefix=X86 %s
; RUN: llc < %s -mtriple=x86_64-pc-linux -mcpu=corei7 -relocation-model=static | FileCheck --check-prefix=X64 %s
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
%Foo = type { [125 x i8] }
declare i32 @llvm.eh.sjlj.setjmp(ptr) nounwind
declare void @whatever(i64, ptr, ptr, ptr, ptr, i32) #0
attributes #0 = { nounwind uwtable "frame-pointer"="all" }
define i32 @test1(i64 %n, ptr byval(%Foo) nocapture readnone align 8 %f) #0 {
entry:
%buf = alloca [5 x ptr], align 16
%p = alloca ptr, align 8
%q = alloca i8, align 64
%s = alloca i8, i64 %n, align 1
store ptr %s, ptr %p, align 8
%t = call i32 @llvm.eh.sjlj.setjmp(ptr %s)
call void @whatever(i64 %n, ptr %f, ptr %p, ptr %q, ptr %s, i32 %t) #1
ret i32 0
; X86: pushl %esi
; X86-NEXT: pushl %esi
; X86: movl %esp, %esi
; X86: movl %esp, -16(%ebp)
; X86: {{.LBB.*:}}
; X86: movl -16(%ebp), %esi
; X86: {{.LBB.*:}}
; X86: popl %esi
; X86-NEXT: popl %esi
; X64: pushq %rbx
; X64-NEXT: pushq %rbx
; X64: movq %rsp, %rbx
; X64: movq %rsp, -48(%rbp)
; X64: {{.LBB.*:}}
; X64: movq -48(%rbp), %rbx
; X64: {{.LBB.*:}}
; X64: popq %rbx
; X64-NEXT: popq %rbx
}