1f3c3f636SJean Perier// Test code generation of hlfir.forall and hlfir.where when temporary 2f3c3f636SJean Perier// storage is needed and requires a runtime managed stack. 3f3c3f636SJean Perier// RUN: fir-opt %s --lower-hlfir-ordered-assignments | FileCheck %s 4f3c3f636SJean Perier 5f3c3f636SJean Perierfunc.func @test_runtime_stack(%arg0: !fir.box<!fir.array<?xi32>>, %n: !fir.ref<i32>) { 6f3c3f636SJean Perier %c1 = arith.constant 1 : index 7f3c3f636SJean Perier %c0 = arith.constant 0 : index 8f3c3f636SJean Perier %c-1 = arith.constant -1 : index 9f3c3f636SJean Perier %c99_i32 = arith.constant 99 : i32 10f3c3f636SJean Perier %c100_i32 = arith.constant 100 : i32 11f3c3f636SJean Perier %c1_i32 = arith.constant 1 : i32 12f3c3f636SJean Perier %1:2 = hlfir.declare %n {uniq_name = "n"} : (!fir.ref<i32>) -> (!fir.ref<i32>, !fir.ref<i32>) 13f3c3f636SJean Perier %2:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.box<!fir.array<?xi32>>) -> (!fir.box<!fir.array<?xi32>>, !fir.box<!fir.array<?xi32>>) 14f3c3f636SJean Perier %3 = fir.load %1#1 : !fir.ref<i32> 15f3c3f636SJean Perier hlfir.forall lb { 16f3c3f636SJean Perier hlfir.yield %c1_i32 : i32 17f3c3f636SJean Perier } ub { 18f3c3f636SJean Perier hlfir.yield %c100_i32 : i32 19f3c3f636SJean Perier } step { 20f3c3f636SJean Perier hlfir.yield %3 : i32 21f3c3f636SJean Perier } (%arg1: i32) { 22f3c3f636SJean Perier hlfir.region_assign { 23f3c3f636SJean Perier %4 = arith.subi %c100_i32, %arg1 : i32 24f3c3f636SJean Perier %5 = arith.subi %c99_i32, %arg1 : i32 25f3c3f636SJean Perier %6 = fir.load %1#0 : !fir.ref<i32> 26f3c3f636SJean Perier %7 = arith.subi %5, %6 : i32 27f3c3f636SJean Perier %8 = fir.convert %4 : (i32) -> index 28f3c3f636SJean Perier %9 = fir.convert %7 : (i32) -> index 29f3c3f636SJean Perier %10 = arith.subi %9, %8 : index 30f3c3f636SJean Perier %11 = arith.addi %10, %c-1 : index 31f3c3f636SJean Perier %12 = arith.divsi %11, %c-1 : index 32f3c3f636SJean Perier %13 = arith.cmpi sgt, %12, %c0 : index 33f3c3f636SJean Perier %14 = arith.select %13, %12, %c0 : index 34f3c3f636SJean Perier %15 = fir.shape %14 : (index) -> !fir.shape<1> 35f3c3f636SJean Perier %16 = hlfir.designate %2#0 (%8:%9:%c-1) shape %15 : (!fir.box<!fir.array<?xi32>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xi32>> 36f3c3f636SJean Perier hlfir.yield %16 : !fir.box<!fir.array<?xi32>> 37f3c3f636SJean Perier } to { 38f3c3f636SJean Perier %4 = fir.load %1#0 : !fir.ref<i32> 39f3c3f636SJean Perier %5 = arith.addi %arg1, %4 : i32 40f3c3f636SJean Perier %6 = arith.subi %5, %c1_i32 : i32 41f3c3f636SJean Perier %7 = fir.convert %arg1 : (i32) -> index 42f3c3f636SJean Perier %8 = fir.convert %6 : (i32) -> index 43f3c3f636SJean Perier %9 = arith.subi %8, %7 : index 44f3c3f636SJean Perier %10 = arith.addi %9, %c1 : index 45f3c3f636SJean Perier %11 = arith.cmpi sgt, %10, %c0 : index 46f3c3f636SJean Perier %12 = arith.select %11, %10, %c0 : index 47f3c3f636SJean Perier %13 = fir.shape %12 : (index) -> !fir.shape<1> 48f3c3f636SJean Perier %14 = hlfir.designate %2#0 (%7:%8:%c1) shape %13 : (!fir.box<!fir.array<?xi32>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xi32>> 49f3c3f636SJean Perier hlfir.yield %14 : !fir.box<!fir.array<?xi32>> 50f3c3f636SJean Perier } 51f3c3f636SJean Perier } 52f3c3f636SJean Perier return 53f3c3f636SJean Perier} 54f3c3f636SJean Perier 55f3c3f636SJean Perier// CHECK-LABEL: func.func @test_runtime_stack( 56f3c3f636SJean Perier// CHECK-SAME: %[[VAL_0:.*]]: !fir.box<!fir.array<?xi32>>, 57f3c3f636SJean Perier// CHECK-SAME: %[[VAL_1:.*]]: !fir.ref<i32>) { 58f3c3f636SJean Perier// CHECK: %[[VAL_2:.*]] = fir.alloca !fir.box<!fir.heap<!fir.array<?xi32>>> 59f3c3f636SJean Perier// CHECK: %[[VAL_3:.*]] = fir.alloca i64 60f3c3f636SJean Perier// CHECK: %[[VAL_4:.*]] = arith.constant 1 : index 61f3c3f636SJean Perier// CHECK: %[[VAL_5:.*]] = arith.constant 0 : index 62f3c3f636SJean Perier// CHECK: %[[VAL_6:.*]] = arith.constant -1 : index 63f3c3f636SJean Perier// CHECK: %[[VAL_7:.*]] = arith.constant 99 : i32 64f3c3f636SJean Perier// CHECK: %[[VAL_8:.*]] = arith.constant 100 : i32 65f3c3f636SJean Perier// CHECK: %[[VAL_9:.*]] = arith.constant 1 : i32 66f3c3f636SJean Perier// CHECK: %[[VAL_10:.*]]:2 = hlfir.declare %[[VAL_1]] {uniq_name = "n"} : (!fir.ref<i32>) -> (!fir.ref<i32>, !fir.ref<i32>) 67f3c3f636SJean Perier// CHECK: %[[VAL_11:.*]]:2 = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.box<!fir.array<?xi32>>) -> (!fir.box<!fir.array<?xi32>>, !fir.box<!fir.array<?xi32>>) 68f3c3f636SJean Perier// CHECK: %[[VAL_12:.*]] = fir.load %[[VAL_10]]#1 : !fir.ref<i32> 69f3c3f636SJean Perier// CHECK: %[[VAL_13:.*]] = fir.convert %[[VAL_9]] : (i32) -> index 70f3c3f636SJean Perier// CHECK: %[[VAL_14:.*]] = fir.convert %[[VAL_8]] : (i32) -> index 71f3c3f636SJean Perier// CHECK: %[[VAL_15:.*]] = fir.convert %[[VAL_12]] : (i32) -> index 72f3c3f636SJean Perier// CHECK: %[[VAL_16:.*]] = arith.constant 0 : i64 73f3c3f636SJean Perier// CHECK: %[[VAL_17:.*]] = arith.constant 1 : i64 74f3c3f636SJean Perier// CHECK: fir.store %[[VAL_16]] to %[[VAL_3]] : !fir.ref<i64> 75f3c3f636SJean Perier// CHECK: %[[VAL_22:.*]] = fir.call @_FortranACreateValueStack(%{{.*}}, %{{.*}}) : (!fir.ref<i8>, i32) -> !fir.llvm_ptr<i8> 76f3c3f636SJean Perier// CHECK: fir.do_loop %[[VAL_23:.*]] = %[[VAL_13]] to %[[VAL_14]] step %[[VAL_15]] { 77f3c3f636SJean Perier// CHECK: %[[VAL_24:.*]] = fir.convert %[[VAL_23]] : (index) -> i32 78f3c3f636SJean Perier// CHECK: %[[VAL_25:.*]] = arith.subi %[[VAL_8]], %[[VAL_24]] : i32 79f3c3f636SJean Perier// CHECK: %[[VAL_26:.*]] = arith.subi %[[VAL_7]], %[[VAL_24]] : i32 80f3c3f636SJean Perier// CHECK: %[[VAL_27:.*]] = fir.load %[[VAL_10]]#0 : !fir.ref<i32> 81f3c3f636SJean Perier// CHECK: %[[VAL_28:.*]] = arith.subi %[[VAL_26]], %[[VAL_27]] : i32 82f3c3f636SJean Perier// CHECK: %[[VAL_29:.*]] = fir.convert %[[VAL_25]] : (i32) -> index 83f3c3f636SJean Perier// CHECK: %[[VAL_30:.*]] = fir.convert %[[VAL_28]] : (i32) -> index 84f3c3f636SJean Perier// CHECK: %[[VAL_31:.*]] = arith.subi %[[VAL_30]], %[[VAL_29]] : index 85f3c3f636SJean Perier// CHECK: %[[VAL_32:.*]] = arith.addi %[[VAL_31]], %[[VAL_6]] : index 86f3c3f636SJean Perier// CHECK: %[[VAL_33:.*]] = arith.divsi %[[VAL_32]], %[[VAL_6]] : index 87f3c3f636SJean Perier// CHECK: %[[VAL_34:.*]] = arith.cmpi sgt, %[[VAL_33]], %[[VAL_5]] : index 88f3c3f636SJean Perier// CHECK: %[[VAL_35:.*]] = arith.select %[[VAL_34]], %[[VAL_33]], %[[VAL_5]] : index 89f3c3f636SJean Perier// CHECK: %[[VAL_36:.*]] = fir.shape %[[VAL_35]] : (index) -> !fir.shape<1> 90f3c3f636SJean Perier// CHECK: %[[VAL_37:.*]] = hlfir.designate %[[VAL_11]]#0 (%[[VAL_29]]:%[[VAL_30]]:%[[VAL_6]]) shape %[[VAL_36]] : (!fir.box<!fir.array<?xi32>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xi32>> 91f3c3f636SJean Perier// CHECK: %[[VAL_38:.*]] = fir.convert %[[VAL_37]] : (!fir.box<!fir.array<?xi32>>) -> !fir.box<none> 92*12ba74e1SValentin Clement (バレンタイン クレメン)// CHECK: fir.call @_FortranAPushValue(%[[VAL_22]], %[[VAL_38]]) : (!fir.llvm_ptr<i8>, !fir.box<none>) -> () 93f3c3f636SJean Perier// CHECK: } 94f3c3f636SJean Perier// CHECK: %[[VAL_40:.*]] = fir.convert %[[VAL_9]] : (i32) -> index 95f3c3f636SJean Perier// CHECK: %[[VAL_41:.*]] = fir.convert %[[VAL_8]] : (i32) -> index 96f3c3f636SJean Perier// CHECK: %[[VAL_42:.*]] = fir.convert %[[VAL_12]] : (i32) -> index 97f3c3f636SJean Perier// CHECK: fir.store %[[VAL_16]] to %[[VAL_3]] : !fir.ref<i64> 98f3c3f636SJean Perier// CHECK: fir.do_loop %[[VAL_43:.*]] = %[[VAL_40]] to %[[VAL_41]] step %[[VAL_42]] { 99f3c3f636SJean Perier// CHECK: %[[VAL_44:.*]] = fir.convert %[[VAL_43]] : (index) -> i32 100f3c3f636SJean Perier// CHECK: %[[VAL_45:.*]] = fir.load %[[VAL_3]] : !fir.ref<i64> 101f3c3f636SJean Perier// CHECK: %[[VAL_46:.*]] = arith.addi %[[VAL_45]], %[[VAL_17]] : i64 102f3c3f636SJean Perier// CHECK: fir.store %[[VAL_46]] to %[[VAL_3]] : !fir.ref<i64> 103f3c3f636SJean Perier// CHECK: %[[VAL_47:.*]] = fir.convert %[[VAL_2]] : (!fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>) -> !fir.ref<!fir.box<none>> 104*12ba74e1SValentin Clement (バレンタイン クレメン)// CHECK: fir.call @_FortranAValueAt(%[[VAL_22]], %[[VAL_45]], %[[VAL_47]]) : (!fir.llvm_ptr<i8>, i64, !fir.ref<!fir.box<none>>) -> () 105f3c3f636SJean Perier// CHECK: %[[VAL_49:.*]] = fir.load %[[VAL_2]] : !fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>> 106f3c3f636SJean Perier// CHECK: %[[VAL_50:.*]] = fir.load %[[VAL_10]]#0 : !fir.ref<i32> 107f3c3f636SJean Perier// CHECK: %[[VAL_51:.*]] = arith.addi %[[VAL_44]], %[[VAL_50]] : i32 108f3c3f636SJean Perier// CHECK: %[[VAL_52:.*]] = arith.subi %[[VAL_51]], %[[VAL_9]] : i32 109f3c3f636SJean Perier// CHECK: %[[VAL_53:.*]] = fir.convert %[[VAL_44]] : (i32) -> index 110f3c3f636SJean Perier// CHECK: %[[VAL_54:.*]] = fir.convert %[[VAL_52]] : (i32) -> index 111f3c3f636SJean Perier// CHECK: %[[VAL_55:.*]] = arith.subi %[[VAL_54]], %[[VAL_53]] : index 112f3c3f636SJean Perier// CHECK: %[[VAL_56:.*]] = arith.addi %[[VAL_55]], %[[VAL_4]] : index 113f3c3f636SJean Perier// CHECK: %[[VAL_57:.*]] = arith.cmpi sgt, %[[VAL_56]], %[[VAL_5]] : index 114f3c3f636SJean Perier// CHECK: %[[VAL_58:.*]] = arith.select %[[VAL_57]], %[[VAL_56]], %[[VAL_5]] : index 115f3c3f636SJean Perier// CHECK: %[[VAL_59:.*]] = fir.shape %[[VAL_58]] : (index) -> !fir.shape<1> 116f3c3f636SJean Perier// CHECK: %[[VAL_60:.*]] = hlfir.designate %[[VAL_11]]#0 (%[[VAL_53]]:%[[VAL_54]]:%[[VAL_4]]) shape %[[VAL_59]] : (!fir.box<!fir.array<?xi32>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xi32>> 117f3c3f636SJean Perier// CHECK: hlfir.assign %[[VAL_49]] to %[[VAL_60]] : !fir.box<!fir.heap<!fir.array<?xi32>>>, !fir.box<!fir.array<?xi32>> 118f3c3f636SJean Perier// CHECK: } 119*12ba74e1SValentin Clement (バレンタイン クレメン)// CHECK: fir.call @_FortranADestroyValueStack(%[[VAL_22]]) : (!fir.llvm_ptr<i8>) -> () 120f3c3f636SJean Perier// CHECK: return 121f3c3f636SJean Perier// CHECK: } 122f3c3f636SJean Perier 123f3c3f636SJean Perier 124f3c3f636SJean Perier// i1 needs to be passed as logical<> to be stored. Check converts are 125f3c3f636SJean Perier// introduced as expected. 126f3c3f636SJean Perierfunc.func @_QPdealing_with_i1(%x: !fir.ref<!fir.array<10x20xi32>>) { 127f3c3f636SJean Perier %c42_i32 = arith.constant 42 : i32 128f3c3f636SJean Perier %c10_i64 = arith.constant 10 : i64 129f3c3f636SJean Perier %c1_i64 = arith.constant 1 : i64 130f3c3f636SJean Perier hlfir.forall lb { 131f3c3f636SJean Perier hlfir.yield %c1_i64 : i64 132f3c3f636SJean Perier } ub { 133f3c3f636SJean Perier hlfir.yield %c10_i64 : i64 134f3c3f636SJean Perier } (%arg1: i64) { 135f3c3f636SJean Perier hlfir.forall lb { 136f3c3f636SJean Perier hlfir.yield %c1_i64 : i64 137f3c3f636SJean Perier } ub { 138f3c3f636SJean Perier hlfir.yield %arg1 : i64 139f3c3f636SJean Perier } (%arg2: i64) { 140f3c3f636SJean Perier hlfir.forall_mask { 141f3c3f636SJean Perier %1 = hlfir.designate %x (%arg2, %arg1) : (!fir.ref<!fir.array<10x20xi32>>, i64, i64) -> !fir.ref<i32> 142f3c3f636SJean Perier %2 = fir.load %1 : !fir.ref<i32> 143f3c3f636SJean Perier %3 = arith.cmpi sgt, %2, %c42_i32 : i32 144f3c3f636SJean Perier hlfir.yield %3 : i1 145f3c3f636SJean Perier } do { 146f3c3f636SJean Perier hlfir.region_assign { 147f3c3f636SJean Perier hlfir.yield %c42_i32 : i32 148f3c3f636SJean Perier } to { 149f3c3f636SJean Perier %1 = hlfir.designate %x (%arg1, %arg2) : (!fir.ref<!fir.array<10x20xi32>>, i64, i64) -> !fir.ref<i32> 150f3c3f636SJean Perier hlfir.yield %1 : !fir.ref<i32> 151f3c3f636SJean Perier } 152f3c3f636SJean Perier } 153f3c3f636SJean Perier } 154f3c3f636SJean Perier } 155f3c3f636SJean Perier return 156f3c3f636SJean Perier} 157f3c3f636SJean Perier// CHECK-LABEL: func.func @_QPdealing_with_i1( 158f3c3f636SJean Perier// CHECK: %[[VAL_1:.*]] = fir.alloca !fir.logical<1> 159f3c3f636SJean Perier// CHECK: %[[VAL_2:.*]] = fir.alloca !fir.box<!fir.heap<!fir.logical<1>>> 160f3c3f636SJean Perier// CHECK: fir.do_loop 161f3c3f636SJean Perier// CHECK: fir.do_loop 162f3c3f636SJean Perier// CHECK: %[[VAL_26:.*]] = arith.cmpi sgt 163f3c3f636SJean Perier// CHECK: %[[VAL_27:.*]] = fir.convert %[[VAL_26]] : (i1) -> !fir.logical<1> 164f3c3f636SJean Perier// CHECK: fir.store %[[VAL_27]] to %[[VAL_1]] : !fir.ref<!fir.logical<1>> 165f3c3f636SJean Perier// CHECK: %[[VAL_28:.*]] = fir.embox %[[VAL_1]] : (!fir.ref<!fir.logical<1>>) -> !fir.box<!fir.logical<1>> 166f3c3f636SJean Perier// CHECK: %[[VAL_29:.*]] = fir.convert %[[VAL_28]] : (!fir.box<!fir.logical<1>>) -> !fir.box<none> 167*12ba74e1SValentin Clement (バレンタイン クレメン)// CHECK: fir.call @_FortranAPushValue(%{{.*}}, %[[VAL_29]]) : (!fir.llvm_ptr<i8>, !fir.box<none>) -> () 168f3c3f636SJean Perier// CHECK: } 169f3c3f636SJean Perier// CHECK: } 170f3c3f636SJean Perier// CHECK: fir.do_loop 171f3c3f636SJean Perier// CHECK: fir.do_loop 172f3c3f636SJean Perier// CHECK: %[[VAL_43:.*]] = fir.convert %[[VAL_2]] : (!fir.ref<!fir.box<!fir.heap<!fir.logical<1>>>>) -> !fir.ref<!fir.box<none>> 173*12ba74e1SValentin Clement (バレンタイン クレメン)// CHECK: fir.call @_FortranAValueAt(%{{.*}}, %{{.*}}, %[[VAL_43]]) 174f3c3f636SJean Perier// CHECK: %[[VAL_45:.*]] = fir.load %[[VAL_2]] : !fir.ref<!fir.box<!fir.heap<!fir.logical<1>>>> 175f3c3f636SJean Perier// CHECK: %[[VAL_46:.*]] = fir.box_addr %[[VAL_45]] : (!fir.box<!fir.heap<!fir.logical<1>>>) -> !fir.heap<!fir.logical<1>> 176f3c3f636SJean Perier// CHECK: %[[VAL_47:.*]] = fir.load %[[VAL_46]] : !fir.heap<!fir.logical<1>> 177f3c3f636SJean Perier// CHECK: %[[VAL_48:.*]] = fir.convert %[[VAL_47]] : (!fir.logical<1>) -> i1 178f3c3f636SJean Perier// CHECK: } 179f3c3f636SJean Perier// CHECK: } 180