1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=mipsel -relocation-model=pic | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker@caller.sf1 = internal unnamed_addr global void (...)* null, align 4 4*9880d681SAndroid Build Coastguard Worker@gf1 = external global void (...)* 5*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [3 x i8] c"f2\00" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workerdefine i32 @main(i32 %argc, i8** nocapture %argv) nounwind { 8*9880d681SAndroid Build Coastguard Workerentry: 9*9880d681SAndroid Build Coastguard Worker; CHECK: lw $[[R0:[0-9]+]], %got(f2) 10*9880d681SAndroid Build Coastguard Worker; CHECK: addiu $25, $[[R0]], %lo(f2) 11*9880d681SAndroid Build Coastguard Worker tail call fastcc void @f2() 12*9880d681SAndroid Build Coastguard Worker ret i32 0 13*9880d681SAndroid Build Coastguard Worker} 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerdefine void @caller(i32 %a0, i32 %a1) nounwind { 16*9880d681SAndroid Build Coastguard Workerentry: 17*9880d681SAndroid Build Coastguard Worker; CHECK: lw $[[R1:[0-9]+]], %got(caller.sf1) 18*9880d681SAndroid Build Coastguard Worker; CHECK: lw $25, %lo(caller.sf1)($[[R1]]) 19*9880d681SAndroid Build Coastguard Worker %tobool = icmp eq i32 %a1, 0 20*9880d681SAndroid Build Coastguard Worker br i1 %tobool, label %if.end, label %if.then 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Workerif.then: ; preds = %entry 23*9880d681SAndroid Build Coastguard Worker %tmp1 = load void (...)*, void (...)** @caller.sf1, align 4 24*9880d681SAndroid Build Coastguard Worker tail call void (...) %tmp1() nounwind 25*9880d681SAndroid Build Coastguard Worker br label %if.end 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %entry, %if.then 28*9880d681SAndroid Build Coastguard Worker; CHECK: lw $[[R2:[0-9]+]], %got(sf2) 29*9880d681SAndroid Build Coastguard Worker; CHECK: addiu ${{[0-9]+}}, $[[R2]], %lo(sf2) 30*9880d681SAndroid Build Coastguard Worker; CHECK: lw $[[R3:[0-9]+]], %got(caller.sf1) 31*9880d681SAndroid Build Coastguard Worker; CHECK: sw ${{[0-9]+}}, %lo(caller.sf1)($[[R3]]) 32*9880d681SAndroid Build Coastguard Worker %tobool3 = icmp ne i32 %a0, 0 33*9880d681SAndroid Build Coastguard Worker %tmp4 = load void (...)*, void (...)** @gf1, align 4 34*9880d681SAndroid Build Coastguard Worker %cond = select i1 %tobool3, void (...)* %tmp4, void (...)* bitcast (void ()* @sf2 to void (...)*) 35*9880d681SAndroid Build Coastguard Worker store void (...)* %cond, void (...)** @caller.sf1, align 4 36*9880d681SAndroid Build Coastguard Worker ret void 37*9880d681SAndroid Build Coastguard Worker} 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerdefine internal void @sf2() nounwind { 40*9880d681SAndroid Build Coastguard Workerentry: 41*9880d681SAndroid Build Coastguard Worker %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @.str, i32 0, i32 0)) nounwind 42*9880d681SAndroid Build Coastguard Worker ret void 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture, ...) nounwind 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Workerdefine internal fastcc void @f2() nounwind noinline { 48*9880d681SAndroid Build Coastguard Workerentry: 49*9880d681SAndroid Build Coastguard Worker %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @.str, i32 0, i32 0)) nounwind 50*9880d681SAndroid Build Coastguard Worker ret void 51*9880d681SAndroid Build Coastguard Worker} 52*9880d681SAndroid Build Coastguard Worker 53