1583d492cSJean Perier! Test lowering of vector subscript designators outside of the 2583d492cSJean Perier! assignment left-and side and input IO context. 3d0829fbdSjeanPerier! RUN: bbc -emit-hlfir -o - -I nw %s 2>&1 | FileCheck %s 4583d492cSJean Perier 5583d492cSJean Periersubroutine foo(x, y) 6583d492cSJean Perier integer :: x(100) 7583d492cSJean Perier integer(8) :: y(20) 8583d492cSJean Perier call bar(x(y)) 9583d492cSJean Perierend subroutine 10583d492cSJean Perier! CHECK-LABEL: func.func @_QPfoo( 11583d492cSJean Perier! CHECK: %[[VAL_2:.*]] = arith.constant 100 : index 12583d492cSJean Perier! CHECK: %[[VAL_3:.*]] = fir.shape %[[VAL_2]] : (index) -> !fir.shape<1> 13583d492cSJean Perier! CHECK: %[[VAL_4:.*]]:2 = hlfir.declare %[[VAL_0:[a-z0-9]*]](%[[VAL_3:[a-z0-9]*]]) {{.*}}Ex 14583d492cSJean Perier! CHECK: %[[VAL_5:.*]] = arith.constant 20 : index 15583d492cSJean Perier! CHECK: %[[VAL_6:.*]] = fir.shape %[[VAL_5]] : (index) -> !fir.shape<1> 16583d492cSJean Perier! CHECK: %[[VAL_7:.*]]:2 = hlfir.declare %[[VAL_1:[a-z0-9]*]](%[[VAL_6:[a-z0-9]*]]) {{.*}}Ey 17583d492cSJean Perier! CHECK: %[[VAL_8:.*]] = arith.constant 20 : index 18583d492cSJean Perier! CHECK: %[[VAL_9:.*]] = fir.shape %[[VAL_8]] : (index) -> !fir.shape<1> 197b4aa95dSSlava Zakharin! CHECK: %[[VAL_10:.*]] = hlfir.elemental %[[VAL_9]] unordered : (!fir.shape<1>) -> !hlfir.expr<20xi32> { 20583d492cSJean Perier! CHECK: ^bb0(%[[VAL_11:.*]]: index): 21583d492cSJean Perier! CHECK: %[[VAL_12:.*]] = hlfir.designate %[[VAL_7]]#0 (%[[VAL_11]]) : (!fir.ref<!fir.array<20xi64>>, index) -> !fir.ref<i64> 22583d492cSJean Perier! CHECK: %[[VAL_13:.*]] = fir.load %[[VAL_12]] : !fir.ref<i64> 23583d492cSJean Perier! CHECK: %[[VAL_14:.*]] = hlfir.designate %[[VAL_4]]#0 (%[[VAL_13]]) : (!fir.ref<!fir.array<100xi32>>, i64) -> !fir.ref<i32> 24583d492cSJean Perier! CHECK: %[[VAL_15:.*]] = fir.load %[[VAL_14]] : !fir.ref<i32> 25583d492cSJean Perier! CHECK: hlfir.yield_element %[[VAL_15]] : i32 26583d492cSJean Perier! CHECK: } 270ccef6a7SMats Petersson! CHECK: %[[VAL_16:.*]]:3 = hlfir.associate %[[VAL_17:.*]](%[[VAL_9]]) {adapt.valuebyref} : (!hlfir.expr<20xi32>, !fir.shape<1>) -> (!fir.ref<!fir.array<20xi32>>, !fir.ref<!fir.array<20xi32>>, i1) 28583d492cSJean Perier! CHECK: fir.call @_QPbar(%[[VAL_16]]#1) fastmath<contract> : (!fir.ref<!fir.array<20xi32>>) -> () 29583d492cSJean Perier! CHECK: hlfir.end_associate %[[VAL_16]]#1, %[[VAL_16]]#2 : !fir.ref<!fir.array<20xi32>>, i1 30583d492cSJean Perier! CHECK: hlfir.destroy %[[VAL_17]] : !hlfir.expr<20xi32> 31583d492cSJean Perier 32583d492cSJean Periersubroutine foo2(x, y) 33583d492cSJean Perier integer :: x(10, 30, 100) 34583d492cSJean Perier integer(8) :: y(20) 35583d492cSJean Perier call bar2(x(1:8:2, 5, y)) 36583d492cSJean Perierend subroutine 37583d492cSJean Perier! CHECK-LABEL: func.func @_QPfoo2( 38583d492cSJean Perier! CHECK: %[[VAL_2:.*]] = arith.constant 10 : index 39583d492cSJean Perier! CHECK: %[[VAL_3:.*]] = arith.constant 30 : index 40583d492cSJean Perier! CHECK: %[[VAL_4:.*]] = arith.constant 100 : index 41583d492cSJean Perier! CHECK: %[[VAL_5:.*]] = fir.shape %[[VAL_2]], %[[VAL_3]], %[[VAL_4]] : (index, index, index) -> !fir.shape<3> 42583d492cSJean Perier! CHECK: %[[VAL_6:.*]]:2 = hlfir.declare %[[VAL_0:[a-z0-9]*]](%[[VAL_5:[a-z0-9]*]]) {{.*}}Ex 43583d492cSJean Perier! CHECK: %[[VAL_7:.*]] = arith.constant 20 : index 44583d492cSJean Perier! CHECK: %[[VAL_8:.*]] = fir.shape %[[VAL_7]] : (index) -> !fir.shape<1> 45583d492cSJean Perier! CHECK: %[[VAL_9:.*]]:2 = hlfir.declare %[[VAL_1:[a-z0-9]*]](%[[VAL_8:[a-z0-9]*]]) {{.*}}Ey 46583d492cSJean Perier! CHECK: %[[VAL_10:.*]] = arith.constant 1 : index 47583d492cSJean Perier! CHECK: %[[VAL_11:.*]] = arith.constant 2 : index 48583d492cSJean Perier! CHECK: %[[VAL_12:.*]] = arith.constant 4 : index 49583d492cSJean Perier! CHECK: %[[VAL_13:.*]] = arith.constant 5 : index 50583d492cSJean Perier! CHECK: %[[VAL_14:.*]] = arith.constant 20 : index 51583d492cSJean Perier! CHECK: %[[VAL_15:.*]] = fir.shape %[[VAL_12]], %[[VAL_14]] : (index, index) -> !fir.shape<2> 527b4aa95dSSlava Zakharin! CHECK: %[[VAL_16:.*]] = hlfir.elemental %[[VAL_15]] unordered : (!fir.shape<2>) -> !hlfir.expr<4x20xi32> { 53583d492cSJean Perier! CHECK: ^bb0(%[[VAL_17:.*]]: index, %[[VAL_18:.*]]: index): 54583d492cSJean Perier! CHECK: %[[VAL_19:.*]] = arith.constant 1 : index 55583d492cSJean Perier! CHECK: %[[VAL_20:.*]] = arith.subi %[[VAL_17]], %[[VAL_19]] : index 56583d492cSJean Perier! CHECK: %[[VAL_21:.*]] = arith.muli %[[VAL_20]], %[[VAL_11]] : index 57583d492cSJean Perier! CHECK: %[[VAL_22:.*]] = arith.addi %[[VAL_10]], %[[VAL_21]] : index 58583d492cSJean Perier! CHECK: %[[VAL_23:.*]] = hlfir.designate %[[VAL_9]]#0 (%[[VAL_18]]) : (!fir.ref<!fir.array<20xi64>>, index) -> !fir.ref<i64> 59583d492cSJean Perier! CHECK: %[[VAL_24:.*]] = fir.load %[[VAL_23]] : !fir.ref<i64> 60583d492cSJean Perier! CHECK: %[[VAL_25:.*]] = hlfir.designate %[[VAL_6]]#0 (%[[VAL_22]], %[[VAL_13]], %[[VAL_24]]) : (!fir.ref<!fir.array<10x30x100xi32>>, index, index, i64) -> !fir.ref<i32> 61583d492cSJean Perier! CHECK: %[[VAL_26:.*]] = fir.load %[[VAL_25]] : !fir.ref<i32> 62583d492cSJean Perier! CHECK: hlfir.yield_element %[[VAL_26]] : i32 63583d492cSJean Perier! CHECK: } 64583d492cSJean Perier 65583d492cSJean Periersubroutine foo3(x, y) 66583d492cSJean Perier integer, pointer :: x(:, :, :) 67583d492cSJean Perier integer(8) :: y(20) 68583d492cSJean Perier call bar2(x(1:8:2, 5, y)) 69583d492cSJean Perierend subroutine 70583d492cSJean Perier! CHECK-LABEL: func.func @_QPfoo3( 711710c8cfSSlava Zakharin! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[VAL_0:[a-z0-9]*]] dummy_scope %{{[0-9]+}} {fortran_attrs = #fir.var_attrs<pointer>, uniq_name = "_QFfoo3Ex"} : (!fir.ref<!fir.box<!fir.ptr<!fir.array<?x?x?xi32>>>>, !fir.dscope) -> (!fir.ref<!fir.box<!fir.ptr<!fir.array<?x?x?xi32>>>>, !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?x?xi32>>>>) 72583d492cSJean Perier! CHECK: %[[VAL_3:.*]] = arith.constant 20 : index 73583d492cSJean Perier! CHECK: %[[VAL_4:.*]] = fir.shape %[[VAL_3]] : (index) -> !fir.shape<1> 74583d492cSJean Perier! CHECK: %[[VAL_5:.*]]:2 = hlfir.declare %[[VAL_1:[a-z0-9]*]](%[[VAL_4:[a-z0-9]*]]) {{.*}}Ey 75583d492cSJean Perier! CHECK: %[[VAL_6:.*]] = fir.load %[[VAL_2]]#0 : !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?x?xi32>>>> 76583d492cSJean Perier! CHECK: %[[VAL_7:.*]] = arith.constant 1 : index 77583d492cSJean Perier! CHECK: %[[VAL_8:.*]] = arith.constant 2 : index 78583d492cSJean Perier! CHECK: %[[VAL_9:.*]] = arith.constant 4 : index 79583d492cSJean Perier! CHECK: %[[VAL_10:.*]] = arith.constant 5 : index 80583d492cSJean Perier! CHECK: %[[VAL_11:.*]] = arith.constant 20 : index 81583d492cSJean Perier! CHECK: %[[VAL_12:.*]] = fir.shape %[[VAL_9]], %[[VAL_11]] : (index, index) -> !fir.shape<2> 827b4aa95dSSlava Zakharin! CHECK: %[[VAL_13:.*]] = hlfir.elemental %[[VAL_12]] unordered : (!fir.shape<2>) -> !hlfir.expr<4x20xi32> { 83583d492cSJean Perier! CHECK: ^bb0(%[[VAL_14:.*]]: index, %[[VAL_15:.*]]: index): 84583d492cSJean Perier! CHECK: %[[VAL_16:.*]] = arith.constant 1 : index 85583d492cSJean Perier! CHECK: %[[VAL_17:.*]] = arith.subi %[[VAL_14]], %[[VAL_16]] : index 86583d492cSJean Perier! CHECK: %[[VAL_18:.*]] = arith.muli %[[VAL_17]], %[[VAL_8]] : index 87583d492cSJean Perier! CHECK: %[[VAL_19:.*]] = arith.addi %[[VAL_7]], %[[VAL_18]] : index 88583d492cSJean Perier! CHECK: %[[VAL_20:.*]] = hlfir.designate %[[VAL_5]]#0 (%[[VAL_15]]) : (!fir.ref<!fir.array<20xi64>>, index) -> !fir.ref<i64> 89583d492cSJean Perier! CHECK: %[[VAL_21:.*]] = fir.load %[[VAL_20]] : !fir.ref<i64> 90583d492cSJean Perier! CHECK: %[[VAL_22:.*]] = hlfir.designate %[[VAL_6]] (%[[VAL_19]], %[[VAL_10]], %[[VAL_21]]) : (!fir.box<!fir.ptr<!fir.array<?x?x?xi32>>>, index, index, i64) -> !fir.ref<i32> 91583d492cSJean Perier! CHECK: %[[VAL_23:.*]] = fir.load %[[VAL_22]] : !fir.ref<i32> 92583d492cSJean Perier! CHECK: hlfir.yield_element %[[VAL_23]] : i32 93583d492cSJean Perier! CHECK: } 94583d492cSJean Perier 95583d492cSJean Periersubroutine foo4(at1, vector, i, j, k, l, step) 96583d492cSJean Perier type t0 97583d492cSJean Perier complex :: x(10, 20) 98583d492cSJean Perier end type 99583d492cSJean Perier type t1 100583d492cSJean Perier type(t0) :: at0(30, 40, 50) 101583d492cSJean Perier end type 102583d492cSJean Perier type(t1) :: at1(:) 103583d492cSJean Perier integer(8) :: vector(:), step, i, j, k, l 104583d492cSJean Perier call bar3(at1(i)%at0(1:8:step, j, vector)%x(k, l)%im) 105583d492cSJean Perierend subroutine 106583d492cSJean Perier! CHECK-LABEL: func.func @_QPfoo4( 107583d492cSJean Perier! CHECK: %[[VAL_7:.*]]:2 = hlfir.declare %[[VAL_0:[a-z0-9]*]] {{.*}}Eat1 108583d492cSJean Perier! CHECK: %[[VAL_8:.*]]:2 = hlfir.declare %[[VAL_2:[a-z0-9]*]] {{.*}}Ei 109583d492cSJean Perier! CHECK: %[[VAL_9:.*]]:2 = hlfir.declare %[[VAL_3:[a-z0-9]*]] {{.*}}Ej 110583d492cSJean Perier! CHECK: %[[VAL_10:.*]]:2 = hlfir.declare %[[VAL_4:[a-z0-9]*]] {{.*}}Ek 111583d492cSJean Perier! CHECK: %[[VAL_11:.*]]:2 = hlfir.declare %[[VAL_5:[a-z0-9]*]] {{.*}}El 112583d492cSJean Perier! CHECK: %[[VAL_12:.*]]:2 = hlfir.declare %[[VAL_6:[a-z0-9]*]] {{.*}}Estep 113583d492cSJean Perier! CHECK: %[[VAL_13:.*]]:2 = hlfir.declare %[[VAL_1:[a-z0-9]*]] {{.*}}Evector 114583d492cSJean Perier! CHECK: %[[VAL_14:.*]] = fir.load %[[VAL_8]]#0 : !fir.ref<i64> 115*c4204c0bSjeanPerier! CHECK: %[[VAL_15:.*]] = hlfir.designate %[[VAL_7]]#0 (%[[VAL_14]]) : (!fir.box<!fir.array<?x!fir.type<_QFfoo4Tt1{at0:!fir.array<30x40x50x!fir.type<_QFfoo4Tt0{x:!fir.array<10x20xcomplex<f32>>}>>}>>>, i64) -> !fir.ref<!fir.type<_QFfoo4Tt1{at0:!fir.array<30x40x50x!fir.type<_QFfoo4Tt0{x:!fir.array<10x20xcomplex<f32>>}>>}>> 116583d492cSJean Perier! CHECK: %[[VAL_16:.*]] = arith.constant 30 : index 117583d492cSJean Perier! CHECK: %[[VAL_17:.*]] = arith.constant 40 : index 118583d492cSJean Perier! CHECK: %[[VAL_18:.*]] = arith.constant 50 : index 119583d492cSJean Perier! CHECK: %[[VAL_19:.*]] = fir.shape %[[VAL_16]], %[[VAL_17]], %[[VAL_18]] : (index, index, index) -> !fir.shape<3> 120583d492cSJean Perier! CHECK: %[[VAL_20:.*]] = arith.constant 1 : index 121583d492cSJean Perier! CHECK: %[[VAL_21:.*]] = arith.constant 8 : index 122583d492cSJean Perier! CHECK: %[[VAL_22:.*]] = fir.load %[[VAL_12]]#0 : !fir.ref<i64> 123583d492cSJean Perier! CHECK: %[[VAL_23:.*]] = fir.convert %[[VAL_22]] : (i64) -> index 124583d492cSJean Perier! CHECK: %[[VAL_24:.*]] = arith.constant 0 : index 125583d492cSJean Perier! CHECK: %[[VAL_25:.*]] = arith.subi %[[VAL_21]], %[[VAL_20]] : index 126583d492cSJean Perier! CHECK: %[[VAL_26:.*]] = arith.addi %[[VAL_25]], %[[VAL_23]] : index 127583d492cSJean Perier! CHECK: %[[VAL_27:.*]] = arith.divsi %[[VAL_26]], %[[VAL_23]] : index 128583d492cSJean Perier! CHECK: %[[VAL_28:.*]] = arith.cmpi sgt, %[[VAL_27]], %[[VAL_24]] : index 129583d492cSJean Perier! CHECK: %[[VAL_29:.*]] = arith.select %[[VAL_28]], %[[VAL_27]], %[[VAL_24]] : index 130583d492cSJean Perier! CHECK: %[[VAL_30:.*]] = fir.load %[[VAL_9]]#0 : !fir.ref<i64> 131583d492cSJean Perier! CHECK: %[[VAL_31:.*]] = arith.constant 0 : index 132583d492cSJean Perier! CHECK: %[[VAL_32:.*]]:3 = fir.box_dims %[[VAL_13]]#0, %[[VAL_31]] : (!fir.box<!fir.array<?xi64>>, index) -> (index, index, index) 133583d492cSJean Perier! CHECK: %[[VAL_33:.*]] = fir.shape %[[VAL_29]], %[[VAL_32]]#1 : (index, index) -> !fir.shape<2> 134583d492cSJean Perier! CHECK: %[[VAL_34:.*]] = arith.constant 10 : index 135583d492cSJean Perier! CHECK: %[[VAL_35:.*]] = arith.constant 20 : index 136583d492cSJean Perier! CHECK: %[[VAL_36:.*]] = fir.shape %[[VAL_34]], %[[VAL_35]] : (index, index) -> !fir.shape<2> 137583d492cSJean Perier! CHECK: %[[VAL_37:.*]] = fir.load %[[VAL_10]]#0 : !fir.ref<i64> 138583d492cSJean Perier! CHECK: %[[VAL_38:.*]] = fir.load %[[VAL_11]]#0 : !fir.ref<i64> 1397b4aa95dSSlava Zakharin! CHECK: %[[VAL_39:.*]] = hlfir.elemental %[[VAL_33]] unordered : (!fir.shape<2>) -> !hlfir.expr<?x?xf32> { 140583d492cSJean Perier! CHECK: ^bb0(%[[VAL_40:.*]]: index, %[[VAL_41:.*]]: index): 141583d492cSJean Perier! CHECK: %[[VAL_42:.*]] = arith.constant 1 : index 142583d492cSJean Perier! CHECK: %[[VAL_43:.*]] = arith.subi %[[VAL_40]], %[[VAL_42]] : index 143583d492cSJean Perier! CHECK: %[[VAL_44:.*]] = arith.muli %[[VAL_43]], %[[VAL_23]] : index 144583d492cSJean Perier! CHECK: %[[VAL_45:.*]] = arith.addi %[[VAL_20]], %[[VAL_44]] : index 145583d492cSJean Perier! CHECK: %[[VAL_46:.*]] = hlfir.designate %[[VAL_13]]#0 (%[[VAL_41]]) : (!fir.box<!fir.array<?xi64>>, index) -> !fir.ref<i64> 146583d492cSJean Perier! CHECK: %[[VAL_47:.*]] = fir.load %[[VAL_46]] : !fir.ref<i64> 147*c4204c0bSjeanPerier! CHECK: %[[VAL_48:.*]] = hlfir.designate %[[VAL_15]]{"at0"} <%[[VAL_19]]> (%[[VAL_45]], %[[VAL_30]], %[[VAL_47]]) : (!fir.ref<!fir.type<_QFfoo4Tt1{at0:!fir.array<30x40x50x!fir.type<_QFfoo4Tt0{x:!fir.array<10x20xcomplex<f32>>}>>}>>, !fir.shape<3>, index, i64, i64) -> !fir.ref<!fir.type<_QFfoo4Tt0{x:!fir.array<10x20xcomplex<f32>>}>> 148*c4204c0bSjeanPerier! CHECK: %[[VAL_49:.*]] = hlfir.designate %[[VAL_48]]{"x"} <%[[VAL_36]]> (%[[VAL_37]], %[[VAL_38]]) imag : (!fir.ref<!fir.type<_QFfoo4Tt0{x:!fir.array<10x20xcomplex<f32>>}>>, !fir.shape<2>, i64, i64) -> !fir.ref<f32> 149583d492cSJean Perier! CHECK: %[[VAL_50:.*]] = fir.load %[[VAL_49]] : !fir.ref<f32> 150583d492cSJean Perier! CHECK: hlfir.yield_element %[[VAL_50]] : f32 151583d492cSJean Perier! CHECK: } 152583d492cSJean Perier 153583d492cSJean Periersubroutine substring(c, vector, i, j) 154583d492cSJean Perier character(*) :: c(:) 155583d492cSJean Perier integer(8) :: vector(:), step, i, j 156583d492cSJean Perier call bar4(c(vector)(i:j)) 157583d492cSJean Perierend subroutine 158583d492cSJean Perier! CHECK-LABEL: func.func @_QPsubstring( 159583d492cSJean Perier! CHECK: %[[VAL_4:.*]]:2 = hlfir.declare %[[VAL_0:[a-z0-9]*]] {{.*}}Ec 160583d492cSJean Perier! CHECK: %[[VAL_5:.*]]:2 = hlfir.declare %[[VAL_2:[a-z0-9]*]] {{.*}}Ei 161583d492cSJean Perier! CHECK: %[[VAL_6:.*]]:2 = hlfir.declare %[[VAL_3:[a-z0-9]*]] {{.*}}Ej 162583d492cSJean Perier! CHECK: %[[VAL_7:.*]] = fir.alloca i64 {bindc_name = "step", uniq_name = "_QFsubstringEstep"} 163583d492cSJean Perier! CHECK: %[[VAL_8:.*]]:2 = hlfir.declare %[[VAL_7:[a-z0-9]*]] {{.*}}Estep 164583d492cSJean Perier! CHECK: %[[VAL_9:.*]]:2 = hlfir.declare %[[VAL_1:[a-z0-9]*]] {{.*}}Evector 165583d492cSJean Perier! CHECK: %[[VAL_10:.*]] = arith.constant 0 : index 166583d492cSJean Perier! CHECK: %[[VAL_11:.*]]:3 = fir.box_dims %[[VAL_9]]#0, %[[VAL_10]] : (!fir.box<!fir.array<?xi64>>, index) -> (index, index, index) 167583d492cSJean Perier! CHECK: %[[VAL_12:.*]] = fir.shape %[[VAL_11]]#1 : (index) -> !fir.shape<1> 168583d492cSJean Perier! CHECK: %[[VAL_13:.*]] = fir.load %[[VAL_5]]#0 : !fir.ref<i64> 169583d492cSJean Perier! CHECK: %[[VAL_14:.*]] = fir.load %[[VAL_6]]#0 : !fir.ref<i64> 170583d492cSJean Perier! CHECK: %[[VAL_15:.*]] = fir.convert %[[VAL_13]] : (i64) -> index 171583d492cSJean Perier! CHECK: %[[VAL_16:.*]] = fir.convert %[[VAL_14]] : (i64) -> index 172583d492cSJean Perier! CHECK: %[[VAL_17:.*]] = arith.constant 1 : index 173583d492cSJean Perier! CHECK: %[[VAL_18:.*]] = arith.subi %[[VAL_16]], %[[VAL_15]] : index 174583d492cSJean Perier! CHECK: %[[VAL_19:.*]] = arith.addi %[[VAL_18]], %[[VAL_17]] : index 175583d492cSJean Perier! CHECK: %[[VAL_20:.*]] = arith.constant 0 : index 176583d492cSJean Perier! CHECK: %[[VAL_21:.*]] = arith.cmpi sgt, %[[VAL_19]], %[[VAL_20]] : index 177583d492cSJean Perier! CHECK: %[[VAL_22:.*]] = arith.select %[[VAL_21]], %[[VAL_19]], %[[VAL_20]] : index 1787b4aa95dSSlava Zakharin! CHECK: %[[VAL_23:.*]] = hlfir.elemental %[[VAL_12]] typeparams %[[VAL_22]] unordered : (!fir.shape<1>, index) -> !hlfir.expr<?x!fir.char<1,?>> { 179583d492cSJean Perier! CHECK: ^bb0(%[[VAL_24:.*]]: index): 180583d492cSJean Perier! CHECK: %[[VAL_25:.*]] = hlfir.designate %[[VAL_9]]#0 (%[[VAL_24]]) : (!fir.box<!fir.array<?xi64>>, index) -> !fir.ref<i64> 181583d492cSJean Perier! CHECK: %[[VAL_26:.*]] = fir.load %[[VAL_25]] : !fir.ref<i64> 182583d492cSJean Perier! CHECK: %[[VAL_27:.*]] = hlfir.designate %[[VAL_4]]#0 (%[[VAL_26]]) substr %[[VAL_15]], %[[VAL_16]] typeparams %[[VAL_22]] : (!fir.box<!fir.array<?x!fir.char<1,?>>>, i64, index, index, index) -> !fir.boxchar<1> 183583d492cSJean Perier! CHECK: hlfir.yield_element %[[VAL_27]] : !fir.boxchar<1> 184583d492cSJean Perier! CHECK: } 185939f0382SjeanPerier 186939f0382SjeanPeriersubroutine test_passing_subscripted_poly(x, vector) 187939f0382SjeanPerier interface 188939f0382SjeanPerier subroutine do_something(x) 189939f0382SjeanPerier class(*) :: x(:) 190939f0382SjeanPerier end subroutine 191939f0382SjeanPerier end interface 192939f0382SjeanPerier class(*) :: x(:, :) 193939f0382SjeanPerier integer(8) :: vector(:) 194939f0382SjeanPerier call do_something(x(314, vector)) 195939f0382SjeanPerierend subroutine 196939f0382SjeanPerier! CHECK-LABEL: func.func @_QPtest_passing_subscripted_poly( 197939f0382SjeanPerier! CHECK-SAME: %[[VAL_0:.*]]: !fir.class<!fir.array<?x?xnone>> 198939f0382SjeanPerier! CHECK-SAME: %[[VAL_1:.*]]: !fir.box<!fir.array<?xi64>> 1991710c8cfSSlava Zakharin! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[VAL_1]] dummy_scope %{{[0-9]+}} {uniq_name = "_QFtest_passing_subscripted_polyEvector"} : (!fir.box<!fir.array<?xi64>>, !fir.dscope) -> (!fir.box<!fir.array<?xi64>>, !fir.box<!fir.array<?xi64>>) 2001710c8cfSSlava Zakharin! CHECK: %[[VAL_3:.*]]:2 = hlfir.declare %[[VAL_0]] dummy_scope %{{[0-9]+}} {uniq_name = "_QFtest_passing_subscripted_polyEx"} : (!fir.class<!fir.array<?x?xnone>>, !fir.dscope) -> (!fir.class<!fir.array<?x?xnone>>, !fir.class<!fir.array<?x?xnone>>) 201939f0382SjeanPerier! CHECK: %[[VAL_4:.*]] = arith.constant 314 : index 202939f0382SjeanPerier! CHECK: %[[VAL_5:.*]] = arith.constant 0 : index 203939f0382SjeanPerier! CHECK: %[[VAL_6:.*]]:3 = fir.box_dims %[[VAL_2]]#0, %[[VAL_5]] : (!fir.box<!fir.array<?xi64>>, index) -> (index, index, index) 204939f0382SjeanPerier! CHECK: %[[VAL_7:.*]] = fir.shape %[[VAL_6]]#1 : (index) -> !fir.shape<1> 205939f0382SjeanPerier! CHECK: %[[VAL_8:.*]] = hlfir.elemental %[[VAL_7]] mold %[[VAL_3]]#0 unordered : (!fir.shape<1>, !fir.class<!fir.array<?x?xnone>>) -> !hlfir.expr<?xnone?> { 206939f0382SjeanPerier! CHECK: ^bb0(%[[VAL_9:.*]]: index): 207939f0382SjeanPerier! CHECK: %[[VAL_10:.*]] = hlfir.designate %[[VAL_2]]#0 (%[[VAL_9]]) : (!fir.box<!fir.array<?xi64>>, index) -> !fir.ref<i64> 208939f0382SjeanPerier! CHECK: %[[VAL_11:.*]] = fir.load %[[VAL_10]] : !fir.ref<i64> 209939f0382SjeanPerier! CHECK: %[[VAL_12:.*]] = hlfir.designate %[[VAL_3]]#0 (%[[VAL_4]], %[[VAL_11]]) : (!fir.class<!fir.array<?x?xnone>>, index, i64) -> !fir.class<none> 210939f0382SjeanPerier! CHECK: hlfir.yield_element %[[VAL_12]] : !fir.class<none> 211939f0382SjeanPerier! CHECK: } 212939f0382SjeanPerier! CHECK: %[[VAL_13:.*]]:3 = hlfir.associate %[[VAL_8]](%[[VAL_7]]) {adapt.valuebyref} : (!hlfir.expr<?xnone?>, !fir.shape<1>) -> (!fir.class<!fir.heap<!fir.array<?xnone>>>, !fir.class<!fir.heap<!fir.array<?xnone>>>, i1) 213939f0382SjeanPerier! CHECK: %[[VAL_14:.*]] = fir.rebox %[[VAL_13]]#0 : (!fir.class<!fir.heap<!fir.array<?xnone>>>) -> !fir.class<!fir.array<?xnone>> 214939f0382SjeanPerier! CHECK: fir.call @_QPdo_something(%[[VAL_14]]) fastmath<contract> : (!fir.class<!fir.array<?xnone>>) -> () 215939f0382SjeanPerier! CHECK: hlfir.end_associate %[[VAL_13]]#0, %[[VAL_13]]#2 : !fir.class<!fir.heap<!fir.array<?xnone>>>, i1 216939f0382SjeanPerier! CHECK: hlfir.destroy %[[VAL_8]] : !hlfir.expr<?xnone?> 217939f0382SjeanPerier! CHECK: return 218939f0382SjeanPerier! CHECK: } 219