2014-04-03 16:01:44 +00:00
|
|
|
; RUN: llc -mtriple=arm-eabi -mattr=+v4t %s -o - | FileCheck %s
|
2014-04-12 00:59:48 +00:00
|
|
|
; RUN: llc -mtriple=arm-eabi -mattr=+v4t -addr-sink-using-gep=1 %s -o - | FileCheck %s
|
2014-04-03 16:01:44 +00:00
|
|
|
|
2010-11-19 22:34:53 +00:00
|
|
|
; <rdar://problem/8686347>
|
|
|
|
|
|
|
|
define i32 @test1(i1 %a, i32* %b) {
|
|
|
|
; CHECK: test1
|
|
|
|
entry:
|
|
|
|
br i1 %a, label %lblock, label %rblock
|
|
|
|
|
|
|
|
lblock:
|
|
|
|
%lbranch = getelementptr i32* %b, i32 1
|
|
|
|
br label %end
|
|
|
|
|
|
|
|
rblock:
|
|
|
|
%rbranch = getelementptr i32* %b, i32 1
|
|
|
|
br label %end
|
|
|
|
|
|
|
|
end:
|
|
|
|
; CHECK: ldr r0, [r1, #4]
|
|
|
|
%gep = phi i32* [%lbranch, %lblock], [%rbranch, %rblock]
|
|
|
|
%r = load i32* %gep
|
|
|
|
; CHECK-NEXT: bx lr
|
|
|
|
ret i32 %r
|
2011-07-07 03:55:05 +00:00
|
|
|
}
|