X86: Don't fold spills into SSE operations if the stack is unaligned.
[oota-llvm.git] / test / CodeGen / X86 / aliases.ll
1 ; RUN: llc < %s -mtriple=i686-pc-linux-gnu -asm-verbose=false | FileCheck %s
2
3 @bar = external global i32
4
5 ; CHECK-DAG: .globl     foo1
6 @foo1 = alias i32* @bar
7
8 ; CHECK-DAG: .globl     foo2
9 @foo2 = alias i32* @bar
10
11 %FunTy = type i32()
12
13 declare i32 @foo_f()
14 ; CHECK-DAG: .weak      bar_f
15 @bar_f = alias weak %FunTy* @foo_f
16
17 @bar_i = alias internal i32* @bar
18
19 ; CHECK-DAG: .globl     A
20 @A = alias bitcast (i32* @bar to i64*)
21
22 ; CHECK-DAG: .globl     bar_h
23 ; CHECK-DAG: .hidden    bar_h
24 @bar_h = hidden alias i32* @bar
25
26 ; CHECK-DAG: .globl     bar_p
27 ; CHECK-DAG: .protected bar_p
28 @bar_p = protected alias i32* @bar
29
30 ; CHECK-DAG: .globl     test
31 define i32 @test() {
32 entry:
33    %tmp = load i32* @foo1
34    %tmp1 = load i32* @foo2
35    %tmp0 = load i32* @bar_i
36    %tmp2 = call i32 @foo_f()
37    %tmp3 = add i32 %tmp, %tmp2
38    %tmp4 = call %FunTy* @bar_f()
39    %tmp5 = add i32 %tmp3, %tmp4
40    %tmp6 = add i32 %tmp1, %tmp5
41    %tmp7 = add i32 %tmp6, %tmp0
42    ret i32 %tmp7
43 }