// 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>, %x: !fir.box>) { %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 { ^bb0(%i : index): %yelt = hlfir.designate %y(%i) : (!fir.box>, index) -> !fir.ref %elt = fir.call @some_elemental(%yelt) : (!fir.ref) -> f32 hlfir.yield_element %elt : f32 } hlfir.yield %expr : !hlfir.expr } to { hlfir.yield %x : !fir.box> } return } // CHECK-LABEL: func.func @region_assign_test( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box>) { // 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 { // CHECK: ^bb0(%[[VAL_5:.*]]: index): // CHECK: %[[VAL_6:.*]] = hlfir.designate %[[VAL_0]] (%[[VAL_5]]) : (!fir.box>, index) -> !fir.ref // CHECK: %[[VAL_7:.*]] = fir.call @some_elemental(%[[VAL_6]]) : (!fir.ref) -> f32 // CHECK: hlfir.yield_element %[[VAL_7]] : f32 // CHECK: } // CHECK: hlfir.yield %[[VAL_8:.*]] : !hlfir.expr // CHECK: } to { // CHECK: hlfir.yield %[[VAL_1]] : !fir.box> // CHECK: } func.func @region_user_assign_test(%y : !fir.box>, %x: !fir.box>) { hlfir.region_assign { hlfir.yield %y : !fir.box> } to { hlfir.yield %x : !fir.box> } user_defined_assign (%rhs : !fir.ref) to (%lhs : !fir.ref) { %0 = fir.load %rhs : !fir.ref fir.call @user_assign(%lhs, %0) : (!fir.ref, i64) -> () } return } // CHECK-LABEL: func.func @region_user_assign_test( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box>) { // CHECK: hlfir.region_assign { // CHECK: hlfir.yield %[[VAL_0]] : !fir.box> // CHECK: } to { // CHECK: hlfir.yield %[[VAL_1]] : !fir.box> // CHECK: } user_defined_assign (%[[VAL_2:.*]]: !fir.ref) to (%[[VAL_3:.*]]: !fir.ref) { // CHECK: %[[VAL_4:.*]] = fir.load %[[VAL_2]] : !fir.ref // CHECK: fir.call @user_assign(%[[VAL_3]], %[[VAL_4]]) : (!fir.ref, i64) -> () // CHECK: } func.func @yield_cleanup(%x: !fir.box>) { hlfir.region_assign { %0 = fir.allocmem !fir.array<100xf32> fir.call @fillin_some_values(%0) : (!fir.heap>) -> () hlfir.yield %0 : !fir.heap> cleanup { fir.freemem %0 : !fir.heap> } } to { hlfir.yield %x : !fir.box> } return } // CHECK-LABEL: func.func @yield_cleanup( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>) { // CHECK: hlfir.region_assign { // CHECK: %[[VAL_1:.*]] = fir.allocmem !fir.array<100xf32> // CHECK: fir.call @fillin_some_values(%[[VAL_1]]) : (!fir.heap>) -> () // CHECK: hlfir.yield %[[VAL_1]] : !fir.heap> cleanup { // CHECK: fir.freemem %[[VAL_1]] : !fir.heap> // CHECK: } // CHECK: } to { // CHECK: hlfir.yield %[[VAL_0]] : !fir.box> // CHECK: } func.func private @user_assign(!fir.ref, i64) -> () func.func private @some_elemental(!fir.ref) -> f32 func.func private @fillin_some_values(!fir.heap>) -> ()