xref: /aosp_15_r20/external/llvm/test/Transforms/ArgumentPromotion/2008-07-02-array-indexing.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -argpromotion -S > %t
2*9880d681SAndroid Build Coastguard Worker; RUN: cat %t | grep "define.*@callee(.*i32\*"
3*9880d681SAndroid Build Coastguard Worker; PR2498
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; This test tries to convince argpromotion about promoting the load from %A + 2,
6*9880d681SAndroid Build Coastguard Worker; because there is a load of %A in the entry block
7*9880d681SAndroid Build Coastguard Workerdefine internal i32 @callee(i1 %C, i32* %A) {
8*9880d681SAndroid Build Coastguard Workerentry:
9*9880d681SAndroid Build Coastguard Worker        ; Unconditonally load the element at %A
10*9880d681SAndroid Build Coastguard Worker        %A.0 = load i32, i32* %A
11*9880d681SAndroid Build Coastguard Worker        br i1 %C, label %T, label %F
12*9880d681SAndroid Build Coastguard WorkerT:
13*9880d681SAndroid Build Coastguard Worker        ret i32 %A.0
14*9880d681SAndroid Build Coastguard WorkerF:
15*9880d681SAndroid Build Coastguard Worker        ; Load the element at offset two from %A. This should not be promoted!
16*9880d681SAndroid Build Coastguard Worker        %A.2 = getelementptr i32, i32* %A, i32 2
17*9880d681SAndroid Build Coastguard Worker        %R = load i32, i32* %A.2
18*9880d681SAndroid Build Coastguard Worker        ret i32 %R
19*9880d681SAndroid Build Coastguard Worker}
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerdefine i32 @foo() {
22*9880d681SAndroid Build Coastguard Worker        %X = call i32 @callee(i1 false, i32* null)             ; <i32> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker        ret i32 %X
24*9880d681SAndroid Build Coastguard Worker}
25*9880d681SAndroid Build Coastguard Worker
26