In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / Transforms / SCCP / apint-load.ll
blob96509714bb070696705b1329bd19dc8966444c8a
1 ; This test makes sure that these instructions are properly constant propagated.
3 ; RUN: llvm-as < %s | opt -ipsccp | llvm-dis | not grep load
4 ; RUN: llvm-as < %s | opt -ipsccp | llvm-dis | not grep fdiv
6 @X = constant i212 42
7 @Y = constant [2 x { i212, float }] [ { i212, float } { i212 12, float 1.0 }, 
8                                      { i212, float } { i212 37, float 0x3FF3B2FEC0000000 } ]
9 define i212 @test1() {
10         %B = load i212* @X
11         ret i212 %B
14 define internal float @test2() {
15         %A = getelementptr [2 x { i212, float}]* @Y, i32 0, i32 1, i32 1
16         %B = load float* %A
17         ret float %B
20 define internal i212 @test3() {
21         %A = getelementptr [2 x { i212, float}]* @Y, i32 0, i32 0, i32 0
22         %B = load i212* %A
23         ret i212 %B
26 define float @All()
28    %A = call float @test2()
29    %B = call i212 @test3()
30    %C = mul i212 %B, -1234567
31    %D = sitofp i212 %C to float
32    %E = fdiv float %A, %D
33    ret float %E