diff --git a/flang/test/Fir/abstract-results.fir b/flang/test/Fir/abstract-results.fir --- a/flang/test/Fir/abstract-results.fir +++ b/flang/test/Fir/abstract-results.fir @@ -1,30 +1,30 @@ // Test rewrite of functions that return fir.array<>, fir.type<>, fir.box<> to // functions that take an additional argument for the result. -// RUN: fir-opt %s --abstract-result-on-func-opt | FileCheck %s -// RUN: fir-opt %s --abstract-result-on-func-opt=abstract-result-as-box | FileCheck %s --check-prefix=CHECK-BOX +// RUN: fir-opt %s --abstract-result-on-func-opt | FileCheck %s --check-prefix=FUNC-REF +// RUN: fir-opt %s --abstract-result-on-func-opt=abstract-result-as-box | FileCheck %s --check-prefix=FUNC-BOX // ----------------------- Test declaration rewrite ---------------------------- -// CHECK-LABEL: func private @arrayfunc(!fir.ref>, i32) -// CHECK-BOX-LABEL: func private @arrayfunc(!fir.box>, i32) +// FUNC-REF-LABEL: func private @arrayfunc(!fir.ref>, i32) +// FUNC-BOX-LABEL: func private @arrayfunc(!fir.box>, i32) func.func private @arrayfunc(i32) -> !fir.array -// CHECK-LABEL: func private @derivedfunc(!fir.ref>, f32) -// CHECK-BOX-LABEL: func private @derivedfunc(!fir.box>, f32) +// FUNC-REF-LABEL: func private @derivedfunc(!fir.ref>, f32) +// FUNC-BOX-LABEL: func private @derivedfunc(!fir.box>, f32) func.func private @derivedfunc(f32) -> !fir.type -// CHECK-LABEL: func private @boxfunc(!fir.ref>>, i64) -// CHECK-BOX-LABEL: func private @boxfunc(!fir.ref>>, i64) +// FUNC-REF-LABEL: func private @boxfunc(!fir.ref>>, i64) +// FUNC-BOX-LABEL: func private @boxfunc(!fir.ref>>, i64) func.func private @boxfunc(i64) -> !fir.box> // ------------------------ Test callee rewrite -------------------------------- -// CHECK-LABEL: func private @arrayfunc_callee( -// CHECK-SAME: %[[buffer:.*]]: !fir.ref>, %[[n:.*]]: index) { -// CHECK-BOX-LABEL: func private @arrayfunc_callee( -// CHECK-BOX-SAME: %[[box:.*]]: !fir.box>, %[[n:.*]]: index) { +// FUNC-REF-LABEL: func private @arrayfunc_callee( +// FUNC-REF-SAME: %[[buffer:.*]]: !fir.ref>, %[[n:.*]]: index) { +// FUNC-BOX-LABEL: func private @arrayfunc_callee( +// FUNC-BOX-SAME: %[[box:.*]]: !fir.box>, %[[n:.*]]: index) { func.func private @arrayfunc_callee(%n : index) -> !fir.array { %buffer = fir.alloca !fir.array, %n // Do something with result (res(4) = 42.) @@ -35,21 +35,21 @@ %res = fir.load %buffer : !fir.ref> return %res : !fir.array - // CHECK-DAG: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, i64) -> !fir.ref - // CHECK-DAG: fir.store %{{.*}} to %[[coor]] : !fir.ref - // CHECK: return + // FUNC-REF-DAG: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, i64) -> !fir.ref + // FUNC-REF-DAG: fir.store %{{.*}} to %[[coor]] : !fir.ref + // FUNC-REF: return - // CHECK-BOX: %[[buffer:.*]] = fir.box_addr %[[box]] : (!fir.box>) -> !fir.ref> - // CHECK-BOX-DAG: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, i64) -> !fir.ref - // CHECK-BOX-DAG: fir.store %{{.*}} to %[[coor]] : !fir.ref - // CHECK-BOX: return + // FUNC-BOX: %[[buffer:.*]] = fir.box_addr %[[box]] : (!fir.box>) -> !fir.ref> + // FUNC-BOX-DAG: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, i64) -> !fir.ref + // FUNC-BOX-DAG: fir.store %{{.*}} to %[[coor]] : !fir.ref + // FUNC-BOX: return } -// CHECK-LABEL: func @derivedfunc_callee( -// CHECK-SAME: %[[buffer:.*]]: !fir.ref>, %[[v:.*]]: f32) { -// CHECK-BOX-LABEL: func @derivedfunc_callee( -// CHECK-BOX-SAME: %[[box:.*]]: !fir.box>, %[[v:.*]]: f32) { +// FUNC-REF-LABEL: func @derivedfunc_callee( +// FUNC-REF-SAME: %[[buffer:.*]]: !fir.ref>, %[[v:.*]]: f32) { +// FUNC-BOX-LABEL: func @derivedfunc_callee( +// FUNC-BOX-SAME: %[[box:.*]]: !fir.box>, %[[v:.*]]: f32) { func.func @derivedfunc_callee(%v: f32) -> !fir.type { %buffer = fir.alloca !fir.type %0 = fir.field_index x, !fir.type @@ -58,37 +58,37 @@ %res = fir.load %buffer : !fir.ref> return %res : !fir.type - // CHECK: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, !fir.field) -> !fir.ref - // CHECK: fir.store %[[v]] to %[[coor]] : !fir.ref - // CHECK: return + // FUNC-REF: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, !fir.field) -> !fir.ref + // FUNC-REF: fir.store %[[v]] to %[[coor]] : !fir.ref + // FUNC-REF: return - // CHECK-BOX: %[[buffer:.*]] = fir.box_addr %[[box]] : (!fir.box>) -> !fir.ref> - // CHECK-BOX: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, !fir.field) -> !fir.ref - // CHECK-BOX: fir.store %[[v]] to %[[coor]] : !fir.ref - // CHECK-BOX: return + // FUNC-BOX: %[[buffer:.*]] = fir.box_addr %[[box]] : (!fir.box>) -> !fir.ref> + // FUNC-BOX: %[[coor:.*]] = fir.coordinate_of %[[buffer]], %{{.*}} : (!fir.ref>, !fir.field) -> !fir.ref + // FUNC-BOX: fir.store %[[v]] to %[[coor]] : !fir.ref + // FUNC-BOX: return } -// CHECK-LABEL: func @boxfunc_callee( -// CHECK-SAME: %[[buffer:.*]]: !fir.ref>>) { -// CHECK-BOX-LABEL: func @boxfunc_callee( -// CHECK-BOX-SAME: %[[buffer:.*]]: !fir.ref>>) { +// FUNC-REF-LABEL: func @boxfunc_callee( +// FUNC-REF-SAME: %[[buffer:.*]]: !fir.ref>>) { +// FUNC-BOX-LABEL: func @boxfunc_callee( +// FUNC-BOX-SAME: %[[buffer:.*]]: !fir.ref>>) { func.func @boxfunc_callee() -> !fir.box> { %alloc = fir.allocmem f64 %res = fir.embox %alloc : (!fir.heap) -> !fir.box> return %res : !fir.box> - // CHECK: %[[box:.*]] = fir.embox %{{.*}} : (!fir.heap) -> !fir.box> - // CHECK: fir.store %[[box]] to %[[buffer]] : !fir.ref>> - // CHECK: return + // FUNC-REF: %[[box:.*]] = fir.embox %{{.*}} : (!fir.heap) -> !fir.box> + // FUNC-REF: fir.store %[[box]] to %[[buffer]] : !fir.ref>> + // FUNC-REF: return - // CHECK-BOX: %[[box:.*]] = fir.embox %{{.*}} : (!fir.heap) -> !fir.box> - // CHECK-BOX: fir.store %[[box]] to %[[buffer]] : !fir.ref>> - // CHECK-BOX: return + // FUNC-BOX: %[[box:.*]] = fir.embox %{{.*}} : (!fir.heap) -> !fir.box> + // FUNC-BOX: fir.store %[[box]] to %[[buffer]] : !fir.ref>> + // FUNC-BOX: return } // ------------------------ Test caller rewrite -------------------------------- -// CHECK-LABEL: func @call_arrayfunc() { -// CHECK-BOX-LABEL: func @call_arrayfunc() { +// FUNC-REF-LABEL: func @call_arrayfunc() { +// FUNC-BOX-LABEL: func @call_arrayfunc() { func.func @call_arrayfunc() { %c100 = arith.constant 100 : index %buffer = fir.alloca !fir.array, %c100 @@ -97,45 +97,45 @@ fir.save_result %res to %buffer(%shape) : !fir.array, !fir.ref>, !fir.shape<1> return - // CHECK: %[[c100:.*]] = arith.constant 100 : index - // CHECK: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] - // CHECK: fir.call @arrayfunc_callee(%[[buffer]], %[[c100]]) : (!fir.ref>, index) -> () - // CHECK-NOT: fir.save_result - - // CHECK-BOX: %[[c100:.*]] = arith.constant 100 : index - // CHECK-BOX: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] - // CHECK-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> - // CHECK-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) : (!fir.ref>, !fir.shape<1>) -> !fir.box> - // CHECK-BOX: fir.call @arrayfunc_callee(%[[box]], %[[c100]]) : (!fir.box>, index) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-REF: %[[c100:.*]] = arith.constant 100 : index + // FUNC-REF: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] + // FUNC-REF: fir.call @arrayfunc_callee(%[[buffer]], %[[c100]]) : (!fir.ref>, index) -> () + // FUNC-REF-NOT: fir.save_result + + // FUNC-BOX: %[[c100:.*]] = arith.constant 100 : index + // FUNC-BOX: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] + // FUNC-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> + // FUNC-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) : (!fir.ref>, !fir.shape<1>) -> !fir.box> + // FUNC-BOX: fir.call @arrayfunc_callee(%[[box]], %[[c100]]) : (!fir.box>, index) -> () + // FUNC-BOX-NOT: fir.save_result } -// CHECK-LABEL: func @call_derivedfunc() { -// CHECK-BOX-LABEL: func @call_derivedfunc() { +// FUNC-REF-LABEL: func @call_derivedfunc() { +// FUNC-BOX-LABEL: func @call_derivedfunc() { func.func @call_derivedfunc() { %buffer = fir.alloca !fir.type %cst = arith.constant 4.200000e+01 : f32 %res = fir.call @derivedfunc_callee(%cst) : (f32) -> !fir.type fir.save_result %res to %buffer : !fir.type, !fir.ref> return - // CHECK: %[[buffer:.*]] = fir.alloca !fir.type - // CHECK: %[[cst:.*]] = arith.constant {{.*}} : f32 - // CHECK: fir.call @derivedfunc_callee(%[[buffer]], %[[cst]]) : (!fir.ref>, f32) -> () - // CHECK-NOT: fir.save_result - - // CHECK-BOX: %[[buffer:.*]] = fir.alloca !fir.type - // CHECK-BOX: %[[cst:.*]] = arith.constant {{.*}} : f32 - // CHECK-BOX: %[[box:.*]] = fir.embox %[[buffer]] : (!fir.ref>) -> !fir.box> - // CHECK-BOX: fir.call @derivedfunc_callee(%[[box]], %[[cst]]) : (!fir.box>, f32) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-REF: %[[buffer:.*]] = fir.alloca !fir.type + // FUNC-REF: %[[cst:.*]] = arith.constant {{.*}} : f32 + // FUNC-REF: fir.call @derivedfunc_callee(%[[buffer]], %[[cst]]) : (!fir.ref>, f32) -> () + // FUNC-REF-NOT: fir.save_result + + // FUNC-BOX: %[[buffer:.*]] = fir.alloca !fir.type + // FUNC-BOX: %[[cst:.*]] = arith.constant {{.*}} : f32 + // FUNC-BOX: %[[box:.*]] = fir.embox %[[buffer]] : (!fir.ref>) -> !fir.box> + // FUNC-BOX: fir.call @derivedfunc_callee(%[[box]], %[[cst]]) : (!fir.box>, f32) -> () + // FUNC-BOX-NOT: fir.save_result } func.func private @derived_lparams_func() -> !fir.type -// CHECK-LABEL: func @call_derived_lparams_func( -// CHECK-SAME: %[[buffer:.*]]: !fir.ref> -// CHECK-BOX-LABEL: func @call_derived_lparams_func( -// CHECK-BOX-SAME: %[[buffer:.*]]: !fir.ref> +// FUNC-REF-LABEL: func @call_derived_lparams_func( +// FUNC-REF-SAME: %[[buffer:.*]]: !fir.ref> +// FUNC-BOX-LABEL: func @call_derived_lparams_func( +// FUNC-BOX-SAME: %[[buffer:.*]]: !fir.ref> func.func @call_derived_lparams_func(%buffer: !fir.ref>) { %l1 = arith.constant 3 : i32 %l2 = arith.constant 5 : i32 @@ -143,39 +143,39 @@ fir.save_result %res to %buffer typeparams %l1, %l2 : !fir.type, !fir.ref>, i32, i32 return - // CHECK: %[[l1:.*]] = arith.constant 3 : i32 - // CHECK: %[[l2:.*]] = arith.constant 5 : i32 - // CHECK: fir.call @derived_lparams_func(%[[buffer]]) : (!fir.ref>) -> () - // CHECK-NOT: fir.save_result + // FUNC-REF: %[[l1:.*]] = arith.constant 3 : i32 + // FUNC-REF: %[[l2:.*]] = arith.constant 5 : i32 + // FUNC-REF: fir.call @derived_lparams_func(%[[buffer]]) : (!fir.ref>) -> () + // FUNC-REF-NOT: fir.save_result - // CHECK-BOX: %[[l1:.*]] = arith.constant 3 : i32 - // CHECK-BOX: %[[l2:.*]] = arith.constant 5 : i32 - // CHECK-BOX: %[[box:.*]] = fir.embox %[[buffer]] typeparams %[[l1]], %[[l2]] : (!fir.ref>, i32, i32) -> !fir.box> - // CHECK-BOX: fir.call @derived_lparams_func(%[[box]]) : (!fir.box>) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-BOX: %[[l1:.*]] = arith.constant 3 : i32 + // FUNC-BOX: %[[l2:.*]] = arith.constant 5 : i32 + // FUNC-BOX: %[[box:.*]] = fir.embox %[[buffer]] typeparams %[[l1]], %[[l2]] : (!fir.ref>, i32, i32) -> !fir.box> + // FUNC-BOX: fir.call @derived_lparams_func(%[[box]]) : (!fir.box>) -> () + // FUNC-BOX-NOT: fir.save_result } -// CHECK-LABEL: func @call_boxfunc() { -// CHECK-BOX-LABEL: func @call_boxfunc() { +// FUNC-REF-LABEL: func @call_boxfunc() { +// FUNC-BOX-LABEL: func @call_boxfunc() { func.func @call_boxfunc() { %buffer = fir.alloca !fir.box> %res = fir.call @boxfunc_callee() : () -> !fir.box> fir.save_result %res to %buffer: !fir.box>, !fir.ref>> return - // CHECK: %[[buffer:.*]] = fir.alloca !fir.box> - // CHECK: fir.call @boxfunc_callee(%[[buffer]]) : (!fir.ref>>) -> () - // CHECK-NOT: fir.save_result + // FUNC-REF: %[[buffer:.*]] = fir.alloca !fir.box> + // FUNC-REF: fir.call @boxfunc_callee(%[[buffer]]) : (!fir.ref>>) -> () + // FUNC-REF-NOT: fir.save_result - // CHECK-BOX: %[[buffer:.*]] = fir.alloca !fir.box> - // CHECK-BOX: fir.call @boxfunc_callee(%[[buffer]]) : (!fir.ref>>) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-BOX: %[[buffer:.*]] = fir.alloca !fir.box> + // FUNC-BOX: fir.call @boxfunc_callee(%[[buffer]]) : (!fir.ref>>) -> () + // FUNC-BOX-NOT: fir.save_result } func.func private @chararrayfunc(index, index) -> !fir.array> -// CHECK-LABEL: func @call_chararrayfunc() { -// CHECK-BOX-LABEL: func @call_chararrayfunc() { +// FUNC-REF-LABEL: func @call_chararrayfunc() { +// FUNC-BOX-LABEL: func @call_chararrayfunc() { func.func @call_chararrayfunc() { %c100 = arith.constant 100 : index %c50 = arith.constant 50 : index @@ -185,48 +185,48 @@ fir.save_result %res to %buffer(%shape) typeparams %c50 : !fir.array>, !fir.ref>>, !fir.shape<1>, index return - // CHECK: %[[c100:.*]] = arith.constant 100 : index - // CHECK: %[[c50:.*]] = arith.constant 50 : index - // CHECK: %[[buffer:.*]] = fir.alloca !fir.array>(%[[c100]] : index), %[[c50]] - // CHECK: fir.call @chararrayfunc(%[[buffer]], %[[c100]], %[[c50]]) : (!fir.ref>>, index, index) -> () - // CHECK-NOT: fir.save_result - - // CHECK-BOX: %[[c100:.*]] = arith.constant 100 : index - // CHECK-BOX: %[[c50:.*]] = arith.constant 50 : index - // CHECK-BOX: %[[buffer:.*]] = fir.alloca !fir.array>(%[[c100]] : index), %[[c50]] - // CHECK-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> - // CHECK-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) typeparams %[[c50]] : (!fir.ref>>, !fir.shape<1>, index) -> !fir.box>> - // CHECK-BOX: fir.call @chararrayfunc(%[[box]], %[[c100]], %[[c50]]) : (!fir.box>>, index, index) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-REF: %[[c100:.*]] = arith.constant 100 : index + // FUNC-REF: %[[c50:.*]] = arith.constant 50 : index + // FUNC-REF: %[[buffer:.*]] = fir.alloca !fir.array>(%[[c100]] : index), %[[c50]] + // FUNC-REF: fir.call @chararrayfunc(%[[buffer]], %[[c100]], %[[c50]]) : (!fir.ref>>, index, index) -> () + // FUNC-REF-NOT: fir.save_result + + // FUNC-BOX: %[[c100:.*]] = arith.constant 100 : index + // FUNC-BOX: %[[c50:.*]] = arith.constant 50 : index + // FUNC-BOX: %[[buffer:.*]] = fir.alloca !fir.array>(%[[c100]] : index), %[[c50]] + // FUNC-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> + // FUNC-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) typeparams %[[c50]] : (!fir.ref>>, !fir.shape<1>, index) -> !fir.box>> + // FUNC-BOX: fir.call @chararrayfunc(%[[box]], %[[c100]], %[[c50]]) : (!fir.box>>, index, index) -> () + // FUNC-BOX-NOT: fir.save_result } // ------------------------ Test fir.address_of rewrite ------------------------ func.func private @takesfuncarray((i32) -> !fir.array) -// CHECK-LABEL: func @test_address_of() { -// CHECK-BOX-LABEL: func @test_address_of() { +// FUNC-REF-LABEL: func @test_address_of() { +// FUNC-BOX-LABEL: func @test_address_of() { func.func @test_address_of() { %0 = fir.address_of(@arrayfunc) : (i32) -> !fir.array fir.call @takesfuncarray(%0) : ((i32) -> !fir.array) -> () return - // CHECK: %[[addrOf:.*]] = fir.address_of(@arrayfunc) : (!fir.ref>, i32) -> () - // CHECK: %[[conv:.*]] = fir.convert %[[addrOf]] : ((!fir.ref>, i32) -> ()) -> ((i32) -> !fir.array) - // CHECK: fir.call @takesfuncarray(%[[conv]]) : ((i32) -> !fir.array) -> () + // FUNC-REF: %[[addrOf:.*]] = fir.address_of(@arrayfunc) : (!fir.ref>, i32) -> () + // FUNC-REF: %[[conv:.*]] = fir.convert %[[addrOf]] : ((!fir.ref>, i32) -> ()) -> ((i32) -> !fir.array) + // FUNC-REF: fir.call @takesfuncarray(%[[conv]]) : ((i32) -> !fir.array) -> () - // CHECK-BOX: %[[addrOf:.*]] = fir.address_of(@arrayfunc) : (!fir.box>, i32) -> () - // CHECK-BOX: %[[conv:.*]] = fir.convert %[[addrOf]] : ((!fir.box>, i32) -> ()) -> ((i32) -> !fir.array) - // CHECK-BOX: fir.call @takesfuncarray(%[[conv]]) : ((i32) -> !fir.array) -> () + // FUNC-BOX: %[[addrOf:.*]] = fir.address_of(@arrayfunc) : (!fir.box>, i32) -> () + // FUNC-BOX: %[[conv:.*]] = fir.convert %[[addrOf]] : ((!fir.box>, i32) -> ()) -> ((i32) -> !fir.array) + // FUNC-BOX: fir.call @takesfuncarray(%[[conv]]) : ((i32) -> !fir.array) -> () } // ----------------------- Test indirect calls rewrite ------------------------ -// CHECK-LABEL: func @test_indirect_calls( -// CHECK-SAME: %[[arg0:.*]]: () -> ()) { -// CHECK-BOX-LABEL: func @test_indirect_calls( -// CHECK-BOX-SAME: %[[arg0:.*]]: () -> ()) { +// FUNC-REF-LABEL: func @test_indirect_calls( +// FUNC-REF-SAME: %[[arg0:.*]]: () -> ()) { +// FUNC-BOX-LABEL: func @test_indirect_calls( +// FUNC-BOX-SAME: %[[arg0:.*]]: () -> ()) { func.func @test_indirect_calls(%arg0: () -> ()) { %c100 = arith.constant 100 : index %buffer = fir.alloca !fir.array, %c100 @@ -236,20 +236,20 @@ fir.save_result %res to %buffer(%shape) : !fir.array, !fir.ref>, !fir.shape<1> return - // CHECK: %[[c100:.*]] = arith.constant 100 : index - // CHECK: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] - // CHECK: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> - // CHECK: %[[original_conv:.*]] = fir.convert %[[arg0]] : (() -> ()) -> ((index) -> !fir.array) - // CHECK: %[[conv:.*]] = fir.convert %[[original_conv]] : ((index) -> !fir.array) -> ((!fir.ref>, index) -> ()) - // CHECK: fir.call %[[conv]](%[[buffer]], %c100) : (!fir.ref>, index) -> () - // CHECK-NOT: fir.save_result - - // CHECK-BOX: %[[c100:.*]] = arith.constant 100 : index - // CHECK-BOX: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] - // CHECK-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> - // CHECK-BOX: %[[original_conv:.*]] = fir.convert %[[arg0]] : (() -> ()) -> ((index) -> !fir.array) - // CHECK-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) : (!fir.ref>, !fir.shape<1>) -> !fir.box> - // CHECK-BOX: %[[conv:.*]] = fir.convert %[[original_conv]] : ((index) -> !fir.array) -> ((!fir.box>, index) -> ()) - // CHECK-BOX: fir.call %[[conv]](%[[box]], %c100) : (!fir.box>, index) -> () - // CHECK-BOX-NOT: fir.save_result + // FUNC-REF: %[[c100:.*]] = arith.constant 100 : index + // FUNC-REF: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] + // FUNC-REF: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> + // FUNC-REF: %[[original_conv:.*]] = fir.convert %[[arg0]] : (() -> ()) -> ((index) -> !fir.array) + // FUNC-REF: %[[conv:.*]] = fir.convert %[[original_conv]] : ((index) -> !fir.array) -> ((!fir.ref>, index) -> ()) + // FUNC-REF: fir.call %[[conv]](%[[buffer]], %c100) : (!fir.ref>, index) -> () + // FUNC-REF-NOT: fir.save_result + + // FUNC-BOX: %[[c100:.*]] = arith.constant 100 : index + // FUNC-BOX: %[[buffer:.*]] = fir.alloca !fir.array, %[[c100]] + // FUNC-BOX: %[[shape:.*]] = fir.shape %[[c100]] : (index) -> !fir.shape<1> + // FUNC-BOX: %[[original_conv:.*]] = fir.convert %[[arg0]] : (() -> ()) -> ((index) -> !fir.array) + // FUNC-BOX: %[[box:.*]] = fir.embox %[[buffer]](%[[shape]]) : (!fir.ref>, !fir.shape<1>) -> !fir.box> + // FUNC-BOX: %[[conv:.*]] = fir.convert %[[original_conv]] : ((index) -> !fir.array) -> ((!fir.box>, index) -> ()) + // FUNC-BOX: fir.call %[[conv]](%[[box]], %c100) : (!fir.box>, index) -> () + // FUNC-BOX-NOT: fir.save_result }