136 lines
4.4 KiB
LLVM
136 lines
4.4 KiB
LLVM
|
; RUN: llc < %s | FileCheck %s
|
||
|
|
||
|
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
||
|
target triple = "x86_64-unknown-linux-gnu"
|
||
|
|
||
|
; | case1 | alloca + align < probe_size
|
||
|
define i32 @foo1(i64 %i) local_unnamed_addr #0 {
|
||
|
; CHECK-LABEL: foo1:
|
||
|
; CHECK: # %bb.0:
|
||
|
; CHECK-NEXT: pushq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||
|
; CHECK-NEXT: .cfi_offset %rbp, -16
|
||
|
; CHECK-NEXT: movq %rsp, %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_register %rbp
|
||
|
; CHECK-NEXT: andq $-64, %rsp
|
||
|
; CHECK-NEXT: subq $832, %rsp # imm = 0x340
|
||
|
; CHECK-NEXT: movl $1, (%rsp,%rdi,4)
|
||
|
; CHECK-NEXT: movl (%rsp), %eax
|
||
|
; CHECK-NEXT: movq %rbp, %rsp
|
||
|
; CHECK-NEXT: popq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa %rsp, 8
|
||
|
; CHECK-NEXT: retq
|
||
|
|
||
|
%a = alloca i32, i32 200, align 64
|
||
|
%b = getelementptr inbounds i32, i32* %a, i64 %i
|
||
|
store volatile i32 1, i32* %b
|
||
|
%c = load volatile i32, i32* %a
|
||
|
ret i32 %c
|
||
|
}
|
||
|
|
||
|
; | case2 | alloca > probe_size, align > probe_size
|
||
|
define i32 @foo2(i64 %i) local_unnamed_addr #0 {
|
||
|
; CHECK-LABEL: foo2:
|
||
|
; CHECK: # %bb.0:
|
||
|
; CHECK-NEXT: pushq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||
|
; CHECK-NEXT: .cfi_offset %rbp, -16
|
||
|
; CHECK-NEXT: movq %rsp, %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_register %rbp
|
||
|
; CHECK-NEXT: andq $-2048, %rsp # imm = 0xF800
|
||
|
; CHECK-NEXT: subq $2048, %rsp # imm = 0x800
|
||
|
; CHECK-NEXT: movq $0, (%rsp)
|
||
|
; CHECK-NEXT: subq $4096, %rsp # imm = 0x1000
|
||
|
; CHECK-NEXT: movq $0, (%rsp)
|
||
|
; CHECK-NEXT: subq $2048, %rsp # imm = 0x800
|
||
|
; CHECK-NEXT: movl $1, (%rsp,%rdi,4)
|
||
|
; CHECK-NEXT: movl (%rsp), %eax
|
||
|
; CHECK-NEXT: movq %rbp, %rsp
|
||
|
; CHECK-NEXT: popq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa %rsp, 8
|
||
|
; CHECK-NEXT: retq
|
||
|
|
||
|
%a = alloca i32, i32 2000, align 2048
|
||
|
%b = getelementptr inbounds i32, i32* %a, i64 %i
|
||
|
store volatile i32 1, i32* %b
|
||
|
%c = load volatile i32, i32* %a
|
||
|
ret i32 %c
|
||
|
}
|
||
|
|
||
|
; | case3 | alloca < probe_size, align < probe_size, alloca + align > probe_size
|
||
|
define i32 @foo3(i64 %i) local_unnamed_addr #0 {
|
||
|
; CHECK-LABEL: foo3:
|
||
|
; CHECK: # %bb.0:
|
||
|
; CHECK-NEXT: pushq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||
|
; CHECK-NEXT: .cfi_offset %rbp, -16
|
||
|
; CHECK-NEXT: movq %rsp, %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_register %rbp
|
||
|
; CHECK-NEXT: andq $-1024, %rsp # imm = 0xFC00
|
||
|
; CHECK-NEXT: subq $3072, %rsp # imm = 0xC00
|
||
|
; CHECK-NEXT: movq $0, (%rsp)
|
||
|
; CHECK-NEXT: subq $1024, %rsp # imm = 0x400
|
||
|
; CHECK-NEXT: movl $1, (%rsp,%rdi,4)
|
||
|
; CHECK-NEXT: movl (%rsp), %eax
|
||
|
; CHECK-NEXT: movq %rbp, %rsp
|
||
|
; CHECK-NEXT: popq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa %rsp, 8
|
||
|
; CHECK-NEXT: retq
|
||
|
|
||
|
|
||
|
%a = alloca i32, i32 1000, align 1024
|
||
|
%b = getelementptr inbounds i32, i32* %a, i64 %i
|
||
|
store volatile i32 1, i32* %b
|
||
|
%c = load volatile i32, i32* %a
|
||
|
ret i32 %c
|
||
|
}
|
||
|
|
||
|
; | case4 | alloca + probe_size < probe_size, followed by dynamic alloca
|
||
|
define i32 @foo4(i64 %i) local_unnamed_addr #0 {
|
||
|
; CHECK-LABEL: foo4:
|
||
|
; CHECK: # %bb.0:
|
||
|
; CHECK-NEXT: pushq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||
|
; CHECK-NEXT: .cfi_offset %rbp, -16
|
||
|
; CHECK-NEXT: movq %rsp, %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa_register %rbp
|
||
|
; CHECK-NEXT: pushq %rbx
|
||
|
; CHECK-NEXT: andq $-64, %rsp
|
||
|
; CHECK-NEXT: subq $896, %rsp # imm = 0x380
|
||
|
; CHECK-NEXT: movq %rsp, %rbx
|
||
|
; CHECK-NEXT: .cfi_offset %rbx, -24
|
||
|
; CHECK-NEXT: movl $1, (%rbx,%rdi,4)
|
||
|
; CHECK-NEXT: movl (%rbx), %ecx
|
||
|
; CHECK-NEXT: movq %rsp, %rax
|
||
|
; CHECK-NEXT: leaq 15(,%rcx,4), %rcx
|
||
|
; CHECK-NEXT: andq $-16, %rcx
|
||
|
; CHECK-NEXT: subq %rcx, %rax
|
||
|
; CHECK-NEXT: cmpq %rsp, %rax
|
||
|
; CHECK-NEXT: jge .LBB3_3
|
||
|
; CHECK-NEXT:.LBB3_2: # =>This Inner Loop Header: Depth=1
|
||
|
; CHECK-NEXT: xorq $0, (%rsp)
|
||
|
; CHECK-NEXT: subq $4096, %rsp # imm = 0x1000
|
||
|
; CHECK-NEXT: cmpq %rsp, %rax
|
||
|
; CHECK-NEXT: jl .LBB3_2
|
||
|
; CHECK-NEXT:.LBB3_3:
|
||
|
; CHECK-NEXT: andq $-64, %rax
|
||
|
; CHECK-NEXT: movq %rax, %rsp
|
||
|
; CHECK-NEXT: movl (%rax), %eax
|
||
|
; CHECK-NEXT: leaq -8(%rbp), %rsp
|
||
|
; CHECK-NEXT: popq %rbx
|
||
|
; CHECK-NEXT: popq %rbp
|
||
|
; CHECK-NEXT: .cfi_def_cfa %rsp, 8
|
||
|
; CHECK-NEXT: retq
|
||
|
|
||
|
%a = alloca i32, i32 200, align 64
|
||
|
%b = getelementptr inbounds i32, i32* %a, i64 %i
|
||
|
store volatile i32 1, i32* %b
|
||
|
%c = load volatile i32, i32* %a
|
||
|
%d = alloca i32, i32 %c, align 64
|
||
|
%e = load volatile i32, i32* %d
|
||
|
ret i32 %e
|
||
|
}
|
||
|
|
||
|
attributes #0 = {"probe-stack"="inline-asm"}
|
||
|
|