[Mlir-commits] [mlir] [mlir][EmitC] Expand the MemRefToEmitC pass - Lowering `CopyOp` (PR #151206)
Gil Rapaport
llvmlistbot at llvm.org
Thu Jul 31 07:37:17 PDT 2025
================
@@ -97,6 +97,29 @@ Type convertMemRefType(MemRefType opTy, const TypeConverter *typeConverter) {
return resultTy;
}
+Value calculateMemrefTotalSizeBytes(Location loc, MemRefType memrefType,
+ ConversionPatternRewriter &rewriter) {
+ emitc::CallOpaqueOp elementSize = rewriter.create<emitc::CallOpaqueOp>(
+ loc, emitc::SizeTType::get(rewriter.getContext()),
+ rewriter.getStringAttr("sizeof"), ValueRange{},
+ ArrayAttr::get(rewriter.getContext(),
+ {TypeAttr::get(memrefType.getElementType())}));
+
+ IndexType indexType = rewriter.getIndexType();
+ int64_t numElements = 1;
+ for (int64_t dimSize : memrefType.getShape()) {
+ numElements *= dimSize;
+ }
+ emitc::ConstantOp numElementsValue = rewriter.create<emitc::ConstantOp>(
+ loc, indexType, rewriter.getIndexAttr(numElements));
+
+ Type sizeTType = emitc::SizeTType::get(rewriter.getContext());
+ emitc::MulOp totalSizeBytes = rewriter.create<emitc::MulOp>(
+ loc, sizeTType, elementSize.getResult(0), numElementsValue);
+
+ return totalSizeBytes.getResult();
+}
+
----------------
aniragil wrote:
+1
As this code is now a function that may be called from various places it should `assert` that this memref obeys the supported-by-emitc constraints.
https://github.com/llvm/llvm-project/pull/151206
More information about the Mlir-commits
mailing list