mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-07 12:30:44 +00:00
8ad1f0e284
needed for this test, but otherwise, there's nothing ARM-specific about it and no need to specify the calling convention. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94862 91177308-0d34-0410-b5e6-96231b3b80d8
17 lines
673 B
LLVM
17 lines
673 B
LLVM
; RUN: opt < %s -instcombine -S | FileCheck %s
|
|
|
|
target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:32-n32"
|
|
|
|
@a = constant [2 x i32] [i32 3, i32 6] ; <[2 x i32]*> [#uses=2]
|
|
|
|
define i32 @b(i32 %y) nounwind readonly {
|
|
; CHECK: @b
|
|
; CHECK-NOT: load
|
|
; CHECK: ret i32
|
|
entry:
|
|
%0 = icmp eq i32 %y, 0 ; <i1> [#uses=1]
|
|
%storemerge = select i1 %0, i32* getelementptr inbounds ([2 x i32]* @a, i32 0, i32 1), i32* getelementptr inbounds ([2 x i32]* @a, i32 0, i32 0) ; <i32*> [#uses=1]
|
|
%1 = load i32* %storemerge, align 4 ; <i32> [#uses=1]
|
|
ret i32 %1
|
|
}
|