|
| 1 | +// Test canonicalization of hlfir.exactly_once operations |
| 2 | +// after CSE. The live-in values that are not dominating |
| 3 | +// the top-level hlfir.where must be cloned inside hlfir.exactly_once, |
| 4 | +// otherwise, the cloning of the hlfir.exactly_once before hlfir.where |
| 5 | +// would cause def-use issues: |
| 6 | +// RUN: fir-opt %s --lower-hlfir-ordered-assignments | FileCheck %s |
| 7 | + |
| 8 | +// Simple case, where CSE makes only hlfir.designate live-in: |
| 9 | +// CHECK-LABEL: func.func @_QPtest1( |
| 10 | +func.func @_QPtest1(%arg0: !fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>> {fir.bindc_name = "x"}) { |
| 11 | + %true = arith.constant true |
| 12 | + %cst = arith.constant 0.000000e+00 : f32 |
| 13 | + %c1 = arith.constant 1 : index |
| 14 | + %c0 = arith.constant 0 : index |
| 15 | + %0 = fir.dummy_scope : !fir.dscope |
| 16 | + %1:2 = hlfir.declare %arg0 dummy_scope %0 {fortran_attrs = #fir.var_attrs<intent_inout>, uniq_name = "_QFtest1Ex"} : (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>, !fir.dscope) -> (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>, !fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>) |
| 17 | + hlfir.where { |
| 18 | + %2 = hlfir.designate %1#0{"p2"} {fortran_attrs = #fir.var_attrs<pointer>} : (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>) -> !fir.ref<!fir.box<!fir.ptr<!fir.array<?xf32>>>> |
| 19 | + %3 = fir.load %2 : !fir.ref<!fir.box<!fir.ptr<!fir.array<?xf32>>>> |
| 20 | + %4:3 = fir.box_dims %3, %c0 : (!fir.box<!fir.ptr<!fir.array<?xf32>>>, index) -> (index, index, index) |
| 21 | + %5 = arith.addi %4#0, %4#1 : index |
| 22 | + %6 = arith.subi %5, %c1 : index |
| 23 | + %7 = arith.subi %6, %4#0 : index |
| 24 | + %8 = arith.addi %7, %c1 : index |
| 25 | + %9 = arith.cmpi sgt, %8, %c0 : index |
| 26 | + %10 = arith.select %9, %8, %c0 : index |
| 27 | + %11 = fir.shape %10 : (index) -> !fir.shape<1> |
| 28 | + %12 = hlfir.designate %3 (%4#0:%6:%c1) shape %11 : (!fir.box<!fir.ptr<!fir.array<?xf32>>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 29 | + %13 = hlfir.elemental %11 unordered : (!fir.shape<1>) -> !hlfir.expr<?x!fir.logical<4>> { |
| 30 | + ^bb0(%arg1: index): |
| 31 | + %14 = hlfir.designate %12 (%arg1) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 32 | + %15 = fir.load %14 : !fir.ref<f32> |
| 33 | + %16 = arith.cmpf ogt, %15, %cst fastmath<contract> : f32 |
| 34 | + %17 = fir.convert %16 : (i1) -> !fir.logical<4> |
| 35 | + hlfir.yield_element %17 : !fir.logical<4> |
| 36 | + } |
| 37 | + hlfir.yield %13 : !hlfir.expr<?x!fir.logical<4>> cleanup { |
| 38 | + hlfir.destroy %13 : !hlfir.expr<?x!fir.logical<4>> |
| 39 | + } |
| 40 | + } do { |
| 41 | + hlfir.region_assign { |
| 42 | + %2 = hlfir.designate %1#0{"p1"} {fortran_attrs = #fir.var_attrs<pointer>} : (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>) -> !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?xf32>>>> |
| 43 | + %3 = fir.load %2 : !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?xf32>>>> |
| 44 | + %4:3 = fir.box_dims %3, %c0 : (!fir.box<!fir.ptr<!fir.array<?x?xf32>>>, index) -> (index, index, index) |
| 45 | + %5 = arith.addi %4#0, %4#1 : index |
| 46 | + %6 = arith.subi %5, %c1 : index |
| 47 | + %7 = arith.subi %6, %4#0 : index |
| 48 | + %8 = arith.addi %7, %c1 : index |
| 49 | + %9 = arith.cmpi sgt, %8, %c0 : index |
| 50 | + %10 = arith.select %9, %8, %c0 : index |
| 51 | + %11 = fir.shape %10 : (index) -> !fir.shape<1> |
| 52 | + %12 = hlfir.designate %3 (%4#0:%6:%c1, %c1) shape %11 : (!fir.box<!fir.ptr<!fir.array<?x?xf32>>>, index, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 53 | + %13 = hlfir.exactly_once : !hlfir.expr<?xf32> { |
| 54 | +// CHECK: %[[VAL_26:.*]] = hlfir.designate %{{.*}}#0{"p1"} {fortran_attrs = #fir.var_attrs<pointer>} : (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>) -> !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?xf32>>>> |
| 55 | +// CHECK: fir.load %[[VAL_26]] : !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?xf32>>>> |
| 56 | +// CHECK: %[[VAL_47:.*]] = fir.call @_QPcallee(%{{.*}}) fastmath<contract> : (!fir.box<!fir.array<?xf32>>) -> !fir.array<?xf32> |
| 57 | +// CHECK: fir.do_loop |
| 58 | + %15 = fir.load %2 : !fir.ref<!fir.box<!fir.ptr<!fir.array<?x?xf32>>>> |
| 59 | + %16:3 = fir.box_dims %15, %c0 : (!fir.box<!fir.ptr<!fir.array<?x?xf32>>>, index) -> (index, index, index) |
| 60 | + %17 = arith.addi %16#0, %16#1 : index |
| 61 | + %18 = arith.subi %17, %c1 : index |
| 62 | + %19 = arith.subi %18, %16#0 : index |
| 63 | + %20 = arith.addi %19, %c1 : index |
| 64 | + %21 = arith.cmpi sgt, %20, %c0 : index |
| 65 | + %22 = arith.select %21, %20, %c0 : index |
| 66 | + %23 = fir.shape %22 : (index) -> !fir.shape<1> |
| 67 | + %24 = hlfir.designate %15 (%16#0:%18:%c1, %c1) shape %23 : (!fir.box<!fir.ptr<!fir.array<?x?xf32>>>, index, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 68 | + %25:2 = hlfir.declare %24 {fortran_attrs = #fir.var_attrs<intent_in>, uniq_name = "_QMmy_moduleFcalleeEx"} : (!fir.box<!fir.array<?xf32>>) -> (!fir.box<!fir.array<?xf32>>, !fir.box<!fir.array<?xf32>>) |
| 69 | + %26:3 = fir.box_dims %25#0, %c0 : (!fir.box<!fir.array<?xf32>>, index) -> (index, index, index) |
| 70 | + %27 = fir.convert %26#1 : (index) -> i64 |
| 71 | + %28 = fir.convert %27 : (i64) -> index |
| 72 | + %29 = arith.cmpi sgt, %28, %c0 : index |
| 73 | + %30 = arith.select %29, %28, %c0 : index |
| 74 | + %31 = fir.shape %30 : (index) -> !fir.shape<1> |
| 75 | + %32 = fir.allocmem !fir.array<?xf32>, %30 {bindc_name = ".tmp.expr_result", uniq_name = ""} |
| 76 | + %33 = fir.convert %32 : (!fir.heap<!fir.array<?xf32>>) -> !fir.ref<!fir.array<?xf32>> |
| 77 | + %34:2 = hlfir.declare %33(%31) {uniq_name = ".tmp.expr_result"} : (!fir.ref<!fir.array<?xf32>>, !fir.shape<1>) -> (!fir.box<!fir.array<?xf32>>, !fir.ref<!fir.array<?xf32>>) |
| 78 | + %35 = fir.call @_QPcallee(%24) fastmath<contract> : (!fir.box<!fir.array<?xf32>>) -> !fir.array<?xf32> |
| 79 | + fir.save_result %35 to %34#1(%31) : !fir.array<?xf32>, !fir.ref<!fir.array<?xf32>>, !fir.shape<1> |
| 80 | + %36 = hlfir.as_expr %34#0 move %true : (!fir.box<!fir.array<?xf32>>, i1) -> !hlfir.expr<?xf32> |
| 81 | + hlfir.yield %36 : !hlfir.expr<?xf32> cleanup { |
| 82 | + hlfir.destroy %36 : !hlfir.expr<?xf32> |
| 83 | + } |
| 84 | + } |
| 85 | + %14 = hlfir.elemental %11 unordered : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| 86 | + ^bb0(%arg1: index): |
| 87 | + %15 = hlfir.designate %12 (%arg1) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 88 | + %16 = hlfir.apply %13, %arg1 : (!hlfir.expr<?xf32>, index) -> f32 |
| 89 | + %17 = fir.load %15 : !fir.ref<f32> |
| 90 | + %18 = arith.divf %17, %16 fastmath<contract> : f32 |
| 91 | + hlfir.yield_element %18 : f32 |
| 92 | + } |
| 93 | + hlfir.yield %14 : !hlfir.expr<?xf32> cleanup { |
| 94 | + hlfir.destroy %14 : !hlfir.expr<?xf32> |
| 95 | + } |
| 96 | + } to { |
| 97 | + %2 = hlfir.designate %1#0{"p2"} {fortran_attrs = #fir.var_attrs<pointer>} : (!fir.ref<!fir.type<_QMmy_moduleTtt{p1:!fir.box<!fir.ptr<!fir.array<?x?xf32>>>,p2:!fir.box<!fir.ptr<!fir.array<?xf32>>>}>>) -> !fir.ref<!fir.box<!fir.ptr<!fir.array<?xf32>>>> |
| 98 | + %3 = fir.load %2 : !fir.ref<!fir.box<!fir.ptr<!fir.array<?xf32>>>> |
| 99 | + %4:3 = fir.box_dims %3, %c0 : (!fir.box<!fir.ptr<!fir.array<?xf32>>>, index) -> (index, index, index) |
| 100 | + %5 = arith.addi %4#0, %4#1 : index |
| 101 | + %6 = arith.subi %5, %c1 : index |
| 102 | + %7 = arith.subi %6, %4#0 : index |
| 103 | + %8 = arith.addi %7, %c1 : index |
| 104 | + %9 = arith.cmpi sgt, %8, %c0 : index |
| 105 | + %10 = arith.select %9, %8, %c0 : index |
| 106 | + %11 = fir.shape %10 : (index) -> !fir.shape<1> |
| 107 | + %12 = hlfir.designate %3 (%4#0:%6:%c1) shape %11 : (!fir.box<!fir.ptr<!fir.array<?xf32>>>, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 108 | + hlfir.yield %12 : !fir.box<!fir.array<?xf32>> |
| 109 | + } |
| 110 | + } |
| 111 | + return |
| 112 | +} |
| 113 | + |
| 114 | +// CSE makes a chain of operations live-in: |
| 115 | +// CHECK-LABEL: func.func @_QPtest_where_in_forall( |
| 116 | +func.func @_QPtest_where_in_forall(%arg0: !fir.box<!fir.array<?x?xf32>> {fir.bindc_name = "a"}, %arg1: !fir.box<!fir.array<?x?xf32>> {fir.bindc_name = "b"}, %arg2: !fir.box<!fir.array<?x?xf32>> {fir.bindc_name = "c"}) { |
| 117 | + %false = arith.constant false |
| 118 | + %c1_i32 = arith.constant 1 : i32 |
| 119 | + %c10_i32 = arith.constant 10 : i32 |
| 120 | + %c0 = arith.constant 0 : index |
| 121 | + %c1 = arith.constant 1 : index |
| 122 | + %c2_i32 = arith.constant 2 : i32 |
| 123 | + %c100 = arith.constant 100 : index |
| 124 | + %0 = fir.alloca !fir.array<100x!fir.logical<4>> {bindc_name = ".tmp.expr_result"} |
| 125 | + %1 = fir.alloca !fir.array<100x!fir.logical<4>> {bindc_name = ".tmp.expr_result"} |
| 126 | + %2 = fir.dummy_scope : !fir.dscope |
| 127 | +// CHECK: %[[VAL_21:.*]]:2 = hlfir.declare %{{.*}} dummy_scope %{{.*}} {uniq_name = "_QFtest_where_in_forallEb"} : (!fir.box<!fir.array<?x?xf32>>, !fir.dscope) -> (!fir.box<!fir.array<?x?xf32>>, !fir.box<!fir.array<?x?xf32>>) |
| 128 | + %3:2 = hlfir.declare %arg0 dummy_scope %2 {uniq_name = "_QFtest_where_in_forallEa"} : (!fir.box<!fir.array<?x?xf32>>, !fir.dscope) -> (!fir.box<!fir.array<?x?xf32>>, !fir.box<!fir.array<?x?xf32>>) |
| 129 | + %4:2 = hlfir.declare %arg1 dummy_scope %2 {uniq_name = "_QFtest_where_in_forallEb"} : (!fir.box<!fir.array<?x?xf32>>, !fir.dscope) -> (!fir.box<!fir.array<?x?xf32>>, !fir.box<!fir.array<?x?xf32>>) |
| 130 | + %5:2 = hlfir.declare %arg2 dummy_scope %2 {uniq_name = "_QFtest_where_in_forallEc"} : (!fir.box<!fir.array<?x?xf32>>, !fir.dscope) -> (!fir.box<!fir.array<?x?xf32>>, !fir.box<!fir.array<?x?xf32>>) |
| 131 | + hlfir.forall lb { |
| 132 | + hlfir.yield %c1_i32 : i32 |
| 133 | + } ub { |
| 134 | + hlfir.yield %c10_i32 : i32 |
| 135 | + } (%arg3: i32) { |
| 136 | + hlfir.where { |
| 137 | + %6 = fir.shape %c100 : (index) -> !fir.shape<1> |
| 138 | + %7:2 = hlfir.declare %0(%6) {uniq_name = ".tmp.expr_result"} : (!fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.shape<1>) -> (!fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.ref<!fir.array<100x!fir.logical<4>>>) |
| 139 | + %8 = fir.call @_QPpure_logical_func1() proc_attrs<pure> fastmath<contract> : () -> !fir.array<100x!fir.logical<4>> |
| 140 | + fir.save_result %8 to %7#1(%6) : !fir.array<100x!fir.logical<4>>, !fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.shape<1> |
| 141 | + %9 = hlfir.as_expr %7#0 move %false : (!fir.ref<!fir.array<100x!fir.logical<4>>>, i1) -> !hlfir.expr<100x!fir.logical<4>> |
| 142 | + hlfir.yield %9 : !hlfir.expr<100x!fir.logical<4>> cleanup { |
| 143 | + hlfir.destroy %9 : !hlfir.expr<100x!fir.logical<4>> |
| 144 | + } |
| 145 | + } do { |
| 146 | + hlfir.region_assign { |
| 147 | + %6 = fir.convert %arg3 : (i32) -> i64 |
| 148 | +// CHECK: %[[VAL_58:.*]]:3 = fir.box_dims %[[VAL_21]]#1, %{{.*}} : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 149 | +// CHECK: %[[VAL_59:.*]] = arith.cmpi sgt, %[[VAL_58]]#1, %{{.*}} : index |
| 150 | +// CHECK: %[[VAL_60:.*]] = arith.select %[[VAL_59]], %[[VAL_58]]#1, %{{.*}} : index |
| 151 | +// CHECK: %[[VAL_61:.*]] = fir.shape %[[VAL_60]] : (index) -> !fir.shape<1> |
| 152 | +// CHECK: %[[VAL_62:.*]] = hlfir.designate %[[VAL_21]]#0 (%{{.*}}, %{{.*}}:%[[VAL_58]]#1:%{{.*}}) shape %[[VAL_61]] : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 153 | + %7:3 = fir.box_dims %4#1, %c1 : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 154 | + %8 = arith.cmpi sgt, %7#1, %c0 : index |
| 155 | + %9 = arith.select %8, %7#1, %c0 : index |
| 156 | + %10 = fir.shape %9 : (index) -> !fir.shape<1> |
| 157 | + %11 = hlfir.designate %4#0 (%6, %c1:%7#1:%c1) shape %10 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 158 | + %12 = hlfir.exactly_once : f32 { |
| 159 | + %19:3 = fir.box_dims %3#1, %c1 : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 160 | + %20 = arith.cmpi sgt, %19#1, %c0 : index |
| 161 | + %21 = arith.select %20, %19#1, %c0 : index |
| 162 | + %22 = fir.shape %21 : (index) -> !fir.shape<1> |
| 163 | + %23 = hlfir.designate %3#0 (%6, %c1:%19#1:%c1) shape %22 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 164 | +// CHECK: %[[VAL_68:.*]] = fir.call @_QPpure_real_func2() fastmath<contract> : () -> f32 |
| 165 | +// CHECK: %[[VAL_69:.*]] = hlfir.elemental %{{.*}} unordered : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| 166 | +// CHECK: ^bb0(%[[VAL_70:.*]]: index): |
| 167 | +// CHECK: %[[VAL_72:.*]] = hlfir.designate %[[VAL_62]] (%[[VAL_70]]) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 168 | + %24 = fir.call @_QPpure_real_func2() fastmath<contract> : () -> f32 |
| 169 | + %25 = hlfir.elemental %22 unordered : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| 170 | + ^bb0(%arg4: index): |
| 171 | + %28 = hlfir.designate %23 (%arg4) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 172 | + %29 = hlfir.designate %11 (%arg4) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 173 | + %30 = fir.load %28 : !fir.ref<f32> |
| 174 | + %31 = fir.load %29 : !fir.ref<f32> |
| 175 | + %32 = arith.addf %30, %31 fastmath<contract> : f32 |
| 176 | + %33 = arith.addf %32, %24 fastmath<contract> : f32 |
| 177 | + hlfir.yield_element %33 : f32 |
| 178 | + } |
| 179 | + %26:3 = hlfir.associate %25(%22) {adapt.valuebyref} : (!hlfir.expr<?xf32>, !fir.shape<1>) -> (!fir.box<!fir.array<?xf32>>, !fir.ref<!fir.array<?xf32>>, i1) |
| 180 | + %27 = fir.call @_QPpure_real_func(%26#1) fastmath<contract> : (!fir.ref<!fir.array<?xf32>>) -> f32 |
| 181 | + hlfir.yield %27 : f32 cleanup { |
| 182 | + hlfir.end_associate %26#1, %26#2 : !fir.ref<!fir.array<?xf32>>, i1 |
| 183 | + hlfir.destroy %25 : !hlfir.expr<?xf32> |
| 184 | + } |
| 185 | + } |
| 186 | + %13:3 = fir.box_dims %3#1, %c1 : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 187 | + %14 = arith.cmpi sgt, %13#1, %c0 : index |
| 188 | + %15 = arith.select %14, %13#1, %c0 : index |
| 189 | + %16 = fir.shape %15 : (index) -> !fir.shape<1> |
| 190 | + %17 = hlfir.designate %3#0 (%6, %c1:%13#1:%c1) shape %16 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 191 | + %18 = hlfir.elemental %10 unordered : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| 192 | + ^bb0(%arg4: index): |
| 193 | + %19 = hlfir.designate %11 (%arg4) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 194 | + %20 = fir.load %19 : !fir.ref<f32> |
| 195 | + %21 = arith.addf %20, %12 fastmath<contract> : f32 |
| 196 | + %22 = hlfir.designate %17 (%arg4) : (!fir.box<!fir.array<?xf32>>, index) -> !fir.ref<f32> |
| 197 | + %23 = fir.call @_QPpure_elem_func(%22) proc_attrs<elemental, pure> fastmath<contract> : (!fir.ref<f32>) -> f32 |
| 198 | + %24 = arith.addf %21, %23 fastmath<contract> : f32 |
| 199 | + hlfir.yield_element %24 : f32 |
| 200 | + } |
| 201 | + hlfir.yield %18 : !hlfir.expr<?xf32> cleanup { |
| 202 | + hlfir.destroy %18 : !hlfir.expr<?xf32> |
| 203 | + } |
| 204 | + } to { |
| 205 | + %6 = arith.muli %arg3, %c2_i32 overflow<nsw> : i32 |
| 206 | + %7 = fir.convert %6 : (i32) -> i64 |
| 207 | + %8:3 = fir.box_dims %3#1, %c1 : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 208 | + %9 = arith.cmpi sgt, %8#1, %c0 : index |
| 209 | + %10 = arith.select %9, %8#1, %c0 : index |
| 210 | + %11 = fir.shape %10 : (index) -> !fir.shape<1> |
| 211 | + %12 = hlfir.designate %3#0 (%7, %c1:%8#1:%c1) shape %11 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 212 | + hlfir.yield %12 : !fir.box<!fir.array<?xf32>> |
| 213 | + } |
| 214 | + hlfir.elsewhere mask { |
| 215 | + %6 = hlfir.exactly_once : !hlfir.expr<100x!fir.logical<4>> { |
| 216 | + %7 = fir.shape %c100 : (index) -> !fir.shape<1> |
| 217 | + %8:2 = hlfir.declare %1(%7) {uniq_name = ".tmp.expr_result"} : (!fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.shape<1>) -> (!fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.ref<!fir.array<100x!fir.logical<4>>>) |
| 218 | + %9 = fir.call @_QPpure_logical_func2() proc_attrs<pure> fastmath<contract> : () -> !fir.array<100x!fir.logical<4>> |
| 219 | + fir.save_result %9 to %8#1(%7) : !fir.array<100x!fir.logical<4>>, !fir.ref<!fir.array<100x!fir.logical<4>>>, !fir.shape<1> |
| 220 | + %10 = hlfir.as_expr %8#0 move %false : (!fir.ref<!fir.array<100x!fir.logical<4>>>, i1) -> !hlfir.expr<100x!fir.logical<4>> |
| 221 | + hlfir.yield %10 : !hlfir.expr<100x!fir.logical<4>> cleanup { |
| 222 | + hlfir.destroy %10 : !hlfir.expr<100x!fir.logical<4>> |
| 223 | + } |
| 224 | + } |
| 225 | + hlfir.yield %6 : !hlfir.expr<100x!fir.logical<4>> |
| 226 | + } do { |
| 227 | + hlfir.region_assign { |
| 228 | + %6 = fir.convert %arg3 : (i32) -> i64 |
| 229 | + %7:3 = fir.box_dims %5#1, %c1 : (!fir.box<!fir.array<?x?xf32>>, index) -> (index, index, index) |
| 230 | + %8 = arith.cmpi sgt, %7#1, %c0 : index |
| 231 | + %9 = arith.select %8, %7#1, %c0 : index |
| 232 | + %10 = fir.shape %9 : (index) -> !fir.shape<1> |
| 233 | + %11 = hlfir.designate %5#0 (%6, %c1:%7#1:%c1) shape %10 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 234 | + hlfir.yield %11 : !fir.box<!fir.array<?xf32>> |
| 235 | + } to { |
| 236 | + %6 = arith.muli %arg3, %c2_i32 overflow<nsw> : i32 |
| 237 | + %7 = fir.convert %6 : (i32) -> i64 |
| 238 | + %8 = hlfir.exactly_once : i32 { |
| 239 | + %14 = fir.call @_QPpure_ifoo() proc_attrs<pure> fastmath<contract> : () -> i32 |
| 240 | + hlfir.yield %14 : i32 cleanup { |
| 241 | + } |
| 242 | + } |
| 243 | + %9 = fir.convert %8 : (i32) -> index |
| 244 | + %10 = arith.cmpi sgt, %9, %c0 : index |
| 245 | + %11 = arith.select %10, %9, %c0 : index |
| 246 | + %12 = fir.shape %11 : (index) -> !fir.shape<1> |
| 247 | + %13 = hlfir.designate %3#0 (%7, %c1:%9:%c1) shape %12 : (!fir.box<!fir.array<?x?xf32>>, i64, index, index, index, !fir.shape<1>) -> !fir.box<!fir.array<?xf32>> |
| 248 | + hlfir.yield %13 : !fir.box<!fir.array<?xf32>> |
| 249 | + } |
| 250 | + } |
| 251 | + } |
| 252 | + } |
| 253 | + return |
| 254 | +} |
0 commit comments