jeanPerier added a comment.

Thanks for all the updates. This looks functionally correct to me. Since I am 
not very familiar with this kind of analysis and transformation, it would be 
great if another reviewer could give his/her opinion. But otherwise, given this 
solution is well isolated from a code point of view and can be turned and 
on/off easily, I'll be glad to approve it.



================
Comment at: flang/lib/Optimizer/Transforms/StackArrays.cpp:352
+      LLVM_DEBUG(llvm::dbgs()
+                 << "--Allocation is not for an array: skipping\n");
+    }
----------------
I think the early return may be missing here.


================
Comment at: flang/lib/Optimizer/Transforms/StackArrays.cpp:446
+      candidateOps.insert({allocmem, insertionPoint});
+    }
+  }
----------------
nit: MLIR/LLVM coding style do not use `{}` for single line if.


================
Comment at: flang/lib/Optimizer/Transforms/StackArrays.cpp:642
+    rewriter.setInsertionPointAfter(op);
+  else if (mlir::Block *block = insertionPoint.tryGetBlock())
+    rewriter.setInsertionPointToStart(block);
----------------
If this case must succeed when the other failed, it may be better to place it 
in an `else {` and assert that a block was obtained, so that it is certain that 
the insertion point was correctly set when looking at this code.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D140415/new/

https://reviews.llvm.org/D140415

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to