mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
26057f3875
Fix for https://bugs.llvm.org/show_bug.cgi?id=41477. On the x32 ABI with stack probing a dynamic alloca will result in a WIN_ALLOCA_32 with a 32-bit size. The current implementation tries to copy it into RAX, resulting in a physreg copy error. Fix this by copying to EAX instead. Also fix incorrect opcodes or registers used in subs. llvm-svn: 358807
55 lines
1.6 KiB
LLVM
55 lines
1.6 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnux32 -verify-machineinstrs | FileCheck %s
|
|
|
|
target datalayout = "e-m:e-p:32:32-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-unknown-linux-gnux32"
|
|
|
|
; probe-stack + dynamic size alloca
|
|
define void @test1(i32 %size) nounwind #0 {
|
|
; CHECK-LABEL: test1:
|
|
; CHECK: # %bb.0: # %start
|
|
; CHECK-NEXT: pushq %rbp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: # kill: def $edi killed $edi def $rdi
|
|
; CHECK-NEXT: leal 15(%rdi), %eax
|
|
; CHECK-NEXT: andl $-16, %eax
|
|
; CHECK-NEXT: callq __rust_probestack
|
|
; CHECK-NEXT: subl %eax, %esp
|
|
start:
|
|
%alloca = alloca i8, i32 %size
|
|
unreachable
|
|
}
|
|
|
|
; probe-stack + no-stack-arg-probe + dynamic size alloca
|
|
define void @test2(i32 %size) nounwind #1 {
|
|
; CHECK-LABEL: test2:
|
|
; CHECK: # %bb.0: # %start
|
|
; CHECK-NEXT: pushq %rbp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: addl $15, %edi
|
|
; CHECK-NEXT: andl $-16, %edi
|
|
; CHECK-NEXT: subl %edi, %esp
|
|
start:
|
|
%alloca = alloca i8, i32 %size
|
|
unreachable
|
|
}
|
|
|
|
; probe-stack + fixed size alloca not in entry block
|
|
define void @test3() nounwind #0 {
|
|
; CHECK-LABEL: test3:
|
|
; CHECK: # %bb.0: # %start
|
|
; CHECK-NEXT: pushq %rbp
|
|
; CHECK-NEXT: movl %esp, %ebp
|
|
; CHECK-NEXT: pushq %rax
|
|
; CHECK-NEXT: subl $1992, %esp # imm = 0x7C8
|
|
start:
|
|
br label %block
|
|
|
|
block:
|
|
%alloca = alloca i8, i32 2000
|
|
unreachable
|
|
}
|
|
|
|
attributes #0 = { "probe-stack"="__rust_probestack" }
|
|
attributes #1 = { "probe-stack"="__rust_probestack" "no-stack-arg-probe" }
|