2008-02-14 06:56:27 +00:00
|
|
|
; This testcase ensures that redundant loads are eliminated when they should
|
2002-05-16 01:03:12 +00:00
|
|
|
; be. All RL variables (redundant loads) should be eliminated.
|
|
|
|
;
|
2008-02-14 06:56:27 +00:00
|
|
|
; RUN: llvm-as < %s | opt -load-vn -gcse | llvm-dis | not grep %RL
|
2002-05-16 01:03:12 +00:00
|
|
|
;
|
2008-02-14 06:56:27 +00:00
|
|
|
|
|
|
|
define i32 @test1(i32* %P) {
|
|
|
|
%A = load i32* %P ; <i32> [#uses=1]
|
|
|
|
%RL = load i32* %P ; <i32> [#uses=1]
|
|
|
|
%C = add i32 %A, %RL ; <i32> [#uses=1]
|
|
|
|
ret i32 %C
|
2002-05-16 01:03:12 +00:00
|
|
|
}
|
|
|
|
|
2008-02-14 06:56:27 +00:00
|
|
|
define i32 @test2(i32* %P) {
|
|
|
|
%A = load i32* %P ; <i32> [#uses=1]
|
2002-05-16 01:03:12 +00:00
|
|
|
br label %BB2
|
2008-02-14 06:56:27 +00:00
|
|
|
|
|
|
|
BB2: ; preds = %0
|
2002-05-16 01:03:12 +00:00
|
|
|
br label %BB3
|
|
|
|
|
2008-02-14 06:56:27 +00:00
|
|
|
BB3: ; preds = %BB2
|
|
|
|
%RL = load i32* %P ; <i32> [#uses=1]
|
|
|
|
%B = add i32 %A, %RL ; <i32> [#uses=1]
|
|
|
|
ret i32 %B
|
|
|
|
}
|