1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -disable-fp-elim < %s | FileCheck -check-prefix=CHECK-FP %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc-unknown-linux-gnu -disable-fp-elim < %s | FileCheck -check-prefix=CHECK-32 %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc-unknown-linux-gnu -disable-fp-elim -relocation-model=pic < %s | FileCheck -check-prefix=CHECK-32-PIC %s 5*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f128:128:128-v128:128:128-n32:64" 6*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu" 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker%struct.s = type { i32, i32 } 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Workerdeclare void @bar(i32*) 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Worker@barbaz = external global i32 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Workerdefine void @goo(%struct.s* byval nocapture readonly %a) { 15*9880d681SAndroid Build Coastguard Workerentry: 16*9880d681SAndroid Build Coastguard Worker %x = alloca [2 x i32], align 32 17*9880d681SAndroid Build Coastguard Worker %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0 18*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %a1, align 4 19*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 0 20*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %arrayidx, align 32 21*9880d681SAndroid Build Coastguard Worker %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1 22*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* %b, align 4 23*9880d681SAndroid Build Coastguard Worker %2 = load i32, i32* @barbaz, align 4 24*9880d681SAndroid Build Coastguard Worker %arrayidx2 = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 1 25*9880d681SAndroid Build Coastguard Worker store i32 %2, i32* %arrayidx2, align 4 26*9880d681SAndroid Build Coastguard Worker call void @bar(i32* %arrayidx) 27*9880d681SAndroid Build Coastguard Worker ret void 28*9880d681SAndroid Build Coastguard Worker} 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @goo 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}} 33*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG:[0-9]+]], 1, 59 34*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -16(1) 35*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1 36*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1) 37*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfic 0, [[REG]], -160 38*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30 41*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_offset r30, -16 42*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_offset lr, 16 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker; CHECK: std 3, 48(30) 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Worker; CHECK: ld 1, 0(1) 47*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ld [[SR:[0-9]+]], 16(1) 48*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ld 30, -16(1) 49*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mtlr [[SR]] 50*9880d681SAndroid Build Coastguard Worker; CHECK: blr 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Worker; CHECK-FP-LABEL: @goo 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mflr {{[0-9]+}} 55*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: clrldi [[REG:[0-9]+]], 1, 59 56*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 31, -8(1) 57*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 30, -16(1) 58*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mr 30, 1 59*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 0, 16(1) 60*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: subfic 0, [[REG]], -160 61*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stdux 1, 1, 0 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_def_cfa_register r30 64*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset r31, -8 65*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset r30, -16 66*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset lr, 16 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker; CHECK-FP: mr 31, 1 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker; CHECK-FP: std 3, 48(30) 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Worker; CHECK-FP: ld 1, 0(1) 73*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld [[SR:[0-9]+]], 16(1) 74*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld 31, -8(1) 75*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld 30, -16(1) 76*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mtlr [[SR]] 77*9880d681SAndroid Build Coastguard Worker; CHECK-FP: blr 78*9880d681SAndroid Build Coastguard Worker 79*9880d681SAndroid Build Coastguard Worker; CHECK-32-LABEL: @goo 80*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mflr {{[0-9]+}} 81*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: clrlwi [[REG:[0-9]+]], 1, 27 82*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 30, -8(1) 83*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mr 30, 1 84*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 0, 4(1) 85*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: subfic 0, [[REG]], -64 86*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0 87*9880d681SAndroid Build Coastguard Worker 88*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-LABEL: @goo 89*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mflr {{[0-9]+}} 90*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: clrlwi [[REG:[0-9]+]], 1, 27 91*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 29, -12(1) 92*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mr 29, 1 93*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 0, 4(1) 94*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: subfic 0, [[REG]], -64 95*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC: stwux 1, 1, 0 96*9880d681SAndroid Build Coastguard Worker 97*9880d681SAndroid Build Coastguard Worker; The large-frame-size case. 98*9880d681SAndroid Build Coastguard Workerdefine void @hoo(%struct.s* byval nocapture readonly %a) { 99*9880d681SAndroid Build Coastguard Workerentry: 100*9880d681SAndroid Build Coastguard Worker %x = alloca [200000 x i32], align 32 101*9880d681SAndroid Build Coastguard Worker %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0 102*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %a1, align 4 103*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds [200000 x i32], [200000 x i32]* %x, i64 0, i64 0 104*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %arrayidx, align 32 105*9880d681SAndroid Build Coastguard Worker %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1 106*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* %b, align 4 107*9880d681SAndroid Build Coastguard Worker %arrayidx2 = getelementptr inbounds [200000 x i32], [200000 x i32]* %x, i64 0, i64 1 108*9880d681SAndroid Build Coastguard Worker store i32 %1, i32* %arrayidx2, align 4 109*9880d681SAndroid Build Coastguard Worker call void @bar(i32* %arrayidx) 110*9880d681SAndroid Build Coastguard Worker ret void 111*9880d681SAndroid Build Coastguard Worker} 112*9880d681SAndroid Build Coastguard Worker 113*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @hoo 114*9880d681SAndroid Build Coastguard Worker 115*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: lis [[REG1:[0-9]+]], -13 116*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG3:[0-9]+]], 1, 59 117*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}} 118*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51808 119*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -16(1) 120*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1 121*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1) 122*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfc 0, [[REG3]], [[REG2]] 123*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0 124*9880d681SAndroid Build Coastguard Worker 125*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30 126*9880d681SAndroid Build Coastguard Worker 127*9880d681SAndroid Build Coastguard Worker; CHECK: blr 128*9880d681SAndroid Build Coastguard Worker 129*9880d681SAndroid Build Coastguard Worker; CHECK-32-LABEL: @hoo 130*9880d681SAndroid Build Coastguard Worker 131*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: lis [[REG1:[0-9]+]], -13 132*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: clrlwi [[REG3:[0-9]+]], 1, 27 133*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mflr {{[0-9]+}} 134*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51904 135*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 30, -8(1) 136*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mr 30, 1 137*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 0, 4(1) 138*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: subfc 0, [[REG3]], [[REG2]] 139*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0 140*9880d681SAndroid Build Coastguard Worker 141*9880d681SAndroid Build Coastguard Worker; CHECK-32: blr 142*9880d681SAndroid Build Coastguard Worker 143*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-LABEL: @hoo 144*9880d681SAndroid Build Coastguard Worker 145*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: lis [[REG1:[0-9]+]], -13 146*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: clrlwi [[REG3:[0-9]+]], 1, 27 147*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mflr {{[0-9]+}} 148*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51904 149*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 29, -12(1) 150*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mr 29, 1 151*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 0, 4(1) 152*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: subfc 0, [[REG3]], [[REG2]] 153*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0 154*9880d681SAndroid Build Coastguard Worker 155*9880d681SAndroid Build Coastguard Worker; CHECK-32: blr 156*9880d681SAndroid Build Coastguard Worker 157*9880d681SAndroid Build Coastguard Worker; Make sure that the FP save area is still allocated correctly relative to 158*9880d681SAndroid Build Coastguard Worker; where r30 is saved. 159*9880d681SAndroid Build Coastguard Workerdefine void @loo(%struct.s* byval nocapture readonly %a) { 160*9880d681SAndroid Build Coastguard Workerentry: 161*9880d681SAndroid Build Coastguard Worker %x = alloca [2 x i32], align 32 162*9880d681SAndroid Build Coastguard Worker %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0 163*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %a1, align 4 164*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 0 165*9880d681SAndroid Build Coastguard Worker store i32 %0, i32* %arrayidx, align 32 166*9880d681SAndroid Build Coastguard Worker %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1 167*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* %b, align 4 168*9880d681SAndroid Build Coastguard Worker %arrayidx2 = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 1 169*9880d681SAndroid Build Coastguard Worker store i32 %1, i32* %arrayidx2, align 4 170*9880d681SAndroid Build Coastguard Worker call void @bar(i32* %arrayidx) 171*9880d681SAndroid Build Coastguard Worker call void asm sideeffect "", "~{f30}"() nounwind 172*9880d681SAndroid Build Coastguard Worker ret void 173*9880d681SAndroid Build Coastguard Worker} 174*9880d681SAndroid Build Coastguard Worker 175*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @loo 176*9880d681SAndroid Build Coastguard Worker 177*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}} 178*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG:[0-9]+]], 1, 59 179*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -32(1) 180*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1 181*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1) 182*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfic 0, [[REG]], -192 183*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0 184*9880d681SAndroid Build Coastguard Worker 185*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30 186*9880d681SAndroid Build Coastguard Worker 187*9880d681SAndroid Build Coastguard Worker; CHECK: stfd 30, -16(30) 188*9880d681SAndroid Build Coastguard Worker 189*9880d681SAndroid Build Coastguard Worker; CHECK: blr 190*9880d681SAndroid Build Coastguard Worker 191*9880d681SAndroid Build Coastguard Worker; CHECK-FP-LABEL: @loo 192*9880d681SAndroid Build Coastguard Worker 193*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mflr {{[0-9]+}} 194*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: clrldi [[REG:[0-9]+]], 1, 59 195*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 31, -24(1) 196*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 30, -32(1) 197*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mr 30, 1 198*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 0, 16(1) 199*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: subfic 0, [[REG]], -192 200*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stdux 1, 1, 0 201*9880d681SAndroid Build Coastguard Worker 202*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_def_cfa_register r30 203*9880d681SAndroid Build Coastguard Worker 204*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stfd 30, -16(30) 205*9880d681SAndroid Build Coastguard Worker 206*9880d681SAndroid Build Coastguard Worker; CHECK-FP: blr 207