1*9880d681SAndroid Build Coastguard Worker; Test 64-bit floating-point loads. 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z10 | FileCheck %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 | FileCheck %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; Test the low end of the LD range. 7*9880d681SAndroid Build Coastguard Workerdefine double @f1(double *%src) { 8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f1: 9*9880d681SAndroid Build Coastguard Worker; CHECK: ld %f0, 0(%r2) 10*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 11*9880d681SAndroid Build Coastguard Worker %val = load double , double *%src 12*9880d681SAndroid Build Coastguard Worker ret double %val 13*9880d681SAndroid Build Coastguard Worker} 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker; Test the high end of the LD range. 16*9880d681SAndroid Build Coastguard Workerdefine double @f2(double *%src) { 17*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f2: 18*9880d681SAndroid Build Coastguard Worker; CHECK: ld %f0, 4088(%r2) 19*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 20*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 511 21*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 22*9880d681SAndroid Build Coastguard Worker ret double %val 23*9880d681SAndroid Build Coastguard Worker} 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker; Check the next doubleword up, which should use LDY instead of LD. 26*9880d681SAndroid Build Coastguard Workerdefine double @f3(double *%src) { 27*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f3: 28*9880d681SAndroid Build Coastguard Worker; CHECK: ldy %f0, 4096(%r2) 29*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 30*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 512 31*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 32*9880d681SAndroid Build Coastguard Worker ret double %val 33*9880d681SAndroid Build Coastguard Worker} 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker; Check the high end of the aligned LDY range. 36*9880d681SAndroid Build Coastguard Workerdefine double @f4(double *%src) { 37*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f4: 38*9880d681SAndroid Build Coastguard Worker; CHECK: ldy %f0, 524280(%r2) 39*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 40*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 65535 41*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 42*9880d681SAndroid Build Coastguard Worker ret double %val 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; Check the next doubleword up, which needs separate address logic. 46*9880d681SAndroid Build Coastguard Worker; Other sequences besides this one would be OK. 47*9880d681SAndroid Build Coastguard Workerdefine double @f5(double *%src) { 48*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f5: 49*9880d681SAndroid Build Coastguard Worker; CHECK: agfi %r2, 524288 50*9880d681SAndroid Build Coastguard Worker; CHECK: ld %f0, 0(%r2) 51*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 52*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 65536 53*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 54*9880d681SAndroid Build Coastguard Worker ret double %val 55*9880d681SAndroid Build Coastguard Worker} 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker; Check the high end of the negative aligned LDY range. 58*9880d681SAndroid Build Coastguard Workerdefine double @f6(double *%src) { 59*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f6: 60*9880d681SAndroid Build Coastguard Worker; CHECK: ldy %f0, -8(%r2) 61*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 62*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 -1 63*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 64*9880d681SAndroid Build Coastguard Worker ret double %val 65*9880d681SAndroid Build Coastguard Worker} 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Worker; Check the low end of the LDY range. 68*9880d681SAndroid Build Coastguard Workerdefine double @f7(double *%src) { 69*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f7: 70*9880d681SAndroid Build Coastguard Worker; CHECK: ldy %f0, -524288(%r2) 71*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 72*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 -65536 73*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 74*9880d681SAndroid Build Coastguard Worker ret double %val 75*9880d681SAndroid Build Coastguard Worker} 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Worker; Check the next doubleword down, which needs separate address logic. 78*9880d681SAndroid Build Coastguard Worker; Other sequences besides this one would be OK. 79*9880d681SAndroid Build Coastguard Workerdefine double @f8(double *%src) { 80*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f8: 81*9880d681SAndroid Build Coastguard Worker; CHECK: agfi %r2, -524296 82*9880d681SAndroid Build Coastguard Worker; CHECK: ld %f0, 0(%r2) 83*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 84*9880d681SAndroid Build Coastguard Worker %ptr = getelementptr double, double *%src, i64 -65537 85*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 86*9880d681SAndroid Build Coastguard Worker ret double %val 87*9880d681SAndroid Build Coastguard Worker} 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Worker; Check that LD allows an index. 90*9880d681SAndroid Build Coastguard Workerdefine double @f9(i64 %src, i64 %index) { 91*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f9: 92*9880d681SAndroid Build Coastguard Worker; CHECK: ld %f0, 4095({{%r3,%r2|%r2,%r3}}) 93*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 94*9880d681SAndroid Build Coastguard Worker %add1 = add i64 %src, %index 95*9880d681SAndroid Build Coastguard Worker %add2 = add i64 %add1, 4095 96*9880d681SAndroid Build Coastguard Worker %ptr = inttoptr i64 %add2 to double * 97*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 98*9880d681SAndroid Build Coastguard Worker ret double %val 99*9880d681SAndroid Build Coastguard Worker} 100*9880d681SAndroid Build Coastguard Worker 101*9880d681SAndroid Build Coastguard Worker; Check that LDY allows an index. 102*9880d681SAndroid Build Coastguard Workerdefine double @f10(i64 %src, i64 %index) { 103*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: f10: 104*9880d681SAndroid Build Coastguard Worker; CHECK: ldy %f0, 4096({{%r3,%r2|%r2,%r3}}) 105*9880d681SAndroid Build Coastguard Worker; CHECK: br %r14 106*9880d681SAndroid Build Coastguard Worker %add1 = add i64 %src, %index 107*9880d681SAndroid Build Coastguard Worker %add2 = add i64 %add1, 4096 108*9880d681SAndroid Build Coastguard Worker %ptr = inttoptr i64 %add2 to double * 109*9880d681SAndroid Build Coastguard Worker %val = load double , double *%ptr 110*9880d681SAndroid Build Coastguard Worker ret double %val 111*9880d681SAndroid Build Coastguard Worker} 112