Skip to content

Commit 4d5a9c1

Browse files
committed
Using higher level interface to insert new arguments so arguments
and their corresponding attributes are moved together Differential revision: https://reviews.llvm.org/D13767
1 parent 82ca918 commit 4d5a9c1

File tree

2 files changed

+34
-2
lines changed

2 files changed

+34
-2
lines changed

flang/lib/Optimizer/Transforms/AbstractResult.cpp

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -334,13 +334,14 @@ class AbstractResultOnFuncOpt
334334
});
335335
return;
336336
}
337-
func.setType(getNewFunctionType(funcTy, shouldBoxResult));
338337
if (!func.empty()) {
339338
// Insert new argument.
340339
mlir::OpBuilder rewriter(context);
341340
auto resultType = funcTy.getResult(0);
342341
auto argTy = getResultArgumentType(resultType, shouldBoxResult);
343-
mlir::Value newArg = func.front().insertArgument(0u, argTy, loc);
342+
func.insertArgument(0u, argTy, {}, loc);
343+
func.eraseResult(0u);
344+
mlir::Value newArg = func.getArgument(0u);
344345
if (mustEmboxResult(resultType, shouldBoxResult)) {
345346
auto bufferType = fir::ReferenceType::get(resultType);
346347
rewriter.setInsertionPointToStart(&func.front());
@@ -349,6 +350,10 @@ class AbstractResultOnFuncOpt
349350
patterns.insert<ReturnOpConversion>(context, newArg);
350351
target.addDynamicallyLegalOp<mlir::func::ReturnOp>(
351352
[](mlir::func::ReturnOp ret) { return ret.operands().empty(); });
353+
assert(func.getFunctionType() ==
354+
getNewFunctionType(funcTy, shouldBoxResult));
355+
} else {
356+
func.setType(getNewFunctionType(funcTy, shouldBoxResult));
352357
}
353358
}
354359
}

flang/test/Fir/abstract-result-2.fir

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
// RUN: fir-opt %s --abstract-result-on-func-opt | FileCheck %s
2+
3+
// Check that the attributes are shifted along with their corresponding arguments
4+
5+
//CHECK: func.func @_QMi8Pintrinsic_pack0(%arg0: !fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>, %arg1: !fir.box<!fir.array<?x?x?xi32>> {fir.bindc_name = "array"}, %arg2: !fir.ref<!fir.logical<4>> {fir.bindc_name = "mask"}, %arg3: !fir.box<!fir.array<?xi32>> {fir.bindc_name = "vector", fir.optional})
6+
7+
func.func @_QMi8Pintrinsic_pack0(%arg0: !fir.box<!fir.array<?x?x?xi32>> {fir.bindc_name = "array"}, %arg1: !fir.ref<!fir.logical<4>> {fir.bindc_name = "mask"}, %arg2: !fir.box<!fir.array<?xi32>> {fir.bindc_name = "vector", fir.optional}) -> !fir.box<!fir.heap<!fir.array<?xi32>>> {
8+
%0 = fir.alloca !fir.box<!fir.heap<!fir.array<?xi32>>>
9+
%1 = fir.alloca !fir.box<!fir.heap<!fir.array<?xi32>>> {bindc_name = "intrinsic_pack0", uniq_name = "_QMi8Fintrinsic_pack0Eintrinsic_pack0"}
10+
%2 = fir.zero_bits !fir.heap<!fir.array<?xi32>>
11+
%c0 = arith.constant 0 : index
12+
%3 = fir.shape %c0 : (index) -> !fir.shape<1>
13+
%4 = fir.embox %2(%3) : (!fir.heap<!fir.array<?xi32>>, !fir.shape<1>) -> !fir.box<!fir.heap<!fir.array<?xi32>>>
14+
fir.store %4 to %1 : !fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>
15+
%5 = fir.embox %arg1 : (!fir.ref<!fir.logical<4>>) -> !fir.box<!fir.logical<4>>
16+
%6 = fir.zero_bits !fir.heap<!fir.array<?xi32>>
17+
%7 = fir.embox %6(%3) : (!fir.heap<!fir.array<?xi32>>, !fir.shape<1>) -> !fir.box<!fir.heap<!fir.array<?xi32>>>
18+
fir.store %7 to %0 : !fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>
19+
%8 = fir.convert %0 : (!fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>) -> !fir.ref<!fir.box<none>>
20+
%9 = fir.convert %arg0 : (!fir.box<!fir.array<?x?x?xi32>>) -> !fir.box<none>
21+
%10 = fir.convert %5 : (!fir.box<!fir.logical<4>>) -> !fir.box<none>
22+
%11 = fir.convert %arg2 : (!fir.box<!fir.array<?xi32>>) -> !fir.box<none>
23+
%12 = fir.call @_FortranAPack(%8, %9, %10, %11) : (!fir.ref<!fir.box<none>>, !fir.box<none>, !fir.box<none>, !fir.box<none>) -> none
24+
%13 = fir.load %1 : !fir.ref<!fir.box<!fir.heap<!fir.array<?xi32>>>>
25+
return %13 : !fir.box<!fir.heap<!fir.array<?xi32>>>
26+
}
27+
func.func private @_FortranAPack(!fir.ref<!fir.box<none>>, !fir.box<none>, !fir.box<none>, !fir.box<none>) -> none attributes {fir.runtime}

0 commit comments

Comments
 (0)