[Mlir-commits] [mlir] [mlir][ptr] Add the `ptradd` and `type_offset` ops, and `int_space` attr (PR #136434)
Tobias Gysi
llvmlistbot at llvm.org
Mon Apr 21 02:31:52 PDT 2025
================
@@ -11,7 +11,81 @@
include "mlir/Dialect/Ptr/IR/PtrDialect.td"
include "mlir/Dialect/Ptr/IR/PtrAttrDefs.td"
+include "mlir/Dialect/Ptr/IR/PtrEnums.td"
include "mlir/Dialect/Ptr/IR/MemorySpaceInterfaces.td"
+include "mlir/Interfaces/SideEffectInterfaces.td"
+include "mlir/Interfaces/ViewLikeInterface.td"
include "mlir/IR/OpAsmInterface.td"
+//===----------------------------------------------------------------------===//
+// PtrAddOp
+//===----------------------------------------------------------------------===//
+
+def Ptr_PtrAddOp : Pointer_Op<"ptr_add", [
+ Pure, AllTypesMatch<["base", "result"]>, ViewLikeOpInterface
+ ]> {
+ let summary = "Pointer add operation";
+ let description = [{
+ The `ptr_add` operation adds an integer offset to a pointer to produce a new
+ pointer. The input and output pointer types are always the same.
+
+ Example:
+
+ ```mlir
+ %x_off = ptr.ptr_add %x, %off : !ptr.ptr<0>, i32
+ %x_off0 = ptr.ptr_add nusw %x, %off : !ptr.ptr<0>, i32
+ ```
+ }];
+
+ let arguments = (ins
+ Ptr_PtrType:$base,
+ AnySignlessIntegerOrIndex:$offset,
+ DefaultValuedProp<EnumProp<Ptr_PtrAddFlags>, "PtrAddFlags::none">:$flags);
+ let results = (outs Ptr_PtrType:$result);
+ let assemblyFormat = [{
+ ($flags^)? $base `,` $offset attr-dict `:` type($base) `,` type($offset)
+ }];
+ let hasFolder = 1;
+ let extraClassDeclaration = [{
+ /// `ViewLikeOp::getViewSource` method.
+ Value getViewSource() { return getBase(); }
+ }];
+}
+
+//===----------------------------------------------------------------------===//
+// TypeOffsetOp
+//===----------------------------------------------------------------------===//
+
+def Ptr_TypeOffsetOp : Pointer_Op<"type_offset", [Pure]> {
+ let summary = "Type offset operation";
+ let description = [{
+ The `type_offset` operation produces an int or index-typed SSA value
+ equal to a target-specific constant representing the offset of a single
+ element of the given type.
+
+ Example:
+
+ ```mlir
+ // Return the offset between two f32 stored in memory
+ %0 = ptr.type_offset f32 : index
+ // Return the offset between two memref descriptors stored in memory
+ %1 = ptr.type_offset memref<12 x f64> : i32
+ ```
+ }];
+
+ let arguments = (ins TypeAttr:$elementType);
+ let results = (outs AnySignlessIntegerOrIndex:$result);
+ let builders = [
+ OpBuilder<(ins "Type":$elementType)>
+ ];
+ let assemblyFormat = [{
+ $elementType attr-dict `:` type($result)
+ }];
+ let extraClassDeclaration = [{
+ /// Returns the type offset according to `maybeLayout`. If `maybeLayout` is
----------------
gysit wrote:
```suggestion
/// Returns the type offset according to `layout`. If `layout` is
```
nit: this seems to have been renamed?
https://github.com/llvm/llvm-project/pull/136434
More information about the Mlir-commits
mailing list