// Test hlfir.declare operation parse, verify (no errors), and unparse. // RUN: fir-opt %s | fir-opt | FileCheck %s func.func @numeric_declare(%arg0: !fir.ref) { %0:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.ref) -> (!fir.ref, !fir.ref) return } // CHECK-LABEL: func.func @numeric_declare( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref) { // CHECK: %[[VAL_1:.*]] = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.ref) -> (!fir.ref, !fir.ref) func.func @char_declare(%arg0: !fir.boxchar<1> ) { %0:2 = fir.unboxchar %arg0 : (!fir.boxchar<1>) -> (!fir.ref>, index) %1:2 = hlfir.declare %0#0 typeparams %0#1 {uniq_name = "c"} : (!fir.ref>, index) -> (!fir.boxchar<1>, !fir.ref>) return } // CHECK-LABEL: func.func @char_declare( // CHECK-SAME: %[[VAL_0:.*]]: !fir.boxchar<1>) { // CHECK: %[[VAL_1:.*]]:2 = fir.unboxchar %[[VAL_0]] : (!fir.boxchar<1>) -> (!fir.ref>, index) // CHECK: %[[VAL_2:.*]] = hlfir.declare %[[VAL_1]]#0 typeparams %[[VAL_1]]#1 {uniq_name = "c"} : (!fir.ref>, index) -> (!fir.boxchar<1>, !fir.ref>) func.func @derived_declare(%arg0: !fir.ref>) { %0:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.ref>) -> (!fir.ref>, !fir.ref>) return } // CHECK-LABEL: func.func @derived_declare( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>) { // CHECK: %[[VAL_1:.*]] = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.ref>) -> (!fir.ref>, !fir.ref>) func.func @pdt_declare(%arg0: !fir.ref>) { %c1 = arith.constant 1 : index %0:2 = hlfir.declare %arg0 typeparams %c1 {uniq_name = "x"} : (!fir.ref>, index) -> (!fir.box>, !fir.ref>) return } // CHECK-LABEL: func.func @pdt_declare( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = hlfir.declare %[[VAL_0]] typeparams %[[VAL_1]] {uniq_name = "x"} : (!fir.ref>, index) -> (!fir.box>, !fir.ref>) func.func @array_declare(%arg0: !fir.ref>) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %shape = fir.shape %c1, %c2 : (index, index) -> !fir.shape<2> %0:2 = hlfir.declare %arg0(%shape) {uniq_name = "x"} : (!fir.ref>, !fir.shape<2>) -> (!fir.box>, !fir.ref>) return } // CHECK-LABEL: func.func @array_declare( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = fir.shape %[[VAL_1]], %[[VAL_2]] : (index, index) -> !fir.shape<2> // CHECK: %[[VAL_4:.*]] = hlfir.declare %[[VAL_0]](%[[VAL_3]]) {uniq_name = "x"} : (!fir.ref>, !fir.shape<2>) -> (!fir.box>, !fir.ref>) func.func @array_declare_2(%arg0: !fir.ref>) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %c3 = arith.constant 3 : index %c4 = arith.constant 4 : index %shape = fir.shape_shift %c1, %c2, %c3, %c4 : (index, index, index, index) -> !fir.shapeshift<2> %0:2 = hlfir.declare %arg0(%shape) {uniq_name = "x"} : (!fir.ref>, !fir.shapeshift<2>) -> (!fir.box>, !fir.ref>) return } // CHECK-LABEL: func.func @array_declare_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = arith.constant 3 : index // CHECK: %[[VAL_4:.*]] = arith.constant 4 : index // CHECK: %[[VAL_5:.*]] = fir.shape_shift %[[VAL_1]], %[[VAL_2]], %[[VAL_3]], %[[VAL_4]] : (index, index, index, index) -> !fir.shapeshift<2> // CHECK: %[[VAL_6:.*]] = hlfir.declare %[[VAL_0]](%[[VAL_5]]) {uniq_name = "x"} : (!fir.ref>, !fir.shapeshift<2>) -> (!fir.box>, !fir.ref>) func.func @array_declare_constant_extents_with_lower_bounds(%arg0: !fir.ref>) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %c3 = arith.constant 3 : index %c4 = arith.constant 4 : index %shape = fir.shape_shift %c1, %c2, %c3, %c4 : (index, index, index, index) -> !fir.shapeshift<2> %0:2 = hlfir.declare %arg0(%shape) {uniq_name = "x"} : (!fir.ref>, !fir.shapeshift<2>) -> (!fir.box>, !fir.ref>) return } // CHECK-LABEL: func.func @array_declare_constant_extents_with_lower_bounds( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = arith.constant 3 : index // CHECK: %[[VAL_4:.*]] = arith.constant 4 : index // CHECK: %[[VAL_5:.*]] = fir.shape_shift %[[VAL_1]], %[[VAL_2]], %[[VAL_3]], %[[VAL_4]] : (index, index, index, index) -> !fir.shapeshift<2> // CHECK: %[[VAL_6:.*]] = hlfir.declare %[[VAL_0]](%[[VAL_5]]) {uniq_name = "x"} : (!fir.ref>, !fir.shapeshift<2>) -> (!fir.box>, !fir.ref>) func.func @array_declare_box(%arg0: !fir.box>) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %shape = fir.shift %c1, %c2 : (index, index) -> !fir.shift<2> %0:2 = hlfir.declare %arg0(%shape) {uniq_name = "x"} : (!fir.box>, !fir.shift<2>) -> (!fir.box>, !fir.box>) return } // CHECK-LABEL: func.func @array_declare_box( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = fir.shift %[[VAL_1]], %[[VAL_2]] : (index, index) -> !fir.shift<2> // CHECK: %[[VAL_4:.*]] = hlfir.declare %[[VAL_0]](%[[VAL_3]]) {uniq_name = "x"} : (!fir.box>, !fir.shift<2>) -> (!fir.box>, !fir.box>) func.func @array_declare_char_box(%arg0: !fir.box>>) { %0:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.box>>) -> (!fir.box>>, !fir.box>>) return } // CHECK-LABEL: func.func @array_declare_char_box( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>>) { // CHECK: %[[VAL_1:.*]] = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.box>>) -> (!fir.box>>, !fir.box>>) func.func @array_declare_char_box_2(%arg0: !fir.box>>) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %c3 = arith.constant 3 : index %shape = fir.shift %c1, %c2 : (index, index) -> !fir.shift<2> %0:2 = hlfir.declare %arg0(%shape) typeparams %c3 {uniq_name = "x"} : (!fir.box>>, !fir.shift<2>, index) -> (!fir.box>>, !fir.box>>) return } // CHECK-LABEL: func.func @array_declare_char_box_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box>>) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = arith.constant 3 : index // CHECK: %[[VAL_4:.*]] = fir.shift %[[VAL_1]], %[[VAL_2]] : (index, index) -> !fir.shift<2> // CHECK: %[[VAL_5:.*]] = hlfir.declare %[[VAL_0]](%[[VAL_4]]) typeparams %[[VAL_3]] {uniq_name = "x"} : (!fir.box>>, !fir.shift<2>, index) -> (!fir.box>>, !fir.box>>) func.func @array_declare_char_boxaddr(%arg0: !fir.ref>>>>) { %0:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.ref>>>>) -> (!fir.ref>>>>, !fir.ref>>>>) return } // CHECK-LABEL: func.func @array_declare_char_boxaddr( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>>>) { // CHECK: %[[VAL_1:.*]] = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.ref>>>>) -> (!fir.ref>>>>, !fir.ref>>>>) func.func @array_declare_char_boxaddr_2(%arg0: !fir.ref>>>>) { %c3 = arith.constant 3 : index %0:2 = hlfir.declare %arg0 typeparams %c3 {uniq_name = "x"} : (!fir.ref>>>>, index) -> (!fir.ref>>>>, !fir.ref>>>>) return } // CHECK-LABEL: func.func @array_declare_char_boxaddr_2( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>>>) { // CHECK: %[[VAL_1:.*]] = arith.constant 3 : index // CHECK: %[[VAL_2:.*]] = hlfir.declare %[[VAL_0]] typeparams %[[VAL_1]] {uniq_name = "x"} : (!fir.ref>>>>, index) -> (!fir.ref>>>>, !fir.ref>>>>) func.func @array_declare_unlimited_polymorphic_boxaddr(%arg0: !fir.ref>>>) { %0:2 = hlfir.declare %arg0 {uniq_name = "x"} : (!fir.ref>>>) -> (!fir.ref>>>, !fir.ref>>>) return } // CHECK-LABEL: func.func @array_declare_unlimited_polymorphic_boxaddr( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>>) { // CHECK: %[[VAL_1:.*]] = hlfir.declare %[[VAL_0]] {uniq_name = "x"} : (!fir.ref>>>) -> (!fir.ref>>>, !fir.ref>>>)