MLIR 23.0.0git
Transform.h
Go to the documentation of this file.
1//===-- mlir-c/Dialect/Transform.h - C API for Transform Dialect --*- C -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM
4// Exceptions.
5// See https://llvm.org/LICENSE.txt for license information.
6// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef MLIR_C_DIALECT_TRANSFORM_H
11#define MLIR_C_DIALECT_TRANSFORM_H
12
13#include "mlir-c/IR.h"
14#include "mlir-c/Interfaces.h"
15#include "mlir-c/Rewrite.h"
16#include "mlir-c/Support.h"
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
23
24#define DEFINE_C_API_STRUCT(name, storage) \
25 struct name { \
26 storage *ptr; \
27 }; \
28 typedef struct name name
29
30DEFINE_C_API_STRUCT(MlirTransformResults, void);
31DEFINE_C_API_STRUCT(MlirTransformRewriter, void);
32DEFINE_C_API_STRUCT(MlirTransformState, void);
33
34#undef DEFINE_C_API_STRUCT
35
36//===---------------------------------------------------------------------===//
37// DiagnosedSilenceableFailure
38//===---------------------------------------------------------------------===//
39
40/// Enum representing the result of a transform operation.
41typedef enum {
42 /// The operation succeeded.
44 /// The operation failed in a silenceable way.
46 /// The operation failed definitively.
49
50//===---------------------------------------------------------------------===//
51// AnyOpType
52//===---------------------------------------------------------------------===//
53
55
57
58MLIR_CAPI_EXPORTED MlirType mlirTransformAnyOpTypeGet(MlirContext ctx);
59
61
62//===---------------------------------------------------------------------===//
63// AnyParamType
64//===---------------------------------------------------------------------===//
65
67
69
70MLIR_CAPI_EXPORTED MlirType mlirTransformAnyParamTypeGet(MlirContext ctx);
71
73
74//===---------------------------------------------------------------------===//
75// AnyValueType
76//===---------------------------------------------------------------------===//
77
79
81
82MLIR_CAPI_EXPORTED MlirType mlirTransformAnyValueTypeGet(MlirContext ctx);
83
85
86//===---------------------------------------------------------------------===//
87// OperationType
88//===---------------------------------------------------------------------===//
89
91
93
94MLIR_CAPI_EXPORTED MlirType
95mlirTransformOperationTypeGet(MlirContext ctx, MlirStringRef operationName);
96
98
101
102//===---------------------------------------------------------------------===//
103// ParamType
104//===---------------------------------------------------------------------===//
105
107
109
110MLIR_CAPI_EXPORTED MlirType mlirTransformParamTypeGet(MlirContext ctx,
111 MlirType type);
112
114
116
117//===---------------------------------------------------------------------===//
118// TransformRewriter
119//===---------------------------------------------------------------------===//
120
121/// Cast the TransformRewriter to a RewriterBase
123mlirTransformRewriterAsBase(MlirTransformRewriter rewriter);
124
125//===---------------------------------------------------------------------===//
126// TransformResults
127//===---------------------------------------------------------------------===//
128
129/// Set the payload operations for a transform result by iterating over a list.
130MLIR_CAPI_EXPORTED void mlirTransformResultsSetOps(MlirTransformResults results,
131 MlirValue result,
132 intptr_t numOps,
133 MlirOperation *ops);
134
135/// Set the payload values for a transform result by iterating over a list.
137mlirTransformResultsSetValues(MlirTransformResults results, MlirValue result,
138 intptr_t numValues, MlirValue *values);
139
140/// Set the parameters for a transform result by iterating over a list.
142mlirTransformResultsSetParams(MlirTransformResults results, MlirValue result,
143 intptr_t numParams, MlirAttribute *params);
144
145//===---------------------------------------------------------------------===//
146// TransformState
147//===---------------------------------------------------------------------===//
148
149/// Callback for iterating over payload operations.
150typedef void (*MlirOperationCallback)(MlirOperation, void *userData);
151
152/// Iterate over payload operations associated with the transform IR value.
153/// Calls the callback for each payload operation.
155mlirTransformStateForEachPayloadOp(MlirTransformState state, MlirValue value,
156 MlirOperationCallback callback,
157 void *userData);
158
159/// Callback for iterating over payload values.
160typedef void (*MlirValueCallback)(MlirValue, void *userData);
161
162/// Iterate over payload values associated with the transform IR value.
163/// Calls the callback for each payload value.
165mlirTransformStateForEachPayloadValue(MlirTransformState state, MlirValue value,
166 MlirValueCallback callback,
167 void *userData);
168
169/// Callback for iterating over parameters.
170typedef void (*MlirAttributeCallback)(MlirAttribute, void *userData);
171
172/// Iterate over parameters associated with the transform IR value.
173/// Calls the callback for each parameter.
175mlirTransformStateForEachParam(MlirTransformState state, MlirValue value,
176 MlirAttributeCallback callback, void *userData);
177
178//===---------------------------------------------------------------------===//
179// TransformOpInterface
180//===---------------------------------------------------------------------===//
181
182/// Returns the interface TypeID of the TransformOpInterface.
184
185/// Callbacks for implementing TransformOpInterface from external code.
186typedef struct {
187 /// Optional constructor for the user data.
188 /// Set to nullptr to disable it.
190 /// Optional destructor for the user data.
191 /// Set to nullptr to disable it.
193 /// Apply callback that implements the transformation.
195 MlirTransformRewriter rewriter,
196 MlirTransformResults results,
197 MlirTransformState state,
198 void *userData);
199 /// Callback to check if repeated handle operands are allowed.
200 bool (*allowsRepeatedHandleOperands)(MlirOperation op, void *userData);
201 void *userData;
203
204/// Attach TransformOpInterface to the operation with the given name using
205/// the provided callbacks.
207 MlirContext ctx, MlirStringRef opName,
209
210//===---------------------------------------------------------------------===//
211// Transform-specifc MemoryEffectsOpInterface helpers
212//===---------------------------------------------------------------------===//
213
214/// Helper to mark operands as only reading handles.
216mlirTransformOnlyReadsHandle(MlirOpOperand *operands, intptr_t numOperands,
217 MlirMemoryEffectInstancesList effects);
218
219/// Helper to mark operands as consuming handles.
221mlirTransformConsumesHandle(MlirOpOperand *operands, intptr_t numOperands,
222 MlirMemoryEffectInstancesList effects);
223
224/// Helper to mark results as producing handles.
226mlirTransformProducesHandle(MlirValue *results, intptr_t numResults,
227 MlirMemoryEffectInstancesList effects);
228
229/// Helper to mark potential modifications to the payload IR.
231mlirTransformModifiesPayload(MlirMemoryEffectInstancesList effects);
232
233/// Helper to mark potential reads from the payload IR.
235mlirTransformOnlyReadsPayload(MlirMemoryEffectInstancesList effects);
236
237#ifdef __cplusplus
238}
239#endif
240
241#include "mlir/Dialect/Transform/Transforms/Passes.capi.h.inc"
242
243#endif // MLIR_C_DIALECT_TRANSFORM_H
MLIR_CAPI_EXPORTED MlirType mlirTransformAnyOpTypeGet(MlirContext ctx)
Definition Transform.cpp:37
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformAnyParamTypeGetTypeID(void)
Definition Transform.cpp:53
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformOpInterfaceTypeID(void)
Returns the interface TypeID of the TransformOpInterface.
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformParamTypeGetName(void)
MLIR_CAPI_EXPORTED bool mlirTypeIsATransformAnyValueType(MlirType type)
Definition Transform.cpp:69
MLIR_CAPI_EXPORTED void mlirTransformModifiesPayload(MlirMemoryEffectInstancesList effects)
Helper to mark potential modifications to the payload IR.
MLIR_CAPI_EXPORTED void mlirTransformResultsSetParams(MlirTransformResults results, MlirValue result, intptr_t numParams, MlirAttribute *params)
Set the parameters for a transform result by iterating over a list.
MLIR_CAPI_EXPORTED bool mlirTypeIsATransformOperationType(MlirType type)
Definition Transform.cpp:89
MLIR_CAPI_EXPORTED void mlirTransformOnlyReadsHandle(MlirOpOperand *operands, intptr_t numOperands, MlirMemoryEffectInstancesList effects)
Helper to mark operands as only reading handles.
MLIR_CAPI_EXPORTED void mlirTransformStateForEachParam(MlirTransformState state, MlirValue value, MlirAttributeCallback callback, void *userData)
Iterate over parameters associated with the transform IR value.
MLIR_CAPI_EXPORTED bool mlirTypeIsATransformAnyParamType(MlirType type)
Definition Transform.cpp:49
void(* MlirOperationCallback)(MlirOperation, void *userData)
Callback for iterating over payload operations.
Definition Transform.h:150
MLIR_CAPI_EXPORTED void mlirTransformResultsSetOps(MlirTransformResults results, MlirValue result, intptr_t numOps, MlirOperation *ops)
Set the payload operations for a transform result by iterating over a list.
#define DEFINE_C_API_STRUCT(name, storage)
Definition Transform.h:24
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformAnyValueTypeGetTypeID(void)
Definition Transform.cpp:73
MLIR_CAPI_EXPORTED void mlirTransformStateForEachPayloadValue(MlirTransformState state, MlirValue value, MlirValueCallback callback, void *userData)
Iterate over payload values associated with the transform IR value.
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformParamTypeGetTypeID(void)
MLIR_CAPI_EXPORTED bool mlirTypeIsATransformAnyOpType(MlirType type)
MLIR_CAPI_EXPORTED MlirType mlirTransformOperationTypeGet(MlirContext ctx, MlirStringRef operationName)
Definition Transform.cpp:97
MLIR_CAPI_EXPORTED MlirRewriterBase mlirTransformRewriterAsBase(MlirTransformRewriter rewriter)
Cast the TransformRewriter to a RewriterBase.
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformOperationTypeGetName(void)
MLIR_CAPI_EXPORTED void mlirTransformStateForEachPayloadOp(MlirTransformState state, MlirValue value, MlirOperationCallback callback, void *userData)
Iterate over payload operations associated with the transform IR value.
MLIR_CAPI_EXPORTED bool mlirTypeIsATransformParamType(MlirType type)
MLIR_CAPI_EXPORTED MlirType mlirTransformParamTypeGet(MlirContext ctx, MlirType type)
MlirDiagnosedSilenceableFailure
Enum representing the result of a transform operation.
Definition Transform.h:41
@ MlirDiagnosedSilenceableFailureSuccess
The operation succeeded.
Definition Transform.h:43
@ MlirDiagnosedSilenceableFailureDefiniteFailure
The operation failed definitively.
Definition Transform.h:47
@ MlirDiagnosedSilenceableFailureSilenceableFailure
The operation failed in a silenceable way.
Definition Transform.h:45
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformOperationTypeGetTypeID(void)
Definition Transform.cpp:93
MLIR_CAPI_EXPORTED void mlirTransformProducesHandle(MlirValue *results, intptr_t numResults, MlirMemoryEffectInstancesList effects)
Helper to mark results as producing handles.
void(* MlirValueCallback)(MlirValue, void *userData)
Callback for iterating over payload values.
Definition Transform.h:160
MLIR_CAPI_EXPORTED void mlirTransformOpInterfaceAttachFallbackModel(MlirContext ctx, MlirStringRef opName, MlirTransformOpInterfaceCallbacks callbacks)
Attach TransformOpInterface to the operation with the given name using the provided callbacks.
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformAnyValueTypeGetName(void)
Definition Transform.cpp:81
MLIR_CAPI_EXPORTED void mlirTransformResultsSetValues(MlirTransformResults results, MlirValue result, intptr_t numValues, MlirValue *values)
Set the payload values for a transform result by iterating over a list.
void(* MlirAttributeCallback)(MlirAttribute, void *userData)
Callback for iterating over parameters.
Definition Transform.h:170
MLIR_CAPI_EXPORTED MlirType mlirTransformAnyValueTypeGet(MlirContext ctx)
Definition Transform.cpp:77
MLIR_CAPI_EXPORTED MlirType mlirTransformAnyParamTypeGet(MlirContext ctx)
Definition Transform.cpp:57
MLIR_CAPI_EXPORTED MlirType mlirTransformParamTypeGetType(MlirType type)
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformOperationTypeGetOperationName(MlirType type)
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformAnyOpTypeGetName(void)
Definition Transform.cpp:41
MLIR_CAPI_EXPORTED void mlirTransformOnlyReadsPayload(MlirMemoryEffectInstancesList effects)
Helper to mark potential reads from the payload IR.
MLIR_CAPI_EXPORTED void mlirTransformConsumesHandle(MlirOpOperand *operands, intptr_t numOperands, MlirMemoryEffectInstancesList effects)
Helper to mark operands as consuming handles.
MLIR_CAPI_EXPORTED MlirStringRef mlirTransformAnyParamTypeGetName(void)
Definition Transform.cpp:61
MLIR_CAPI_EXPORTED MlirTypeID mlirTransformAnyOpTypeGetTypeID(void)
Definition Transform.cpp:33
#define MLIR_DECLARE_CAPI_DIALECT_REGISTRATION(Name, Namespace)
Definition IR.h:215
#define MLIR_CAPI_EXPORTED
Definition Support.h:46
A pointer to a sized fragment of a string, not necessarily null-terminated.
Definition Support.h:78
Callbacks for implementing TransformOpInterface from external code.
Definition Transform.h:186
MlirDiagnosedSilenceableFailure(* apply)(MlirOperation op, MlirTransformRewriter rewriter, MlirTransformResults results, MlirTransformState state, void *userData)
Apply callback that implements the transformation.
Definition Transform.h:194
void(* destruct)(void *userData)
Optional destructor for the user data.
Definition Transform.h:192
void(* construct)(void *userData)
Optional constructor for the user data.
Definition Transform.h:189
bool(* allowsRepeatedHandleOperands)(MlirOperation op, void *userData)
Callback to check if repeated handle operands are allowed.
Definition Transform.h:200