[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / X86 / alias-static-alloca.ll
blob01d5e506f6da8e82fcd37e22ef7e1de3b3f300e9
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-linux-gnu | FileCheck %s
4 ; We should be able to bypass the load values to their corresponding
5 ; stores here.
7 define i32 @foo(i32 %a, i32 %b, i32 %c, i32 %d) {
8 ; CHECK-LABEL: foo:
9 ; CHECK:       # %bb.0: # %entry
10 ; CHECK-NEXT:    # kill: def $esi killed $esi def $rsi
11 ; CHECK-NEXT:    # kill: def $edi killed $edi def $rdi
12 ; CHECK-NEXT:    movl %esi, -8(%rsp)
13 ; CHECK-NEXT:    movl %ecx, -16(%rsp)
14 ; CHECK-NEXT:    movl %edi, -4(%rsp)
15 ; CHECK-NEXT:    movl %edx, -12(%rsp)
16 ; CHECK-NEXT:    leal (%rdi,%rsi), %eax
17 ; CHECK-NEXT:    addl %edx, %eax
18 ; CHECK-NEXT:    addl %ecx, %eax
19 ; CHECK-NEXT:    retq
20 entry:
21   %a0 = alloca i32
22   %a1 = alloca i32
23   %a2 = alloca i32
24   %a3 = alloca i32
25   store i32 %b, i32* %a1
26   store i32 %d, i32* %a3
27   store i32 %a, i32* %a0
28   store i32 %c, i32* %a2
29   %l0 = load i32, i32* %a0
30   %l1 = load i32, i32* %a1
31   %l2 = load i32, i32* %a2
32   %l3 = load i32, i32* %a3
33   %add0 = add nsw i32 %l0, %l1
34   %add1 = add nsw i32 %add0, %l2
35   %add2 = add nsw i32 %add1, %l3
36   ret i32 %add2