[flang-commits] [flang] [llvm] [mlir] [MLIR][OpenMP] Lowering nontemporal clause to LLVM IR for SIMD directive (PR #118751)
Tom Eccles via flang-commits
flang-commits at lists.llvm.org
Mon Apr 7 03:13:02 PDT 2025
================
@@ -0,0 +1,71 @@
+//===- LowerNontemporal.cpp -------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+//
+// Add nontemporal attributes to load and stores of variables marked as
+// nontemporal.
+//
+//===----------------------------------------------------------------------===//
+#include "flang/Optimizer/Dialect/FIROpsSupport.h"
+#include "flang/Optimizer/OpenMP/Passes.h"
+#include "mlir/Dialect/OpenMP/OpenMPDialect.h"
+using namespace mlir;
+namespace flangomp {
+#define GEN_PASS_DEF_LOWERNONTEMPORALPASS
+#include "flang/Optimizer/OpenMP/Passes.h.inc"
+} // namespace flangomp
+namespace {
+class LowerNontemporalPass
+ : public flangomp::impl::LowerNontemporalPassBase<LowerNontemporalPass> {
+ void addNonTemporalAttr(omp::SimdOp simdOp) {
+ if (!simdOp.getNontemporalVars().empty()) {
+ llvm::SmallVector<mlir::Value> nontemporalOrigVars;
+ mlir::OperandRange nontemporals = simdOp.getNontemporalVars();
----------------
tblah wrote:
nit: Stylistically we generally prefer early returns instead of nesting the whole function like this
```suggestion
if (simdOp.getNontemporalVars().empty())
return;
llvm::SmallVector<mlir::Value> nontemporalOrigVars;
mlir::OperandRange nontemporals = simdOp.getNontemporalVars();
```
https://github.com/llvm/llvm-project/pull/118751
More information about the flang-commits
mailing list