[Mlir-commits] [mlir] [MLIR][OpenMP] Add `omp.private` op (PR #80955)
Kareem Ergawy
llvmlistbot at llvm.org
Thu Feb 8 02:18:27 PST 2024
================
@@ -133,6 +134,84 @@ def DeclareTargetAttr : OpenMP_Attr<"DeclareTarget", "declaretarget"> {
let assemblyFormat = "`<` struct(params) `>`";
}
+//===----------------------------------------------------------------------===//
+// 2.19.4 Data-Sharing Attribute Clauses
+//===----------------------------------------------------------------------===//
+
+def PrivateClauseOp : OpenMP_Op<"private", [
+ IsolatedFromAbove, FunctionOpInterface
+ ]> {
+ let summary = "Outline [first]private logic in a separate op.";
+ let description = [{
+ Using this operation, the dialect can model the data-sharing attributes of
+ `private` and `firstprivate` variables on the IR level. This means that of
+ "eagerly" privatizing variables in the frontend, we can instead model which
+ variables should be privatized and only materialze the privatization when
+ necessary; e.g. directly before lowring to LLVM IR.
+
+ Examples:
+ ---------
+ * `private(x)` would be emitted as:
+ ```mlir
+ omp.private @x.privatizer : (!fir.ref<i32>) -> !fir.ref<i32> {
+ ^bb0(%arg0: !fir.ref<i32>):
+ %0 = fir.alloca i32
+ omp.yield(%0 : !fir.ref<i32>)
+ }
+ ```
+
+ * `firstprivate(x)` would be emitted as:
+ ```mlir
+ omp.private @x.privatizer : (!fir.ref<i32>) -> !fir.ref<i32> {
+ ^bb0(%arg0: !fir.ref<i32>):
+ %0 = fir.alloca i32
+ %1 = fir.load %arg0 : !fir.ref<i32>
+ fir.store %1 to %0 : !fir.ref<i32>
+ omp.yield(%0 : !fir.ref<i32>)
+ }
+ ```
----------------
ergawy wrote:
Updated the syntax of the op. Thanks again for helping out with this.
https://github.com/llvm/llvm-project/pull/80955
More information about the Mlir-commits
mailing list