[flang-commits] [PATCH] D151428: [flang][hlfir] address post-commit comments from D151247 and D151251
Jean Perier via Phabricator via flang-commits
flang-commits at lists.llvm.org
Thu May 25 07:35:24 PDT 2023
This revision was automatically updated to reflect the committed changes.
jeanPerier marked an inline comment as done.
Closed by commit rGb361e1c02538: [flang][hlfir] address post-commit comments from D151247 and D151251 (authored by jeanPerier).
Changed prior to commit:
https://reviews.llvm.org/D151428?vs=525546&id=525599#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D151428/new/
https://reviews.llvm.org/D151428
Files:
flang/lib/Optimizer/Builder/TemporaryStorage.cpp
flang/lib/Optimizer/HLFIR/Transforms/LowerHLFIROrderedAssignments.cpp
flang/test/HLFIR/order_assignments/impure-where.fir
Index: flang/test/HLFIR/order_assignments/impure-where.fir
===================================================================
--- flang/test/HLFIR/order_assignments/impure-where.fir
+++ flang/test/HLFIR/order_assignments/impure-where.fir
@@ -34,7 +34,8 @@
}
// CHECK-LABEL: func.func @test_elsewhere_impure_mask(
// CHECK: %[[VAL_12:.*]] = fir.call @impure() : () -> !fir.heap<!fir.array<10x!fir.logical<4>>>
-// CHECK: %[[VAL_21:.*]] = fir.allocmem !fir.array<?x!fir.logical<4>>
+// CHECK: %[[VAL_21:.*]] = fir.allocmem !fir.array<?x!fir.logical<4>>, %[[extent:[^ ]*]]
+// CHECK: %[[VAL_22:.*]] = fir.shape %[[extent]] : (index) -> !fir.shape<1>
// CHECK: %[[VAL_23:.*]]:2 = hlfir.declare %[[VAL_21]](%{{.*}}) {uniq_name = ".tmp.forall"}
// CHECK: fir.do_loop
// CHECK: fir.if {{.*}} {
Index: flang/lib/Optimizer/HLFIR/Transforms/LowerHLFIROrderedAssignments.cpp
===================================================================
--- flang/lib/Optimizer/HLFIR/Transforms/LowerHLFIROrderedAssignments.cpp
+++ flang/lib/Optimizer/HLFIR/Transforms/LowerHLFIROrderedAssignments.cpp
@@ -146,7 +146,8 @@
/// Is this an assignment to a vector subscripted entity?
static bool hasVectorSubscriptedLhs(hlfir::RegionAssignOp regionAssignOp);
- /// Are they any leaf region in node that must be saved in the current run?
+ /// Are there any leaf region in the node that must be saved in the current
+ /// run?
bool mustSaveRegionIn(
hlfir::OrderedAssignmentTreeOpInterface node,
llvm::SmallVectorImpl<hlfir::SaveEntity> &saveEntities) const;
@@ -216,7 +217,7 @@
}
/// Can the current loop nest iteration number be computed? For simplicity,
- /// this is true if an only if all the bounds and steps of the fir.do_loop
+ /// this is true if and only if all the bounds and steps of the fir.do_loop
/// nest dominates the outer loop. The argument is filled with the current
/// loop nest on success.
bool currentLoopNestIterationNumberCanBeComputed(
@@ -250,10 +251,10 @@
/// Map of temporary storage to keep track of saved entity once the run
/// that saves them has been lowered. It is kept in-between runs.
llvm::DenseMap<mlir::Region *, fir::factory::TemporaryStorage> savedEntities;
- /// Map holding the value that were saved in the current run and that also
+ /// Map holding the values that were saved in the current run and that also
/// need to be used (because their construct will be visited). It is reset
/// after each run. It avoids having to store and fetch in the temporary
- /// during the same run, which would required the temporary to have different
+ /// during the same run, which would require the temporary to have different
/// fetching and storing counters.
llvm::DenseMap<mlir::Region *, ValueAndCleanUp> savedInCurrentRunBeforeUse;
Index: flang/lib/Optimizer/Builder/TemporaryStorage.cpp
===================================================================
--- flang/lib/Optimizer/Builder/TemporaryStorage.cpp
+++ flang/lib/Optimizer/Builder/TemporaryStorage.cpp
@@ -208,12 +208,22 @@
fir::FirOpBuilder &builder) {
mlir::Value indexValue = counter.getAndIncrementIndex(loc, builder);
fir::runtime::genValueAt(loc, builder, opaquePtr, indexValue, retValueBox);
- /// Dereference the allocatable "retValueBox", and load if trivial scalar
- /// value.
+ // Dereference the allocatable "retValueBox", and load if trivial scalar
+ // value.
mlir::Value result =
hlfir::loadTrivialScalar(loc, builder, hlfir::Entity{retValueBox});
- if (valueStaticType == builder.getI1Type())
- return builder.createConvert(loc, valueStaticType, result);
+ if (valueStaticType != result.getType()) {
+ // Cast back saved simple scalars stored with another type to their original
+ // type (like i1).
+ if (fir::isa_trivial(valueStaticType))
+ return builder.createConvert(loc, valueStaticType, result);
+ // Memory type mismatches (e.g. fir.ref vs fir.heap) or hlfir.expr vs
+ // variable type mismatches are OK, but the base Fortran type must be the
+ // same.
+ assert(hlfir::getFortranElementOrSequenceType(valueStaticType) ==
+ hlfir::getFortranElementOrSequenceType(result.getType()) &&
+ "non trivial values must be saved with their original type");
+ }
return result;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D151428.525599.patch
Type: text/x-patch
Size: 4454 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/flang-commits/attachments/20230525/f7529ef8/attachment-0001.bin>
More information about the flang-commits
mailing list