Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / stack-clash-medium-natural-probes.ll
blob9c60238a0bea80eb5d23cc993d950f5f745ead58
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --no_x86_scrub_sp
2 ; RUN: llc < %s | FileCheck %s
4 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5 target triple = "x86_64-unknown-linux-gnu"
7 define i32 @foo() local_unnamed_addr #0 {
8 ; CHECK-LABEL: foo:
9 ; CHECK:       # %bb.0:
10 ; CHECK-NEXT:    subq $4096, %rsp # imm = 0x1000
11 ; CHECK-NEXT:    .cfi_adjust_cfa_offset 4096
12 ; CHECK-NEXT:    movq $0, (%rsp)
13 ; CHECK-NEXT:    subq $3784, %rsp # imm = 0xEC8
14 ; CHECK-NEXT:    .cfi_def_cfa_offset 7888
15 ; CHECK-NEXT:    movl $1, 264(%rsp)
16 ; CHECK-NEXT:    movl $1, 4664(%rsp)
17 ; CHECK-NEXT:    movl -128(%rsp), %eax
18 ; CHECK-NEXT:    addq $7880, %rsp # imm = 0x1EC8
19 ; CHECK-NEXT:    .cfi_def_cfa_offset 8
20 ; CHECK-NEXT:    retq
21   %a = alloca i32, i64 2000, align 16
22   %b0 = getelementptr inbounds i32, ptr %a, i64 98
23   %b1 = getelementptr inbounds i32, ptr %a, i64 1198
24   store i32 1, ptr %b0
25   store i32 1, ptr %b1
26   %c = load volatile i32, ptr %a
27   ret i32 %c
30 attributes #0 =  {"probe-stack"="inline-asm"}