Some optimizations done by globalopt are safe only for internal linkage, not
[oota-llvm.git] / test / Transforms / GlobalOpt / unnamed-addr.ll
1 ; RUN: opt %s -globalopt -S | FileCheck %s
2
3 @a = internal global i32 0, align 4
4 @b = internal global i32 0, align 4
5 @c = internal global i32 0, align 4
6 @d = internal constant [4 x i8] c"foo\00", align 1
7 @e = linkonce_odr global i32 0
8
9 ; CHECK: @a = internal global i32 0, align 4
10 ; CHECK: @b = internal global i32 0, align 4
11 ; CHECK: @c = internal unnamed_addr global i32 0, align 4
12 ; CHECK: @d = internal unnamed_addr constant [4 x i8] c"foo\00", align 1
13 ; CHECK: @e = linkonce_odr global i32 0
14
15 define i32 @get_e() {
16        %t = load i32* @e
17        ret i32 %t
18 }
19
20 define void @set_e(i32 %x) {
21        store i32 %x, i32* @e
22        ret void
23 }
24
25 define i1 @bah(i64 %i) nounwind readonly optsize ssp {
26 entry:
27   %arrayidx4 = getelementptr inbounds [4 x i8]* @d, i64 0, i64 %i
28   %tmp5 = load i8* %arrayidx4, align 1
29   %cmp = icmp eq i8 %tmp5, 42
30   ret i1 %cmp
31 }
32
33 define void @baz(i32 %x) {
34 entry:
35   store i32 %x, i32* @a, align 4
36   store i32 %x, i32* @b, align 4
37   store i32 %x, i32* @c, align 4
38   ret void
39 }
40
41 define i32 @foo(i32* %x) nounwind readnone optsize ssp {
42 entry:
43   %cmp = icmp eq i32* %x, @a
44   %conv = zext i1 %cmp to i32
45   ret i32 %conv
46 }
47
48 define i32 @bar() {
49 entry:
50   switch i64 ptrtoint (i32* @b to i64), label %sw.epilog [
51     i64 1, label %return
52     i64 0, label %return
53   ]
54
55 sw.epilog:
56   ret i32 0
57
58 return:
59   ret i32 1
60 }
61
62 define i32 @zed() {
63 entry:
64   %tmp1 = load i32* @c, align 4
65   ret i32 %tmp1
66 }