[docs] Add LICENSE.txt to the root of the mono-repo
[llvm-project.git] / llvm / test / CodeGen / X86 / alias-static-alloca.ll
blobf8d4ccce89f9666f9d0b0707276eef6d4ddf9f4a
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, -{{[0-9]+}}(%rsp)
13 ; CHECK-NEXT:    movl %ecx, -{{[0-9]+}}(%rsp)
14 ; CHECK-NEXT:    movl %edi, -{{[0-9]+}}(%rsp)
15 ; CHECK-NEXT:    movl %edx, -{{[0-9]+}}(%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, ptr %a1
26   store i32 %d, ptr %a3
27   store i32 %a, ptr %a0
28   store i32 %c, ptr %a2
29   %l0 = load i32, ptr %a0
30   %l1 = load i32, ptr %a1
31   %l2 = load i32, ptr %a2
32   %l3 = load i32, ptr %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