Fix PR4948 (and a leak): by not destroying the DwarfException
[llvm/avr.git] / test / Assembler / ConstantExprFold.ll
blob89edc24b37ec783ae96aa610d661bd852116cd32
1 ; This test checks to make sure that constant exprs fold in some simple 
2 ; situations
4 ; RUN: llvm-as < %s | llvm-dis | not grep {(}
6 @A = global i64 0
8 global i64* inttoptr (i64 add (i64 ptrtoint (i64* @A to i64), i64 0) to i64*) ; X + 0 == X
9 global i64* inttoptr (i64 sub (i64 ptrtoint (i64* @A to i64), i64 0) to i64*) ; X - 0 == X
10 global i64* inttoptr (i64 mul (i64 ptrtoint (i64* @A to i64), i64 0) to i64*) ; X * 0 == 0
11 global i64* inttoptr (i64 sdiv (i64 ptrtoint (i64* @A to i64), i64 1) to i64*) ; X / 1 == X
12 global i64* inttoptr (i64 srem (i64 ptrtoint (i64* @A to i64), i64 1) to i64*) ; X % 1 == 0
13 global i64* inttoptr (i64 and (i64 ptrtoint (i64* @A to i64), i64 0) to i64*) ; X & 0 == 0
14 global i64* inttoptr (i64 and (i64 ptrtoint (i64* @A to i64), i64 -1) to i64*) ; X & -1 == X
15 global i64 or (i64 ptrtoint (i64* @A to i64), i64 -1)  ; X | -1 == -1
16 global i64* inttoptr (i64 xor (i64 ptrtoint (i64* @A to i64), i64 0) to i64*) ; X ^ 0 == X
18 %Ty = type { i32, i32 }
19 @B = external global %Ty 
21 global i1 icmp slt (i64* @A, i64* getelementptr (i64* @A, i64 1))        ; true
22 global i1 icmp slt (i64* @A, i64* getelementptr (i64* @A, i64 0))        ; false
23 global i1 icmp slt (i32* getelementptr (%Ty* @B, i64 0, i32 0), 
24                    i32* getelementptr (%Ty* @B, i64 0, i32 1))            ; true
25 ;global i1 icmp ne (i64* @A, i64* bitcast (%Ty* @B to i64*))                 ; true
27 ; PR2206
28 @cons = weak global i32 0, align 8              ; <i32*> [#uses=1]
29 global i64 and (i64 ptrtoint (i32* @cons to i64), i64 7)