| // Test hlfir.region_assign and hlfir.yield operation parse, verify (no errors), |
| // and unparse. |
| // RUN: fir-opt %s | fir-opt | FileCheck %s |
| |
| func.func @region_assign_test(%y : !fir.box<!fir.array<?xi64>>, %x: !fir.box<!fir.array<?xf32>>) { |
| %c100 = arith.constant 100 : index |
| %shape = fir.shape %c100 : (index) -> !fir.shape<1> |
| hlfir.region_assign { |
| %expr = hlfir.elemental %shape : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| ^bb0(%i : index): |
| %yelt = hlfir.designate %y(%i) : (!fir.box<!fir.array<?xi64>>, index) -> !fir.ref<i64> |
| %elt = fir.call @some_elemental(%yelt) : (!fir.ref<i64>) -> f32 |
| hlfir.yield_element %elt : f32 |
| } |
| hlfir.yield %expr : !hlfir.expr<?xf32> |
| } to { |
| hlfir.yield %x : !fir.box<!fir.array<?xf32>> |
| } |
| return |
| } |
| // CHECK-LABEL: func.func @region_assign_test( |
| // CHECK-SAME: %[[VAL_0:.*]]: !fir.box<!fir.array<?xi64>>, |
| // CHECK-SAME: %[[VAL_1:.*]]: !fir.box<!fir.array<?xf32>>) { |
| // CHECK: %[[VAL_2:.*]] = arith.constant 100 : index |
| // CHECK: %[[VAL_3:.*]] = fir.shape %[[VAL_2]] : (index) -> !fir.shape<1> |
| // CHECK: hlfir.region_assign { |
| // CHECK: %[[VAL_4:.*]] = hlfir.elemental %[[VAL_3]] : (!fir.shape<1>) -> !hlfir.expr<?xf32> { |
| // CHECK: ^bb0(%[[VAL_5:.*]]: index): |
| // CHECK: %[[VAL_6:.*]] = hlfir.designate %[[VAL_0]] (%[[VAL_5]]) : (!fir.box<!fir.array<?xi64>>, index) -> !fir.ref<i64> |
| // CHECK: %[[VAL_7:.*]] = fir.call @some_elemental(%[[VAL_6]]) : (!fir.ref<i64>) -> f32 |
| // CHECK: hlfir.yield_element %[[VAL_7]] : f32 |
| // CHECK: } |
| // CHECK: hlfir.yield %[[VAL_8:.*]] : !hlfir.expr<?xf32> |
| // CHECK: } to { |
| // CHECK: hlfir.yield %[[VAL_1]] : !fir.box<!fir.array<?xf32>> |
| // CHECK: } |
| |
| func.func @region_user_assign_test(%y : !fir.box<!fir.array<?xi64>>, %x: !fir.box<!fir.array<?xf32>>) { |
| hlfir.region_assign { |
| hlfir.yield %y : !fir.box<!fir.array<?xi64>> |
| } to { |
| hlfir.yield %x : !fir.box<!fir.array<?xf32>> |
| } user_defined_assign (%rhs : !fir.ref<i64>) to (%lhs : !fir.ref<f32>) { |
| %0 = fir.load %rhs : !fir.ref<i64> |
| fir.call @user_assign(%lhs, %0) : (!fir.ref<f32>, i64) -> () |
| } |
| return |
| } |
| // CHECK-LABEL: func.func @region_user_assign_test( |
| // CHECK-SAME: %[[VAL_0:.*]]: !fir.box<!fir.array<?xi64>>, |
| // CHECK-SAME: %[[VAL_1:.*]]: !fir.box<!fir.array<?xf32>>) { |
| // CHECK: hlfir.region_assign { |
| // CHECK: hlfir.yield %[[VAL_0]] : !fir.box<!fir.array<?xi64>> |
| // CHECK: } to { |
| // CHECK: hlfir.yield %[[VAL_1]] : !fir.box<!fir.array<?xf32>> |
| // CHECK: } user_defined_assign (%[[VAL_2:.*]]: !fir.ref<i64>) to (%[[VAL_3:.*]]: !fir.ref<f32>) { |
| // CHECK: %[[VAL_4:.*]] = fir.load %[[VAL_2]] : !fir.ref<i64> |
| // CHECK: fir.call @user_assign(%[[VAL_3]], %[[VAL_4]]) : (!fir.ref<f32>, i64) -> () |
| // CHECK: } |
| |
| func.func @yield_cleanup(%x: !fir.box<!fir.array<?xf32>>) { |
| hlfir.region_assign { |
| %0 = fir.allocmem !fir.array<100xf32> |
| fir.call @fillin_some_values(%0) : (!fir.heap<!fir.array<100xf32>>) -> () |
| hlfir.yield %0 : !fir.heap<!fir.array<100xf32>> cleanup { |
| fir.freemem %0 : !fir.heap<!fir.array<100xf32>> |
| } |
| } to { |
| hlfir.yield %x : !fir.box<!fir.array<?xf32>> |
| } |
| return |
| } |
| // CHECK-LABEL: func.func @yield_cleanup( |
| // CHECK-SAME: %[[VAL_0:.*]]: !fir.box<!fir.array<?xf32>>) { |
| // CHECK: hlfir.region_assign { |
| // CHECK: %[[VAL_1:.*]] = fir.allocmem !fir.array<100xf32> |
| // CHECK: fir.call @fillin_some_values(%[[VAL_1]]) : (!fir.heap<!fir.array<100xf32>>) -> () |
| // CHECK: hlfir.yield %[[VAL_1]] : !fir.heap<!fir.array<100xf32>> cleanup { |
| // CHECK: fir.freemem %[[VAL_1]] : !fir.heap<!fir.array<100xf32>> |
| // CHECK: } |
| // CHECK: } to { |
| // CHECK: hlfir.yield %[[VAL_0]] : !fir.box<!fir.array<?xf32>> |
| // CHECK: } |
| |
| func.func private @user_assign(!fir.ref<f32>, i64) -> () |
| func.func private @some_elemental(!fir.ref<i64>) -> f32 |
| func.func private @fillin_some_values(!fir.heap<!fir.array<100xf32>>) -> () |