|
MLIR 22.0.0git
|
Go to the source code of this file.
Classes | |
| struct | MlirNamedAttribute |
| Named MLIR attribute. More... | |
| struct | MlirDialectHandle |
Macros | |
| #define | DEFINE_C_API_STRUCT(name, storage) |
| Opaque type declarations. | |
| #define | MLIR_DECLARE_CAPI_DIALECT_REGISTRATION(Name, Namespace) |
Typedefs | |
| typedef struct MlirNamedAttribute | MlirNamedAttribute |
| typedef struct MlirDialectHandle | MlirDialectHandle |
| typedef enum MlirWalkResult | MlirWalkResult |
| Operation walk result. | |
| typedef enum MlirWalkOrder | MlirWalkOrder |
| Traversal order for operation walk. | |
| typedef MlirWalkResult(* | MlirOperationWalkCallback) (MlirOperation, void *userData) |
| Operation walker type. | |
Enumerations | |
| enum | MlirWalkResult { MlirWalkResultAdvance , MlirWalkResultInterrupt , MlirWalkResultSkip } |
| Operation walk result. More... | |
| enum | MlirWalkOrder { MlirWalkPreOrder , MlirWalkPostOrder } |
| Traversal order for operation walk. More... | |
Functions | |
| DEFINE_C_API_STRUCT (MlirAsmState, void) | |
| DEFINE_C_API_STRUCT (MlirBytecodeWriterConfig, void) | |
| DEFINE_C_API_STRUCT (MlirContext, void) | |
| DEFINE_C_API_STRUCT (MlirDialect, void) | |
| DEFINE_C_API_STRUCT (MlirDialectRegistry, void) | |
| DEFINE_C_API_STRUCT (MlirOperation, void) | |
| DEFINE_C_API_STRUCT (MlirOpOperand, void) | |
| DEFINE_C_API_STRUCT (MlirOpPrintingFlags, void) | |
| DEFINE_C_API_STRUCT (MlirBlock, void) | |
| DEFINE_C_API_STRUCT (MlirRegion, void) | |
| DEFINE_C_API_STRUCT (MlirSymbolTable, void) | |
| DEFINE_C_API_STRUCT (MlirAttribute, const void) | |
| DEFINE_C_API_STRUCT (MlirIdentifier, const void) | |
| DEFINE_C_API_STRUCT (MlirLocation, const void) | |
| DEFINE_C_API_STRUCT (MlirModule, const void) | |
| DEFINE_C_API_STRUCT (MlirType, const void) | |
| DEFINE_C_API_STRUCT (MlirValue, const void) | |
| MLIR_CAPI_EXPORTED MlirContext | mlirContextCreate (void) |
| Creates an MLIR context and transfers its ownership to the caller. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirContextCreateWithThreading (bool threadingEnabled) |
| Creates an MLIR context with an explicit setting of the multithreading setting and transfers its ownership to the caller. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirContextCreateWithRegistry (MlirDialectRegistry registry, bool threadingEnabled) |
| Creates an MLIR context, setting the multithreading setting explicitly and pre-loading the dialects from the provided DialectRegistry. | |
| MLIR_CAPI_EXPORTED bool | mlirContextEqual (MlirContext ctx1, MlirContext ctx2) |
| Checks if two contexts are equal. | |
| static bool | mlirContextIsNull (MlirContext context) |
| Checks whether a context is null. | |
| MLIR_CAPI_EXPORTED void | mlirContextDestroy (MlirContext context) |
| Takes an MLIR context owned by the caller and destroys it. | |
| MLIR_CAPI_EXPORTED void | mlirContextSetAllowUnregisteredDialects (MlirContext context, bool allow) |
| Sets whether unregistered dialects are allowed in this context. | |
| MLIR_CAPI_EXPORTED bool | mlirContextGetAllowUnregisteredDialects (MlirContext context) |
| Returns whether the context allows unregistered dialects. | |
| MLIR_CAPI_EXPORTED intptr_t | mlirContextGetNumRegisteredDialects (MlirContext context) |
| Returns the number of dialects registered with the given context. | |
| MLIR_CAPI_EXPORTED void | mlirContextAppendDialectRegistry (MlirContext ctx, MlirDialectRegistry registry) |
| Append the contents of the given dialect registry to the registry associated with the context. | |
| MLIR_CAPI_EXPORTED intptr_t | mlirContextGetNumLoadedDialects (MlirContext context) |
| Returns the number of dialects loaded by the context. | |
| MLIR_CAPI_EXPORTED MlirDialect | mlirContextGetOrLoadDialect (MlirContext context, MlirStringRef name) |
| Gets the dialect instance owned by the given context using the dialect namespace to identify it, loads (i.e., constructs the instance of) the dialect if necessary. | |
| MLIR_CAPI_EXPORTED void | mlirContextEnableMultithreading (MlirContext context, bool enable) |
| Set threading mode (must be set to false to mlir-print-ir-after-all). | |
| MLIR_CAPI_EXPORTED void | mlirContextLoadAllAvailableDialects (MlirContext context) |
| Eagerly loads all available dialects registered with a context, making them available for use for IR construction. | |
| MLIR_CAPI_EXPORTED bool | mlirContextIsRegisteredOperation (MlirContext context, MlirStringRef name) |
| Returns whether the given fully-qualified operation (i.e. | |
| MLIR_CAPI_EXPORTED void | mlirContextSetThreadPool (MlirContext context, MlirLlvmThreadPool threadPool) |
| Sets the thread pool of the context explicitly, enabling multithreading in the process. | |
| MLIR_CAPI_EXPORTED unsigned | mlirContextGetNumThreads (MlirContext context) |
| Gets the number of threads of the thread pool of the context when multithreading is enabled. | |
| MLIR_CAPI_EXPORTED MlirLlvmThreadPool | mlirContextGetThreadPool (MlirContext context) |
| Gets the thread pool of the context when enabled multithreading, otherwise an assertion is raised. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirDialectGetContext (MlirDialect dialect) |
| Returns the context that owns the dialect. | |
| static bool | mlirDialectIsNull (MlirDialect dialect) |
| Checks if the dialect is null. | |
| MLIR_CAPI_EXPORTED bool | mlirDialectEqual (MlirDialect dialect1, MlirDialect dialect2) |
| Checks if two dialects that belong to the same context are equal. | |
| MLIR_CAPI_EXPORTED MlirStringRef | mlirDialectGetNamespace (MlirDialect dialect) |
| Returns the namespace of the given dialect. | |
| MLIR_CAPI_EXPORTED MlirStringRef | mlirDialectHandleGetNamespace (MlirDialectHandle) |
| Returns the namespace associated with the provided dialect handle. | |
| MLIR_CAPI_EXPORTED void | mlirDialectHandleInsertDialect (MlirDialectHandle, MlirDialectRegistry) |
| Inserts the dialect associated with the provided dialect handle into the provided dialect registry. | |
| MLIR_CAPI_EXPORTED void | mlirDialectHandleRegisterDialect (MlirDialectHandle, MlirContext) |
| Registers the dialect associated with the provided dialect handle. | |
| MLIR_CAPI_EXPORTED MlirDialect | mlirDialectHandleLoadDialect (MlirDialectHandle, MlirContext) |
| Loads the dialect associated with the provided dialect handle. | |
| MLIR_CAPI_EXPORTED MlirDialectRegistry | mlirDialectRegistryCreate (void) |
| Creates a dialect registry and transfers its ownership to the caller. | |
| static bool | mlirDialectRegistryIsNull (MlirDialectRegistry registry) |
| Checks if the dialect registry is null. | |
| MLIR_CAPI_EXPORTED void | mlirDialectRegistryDestroy (MlirDialectRegistry registry) |
| Takes a dialect registry owned by the caller and destroys it. | |
| MLIR_CAPI_EXPORTED MlirAttribute | mlirLocationGetAttribute (MlirLocation location) |
| Returns the underlying location attribute of this location. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationFromAttribute (MlirAttribute attribute) |
| Creates a location from a location attribute. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationFileLineColGet (MlirContext context, MlirStringRef filename, unsigned line, unsigned col) |
| Creates an File/Line/Column location owned by the given context. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationFileLineColRangeGet (MlirContext context, MlirStringRef filename, unsigned start_line, unsigned start_col, unsigned end_line, unsigned end_col) |
| Creates an File/Line/Column range location owned by the given context. | |
| MLIR_CAPI_EXPORTED MlirIdentifier | mlirLocationFileLineColRangeGetFilename (MlirLocation location) |
| Getter for filename of FileLineColRange. | |
| MLIR_CAPI_EXPORTED int | mlirLocationFileLineColRangeGetStartLine (MlirLocation location) |
| Getter for start_line of FileLineColRange. | |
| MLIR_CAPI_EXPORTED int | mlirLocationFileLineColRangeGetStartColumn (MlirLocation location) |
| Getter for start_column of FileLineColRange. | |
| MLIR_CAPI_EXPORTED int | mlirLocationFileLineColRangeGetEndLine (MlirLocation location) |
| Getter for end_line of FileLineColRange. | |
| MLIR_CAPI_EXPORTED int | mlirLocationFileLineColRangeGetEndColumn (MlirLocation location) |
| Getter for end_column of FileLineColRange. | |
| MLIR_CAPI_EXPORTED MlirTypeID | mlirLocationFileLineColRangeGetTypeID (void) |
| TypeID Getter for FileLineColRange. | |
| MLIR_CAPI_EXPORTED bool | mlirLocationIsAFileLineColRange (MlirLocation location) |
| Checks whether the given location is an FileLineColRange. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationCallSiteGet (MlirLocation callee, MlirLocation caller) |
| Creates a call site location with a callee and a caller. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationCallSiteGetCallee (MlirLocation location) |
| Getter for callee of CallSite. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationCallSiteGetCaller (MlirLocation location) |
| Getter for caller of CallSite. | |
| MLIR_CAPI_EXPORTED MlirTypeID | mlirLocationCallSiteGetTypeID (void) |
| TypeID Getter for CallSite. | |
| MLIR_CAPI_EXPORTED bool | mlirLocationIsACallSite (MlirLocation location) |
| Checks whether the given location is an CallSite. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationFusedGet (MlirContext ctx, intptr_t nLocations, MlirLocation const *locations, MlirAttribute metadata) |
| Creates a fused location with an array of locations and metadata. | |
| MLIR_CAPI_EXPORTED unsigned | mlirLocationFusedGetNumLocations (MlirLocation location) |
| Getter for number of locations fused together. | |
| MLIR_CAPI_EXPORTED void | mlirLocationFusedGetLocations (MlirLocation location, MlirLocation *locationsCPtr) |
| Getter for locations of Fused. | |
| MLIR_CAPI_EXPORTED MlirAttribute | mlirLocationFusedGetMetadata (MlirLocation location) |
| Getter for metadata of Fused. | |
| MLIR_CAPI_EXPORTED MlirTypeID | mlirLocationFusedGetTypeID (void) |
| TypeID Getter for Fused. | |
| MLIR_CAPI_EXPORTED bool | mlirLocationIsAFused (MlirLocation location) |
| Checks whether the given location is an Fused. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationNameGet (MlirContext context, MlirStringRef name, MlirLocation childLoc) |
| Creates a name location owned by the given context. | |
| MLIR_CAPI_EXPORTED MlirIdentifier | mlirLocationNameGetName (MlirLocation location) |
| Getter for name of Name. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationNameGetChildLoc (MlirLocation location) |
| Getter for childLoc of Name. | |
| MLIR_CAPI_EXPORTED MlirTypeID | mlirLocationNameGetTypeID (void) |
| TypeID Getter for Name. | |
| MLIR_CAPI_EXPORTED bool | mlirLocationIsAName (MlirLocation location) |
| Checks whether the given location is an Name. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirLocationUnknownGet (MlirContext context) |
| Creates a location with unknown position owned by the given context. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirLocationGetContext (MlirLocation location) |
| Gets the context that a location was created with. | |
| static bool | mlirLocationIsNull (MlirLocation location) |
| Checks if the location is null. | |
| MLIR_CAPI_EXPORTED bool | mlirLocationEqual (MlirLocation l1, MlirLocation l2) |
| Checks if two locations are equal. | |
| MLIR_CAPI_EXPORTED void | mlirOperationPrint (MlirOperation op, MlirStringCallback callback, void *userData) |
| Prints a location by sending chunks of the string representation and forwarding userData to callback`. | |
| MLIR_CAPI_EXPORTED void | mlirOperationPrintWithFlags (MlirOperation op, MlirOpPrintingFlags flags, MlirStringCallback callback, void *userData) |
| Same as mlirOperationPrint but accepts flags controlling the printing behavior. | |
| MLIR_CAPI_EXPORTED void | mlirOperationPrintWithState (MlirOperation op, MlirAsmState state, MlirStringCallback callback, void *userData) |
| Same as mlirOperationPrint but accepts AsmState controlling the printing behavior as well as caching computed names. | |
| MLIR_CAPI_EXPORTED void | mlirOperationWriteBytecode (MlirOperation op, MlirStringCallback callback, void *userData) |
| Same as mlirOperationPrint but writing the bytecode format. | |
| MLIR_CAPI_EXPORTED MlirLogicalResult | mlirOperationWriteBytecodeWithConfig (MlirOperation op, MlirBytecodeWriterConfig config, MlirStringCallback callback, void *userData) |
| Same as mlirOperationWriteBytecode but with writer config and returns failure only if desired bytecode could not be honored. | |
| MLIR_CAPI_EXPORTED void | mlirOperationDump (MlirOperation op) |
| Prints an operation to stderr. | |
| MLIR_CAPI_EXPORTED bool | mlirOperationVerify (MlirOperation op) |
| Verify the operation and return true if it passes, false if it fails. | |
| MLIR_CAPI_EXPORTED void | mlirOperationMoveAfter (MlirOperation op, MlirOperation other) |
| Moves the given operation immediately after the other operation in its parent block. | |
| MLIR_CAPI_EXPORTED void | mlirOperationMoveBefore (MlirOperation op, MlirOperation other) |
| Moves the given operation immediately before the other operation in its parent block. | |
| MLIR_CAPI_EXPORTED bool | mlirOperationIsBeforeInBlock (MlirOperation op, MlirOperation other) |
| Given an operation 'other' that is within the same parent block, return whether the current operation is before 'other' in the operation list of the parent block. | |
| MLIR_CAPI_EXPORTED void | mlirOperationWalk (MlirOperation op, MlirOperationWalkCallback callback, void *userData, MlirWalkOrder walkOrder) |
| Walks operation op in walkOrder and calls callback on that operation. | |
| MLIR_CAPI_EXPORTED MlirRegion | mlirRegionCreate (void) |
| Creates a new empty region and transfers ownership to the caller. | |
| MLIR_CAPI_EXPORTED void | mlirRegionDestroy (MlirRegion region) |
| Takes a region owned by the caller and destroys it. | |
| static bool | mlirRegionIsNull (MlirRegion region) |
| Checks whether a region is null. | |
| MLIR_CAPI_EXPORTED bool | mlirRegionEqual (MlirRegion region, MlirRegion other) |
| Checks whether two region handles point to the same region. | |
| MLIR_CAPI_EXPORTED MlirBlock | mlirRegionGetFirstBlock (MlirRegion region) |
| Gets the first block in the region. | |
| MLIR_CAPI_EXPORTED void | mlirRegionAppendOwnedBlock (MlirRegion region, MlirBlock block) |
| Takes a block owned by the caller and appends it to the given region. | |
| MLIR_CAPI_EXPORTED void | mlirRegionInsertOwnedBlock (MlirRegion region, intptr_t pos, MlirBlock block) |
| Takes a block owned by the caller and inserts it at pos to the given region. | |
| MLIR_CAPI_EXPORTED void | mlirRegionInsertOwnedBlockAfter (MlirRegion region, MlirBlock reference, MlirBlock block) |
| Takes a block owned by the caller and inserts it after the (non-owned) reference block in the given region. | |
| MLIR_CAPI_EXPORTED void | mlirRegionInsertOwnedBlockBefore (MlirRegion region, MlirBlock reference, MlirBlock block) |
| Takes a block owned by the caller and inserts it before the (non-owned) reference block in the given region. | |
| MLIR_CAPI_EXPORTED MlirRegion | mlirOperationGetFirstRegion (MlirOperation op) |
| Returns first region attached to the operation. | |
| MLIR_CAPI_EXPORTED MlirRegion | mlirRegionGetNextInOperation (MlirRegion region) |
| Returns the region immediately following the given region in its parent operation. | |
| MLIR_CAPI_EXPORTED void | mlirRegionTakeBody (MlirRegion target, MlirRegion source) |
| Moves the entire content of the source region to the target region. | |
| MLIR_CAPI_EXPORTED MlirBlock | mlirBlockCreate (intptr_t nArgs, MlirType const *args, MlirLocation const *locs) |
| Creates a new empty block with the given argument types and transfers ownership to the caller. | |
| MLIR_CAPI_EXPORTED void | mlirBlockDestroy (MlirBlock block) |
| Takes a block owned by the caller and destroys it. | |
| MLIR_CAPI_EXPORTED void | mlirBlockDetach (MlirBlock block) |
| Detach a block from the owning region and assume ownership. | |
| static bool | mlirBlockIsNull (MlirBlock block) |
| Checks whether a block is null. | |
| MLIR_CAPI_EXPORTED bool | mlirBlockEqual (MlirBlock block, MlirBlock other) |
| Checks whether two blocks handles point to the same block. | |
| MLIR_CAPI_EXPORTED MlirOperation | mlirBlockGetParentOperation (MlirBlock) |
| Returns the closest surrounding operation that contains this block. | |
| MLIR_CAPI_EXPORTED MlirRegion | mlirBlockGetParentRegion (MlirBlock block) |
| Returns the region that contains this block. | |
| MLIR_CAPI_EXPORTED MlirBlock | mlirBlockGetNextInRegion (MlirBlock block) |
| Returns the block immediately following the given block in its parent region. | |
| MLIR_CAPI_EXPORTED MlirOperation | mlirBlockGetFirstOperation (MlirBlock block) |
| Returns the first operation in the block. | |
| MLIR_CAPI_EXPORTED MlirOperation | mlirBlockGetTerminator (MlirBlock block) |
| Returns the terminator operation in the block or null if no terminator. | |
| MLIR_CAPI_EXPORTED void | mlirBlockAppendOwnedOperation (MlirBlock block, MlirOperation operation) |
| Takes an operation owned by the caller and appends it to the block. | |
| MLIR_CAPI_EXPORTED void | mlirBlockInsertOwnedOperation (MlirBlock block, intptr_t pos, MlirOperation operation) |
| Takes an operation owned by the caller and inserts it as pos to the block. | |
| MLIR_CAPI_EXPORTED void | mlirBlockInsertOwnedOperationAfter (MlirBlock block, MlirOperation reference, MlirOperation operation) |
| Takes an operation owned by the caller and inserts it after the (non-owned) reference operation in the given block. | |
| MLIR_CAPI_EXPORTED void | mlirBlockInsertOwnedOperationBefore (MlirBlock block, MlirOperation reference, MlirOperation operation) |
| Takes an operation owned by the caller and inserts it before the (non-owned) reference operation in the given block. | |
| MLIR_CAPI_EXPORTED intptr_t | mlirBlockGetNumArguments (MlirBlock block) |
| Returns the number of arguments of the block. | |
| MLIR_CAPI_EXPORTED MlirValue | mlirBlockAddArgument (MlirBlock block, MlirType type, MlirLocation loc) |
| Appends an argument of the specified type to the block. | |
| MLIR_CAPI_EXPORTED void | mlirBlockEraseArgument (MlirBlock block, unsigned index) |
| Erase the argument at 'index' and remove it from the argument list. | |
| MLIR_CAPI_EXPORTED MlirValue | mlirBlockInsertArgument (MlirBlock block, intptr_t pos, MlirType type, MlirLocation loc) |
| Inserts an argument of the specified type at a specified index to the block. | |
| MLIR_CAPI_EXPORTED MlirValue | mlirBlockGetArgument (MlirBlock block, intptr_t pos) |
| Returns pos-th argument of the block. | |
| MLIR_CAPI_EXPORTED void | mlirValuePrint (MlirValue value, MlirStringCallback callback, void *userData) |
| Prints a block by sending chunks of the string representation and forwarding userData to callback`. | |
| MLIR_CAPI_EXPORTED void | mlirValuePrintAsOperand (MlirValue value, MlirAsmState state, MlirStringCallback callback, void *userData) |
| Prints a value as an operand (i.e., the ValueID). | |
| MLIR_CAPI_EXPORTED MlirOpOperand | mlirValueGetFirstUse (MlirValue value) |
| Returns an op operand representing the first use of the value, or a null op operand if there are no uses. | |
| MLIR_CAPI_EXPORTED void | mlirValueReplaceAllUsesOfWith (MlirValue of, MlirValue with) |
| Replace all uses of 'of' value with the 'with' value, updating anything in the IR that uses 'of' to use the other value instead. | |
| MLIR_CAPI_EXPORTED void | mlirValueReplaceAllUsesExcept (MlirValue of, MlirValue with, intptr_t numExceptions, MlirOperation *exceptions) |
| Replace all uses of 'of' value with 'with' value, updating anything in the IR that uses 'of' to use 'with' instead, except if the user is listed in 'exceptions'. | |
| MLIR_CAPI_EXPORTED MlirLocation | mlirValueGetLocation (MlirValue v) |
| Gets the location of the value. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirValueGetContext (MlirValue v) |
| Gets the context that a value was created with. | |
| MLIR_CAPI_EXPORTED bool | mlirOpOperandIsNull (MlirOpOperand opOperand) |
| Returns whether the op operand is null. | |
| MLIR_CAPI_EXPORTED MlirValue | mlirOpOperandGetValue (MlirOpOperand opOperand) |
| Returns the value of an op operand. | |
| MLIR_CAPI_EXPORTED MlirOperation | mlirOpOperandGetOwner (MlirOpOperand opOperand) |
| Returns the owner operation of an op operand. | |
| MLIR_CAPI_EXPORTED unsigned | mlirOpOperandGetOperandNumber (MlirOpOperand opOperand) |
| Returns the operand number of an op operand. | |
| MLIR_CAPI_EXPORTED MlirOpOperand | mlirOpOperandGetNextUse (MlirOpOperand opOperand) |
| Returns an op operand representing the next use of the value, or a null op operand if there is no next use. | |
| MLIR_CAPI_EXPORTED MlirType | mlirTypeParseGet (MlirContext context, MlirStringRef type) |
| Parses a type. The type is owned by the context. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirTypeGetContext (MlirType type) |
| Gets the context that a type was created with. | |
| MLIR_CAPI_EXPORTED MlirTypeID | mlirTypeGetTypeID (MlirType type) |
| Gets the type ID of the type. | |
| MLIR_CAPI_EXPORTED MlirDialect | mlirTypeGetDialect (MlirType type) |
| Gets the dialect a type belongs to. | |
| static bool | mlirTypeIsNull (MlirType type) |
| Checks whether a type is null. | |
| MLIR_CAPI_EXPORTED bool | mlirTypeEqual (MlirType t1, MlirType t2) |
| Checks if two types are equal. | |
| MLIR_CAPI_EXPORTED void | mlirAttributePrint (MlirAttribute attr, MlirStringCallback callback, void *userData) |
| Prints a location by sending chunks of the string representation and forwarding userData to callback`. | |
| MLIR_CAPI_EXPORTED void | mlirAttributeDump (MlirAttribute attr) |
| Prints the attribute to the standard error stream. | |
| MLIR_CAPI_EXPORTED MlirNamedAttribute | mlirNamedAttributeGet (MlirIdentifier name, MlirAttribute attr) |
| Associates an attribute with the name. Takes ownership of neither. | |
| MLIR_CAPI_EXPORTED MlirIdentifier | mlirIdentifierGet (MlirContext context, MlirStringRef str) |
| Gets an identifier with the given string value. | |
| MLIR_CAPI_EXPORTED MlirContext | mlirIdentifierGetContext (MlirIdentifier) |
| Returns the context associated with this identifier. | |
| MLIR_CAPI_EXPORTED bool | mlirIdentifierEqual (MlirIdentifier ident, MlirIdentifier other) |
| Checks whether two identifiers are the same. | |
| MLIR_CAPI_EXPORTED MlirStringRef | mlirIdentifierStr (MlirIdentifier ident) |
| Gets the string value of the identifier. | |
| MLIR_CAPI_EXPORTED MlirStringRef | mlirSymbolTableGetSymbolAttributeName (void) |
| Returns the name of the attribute used to store symbol names compatible with symbol tables. | |
| MLIR_CAPI_EXPORTED MlirStringRef | mlirSymbolTableGetVisibilityAttributeName (void) |
| Returns the name of the attribute used to store symbol visibility. | |
| MLIR_CAPI_EXPORTED MlirSymbolTable | mlirSymbolTableCreate (MlirOperation operation) |
| Creates a symbol table for the given operation. | |
| static bool | mlirSymbolTableIsNull (MlirSymbolTable symbolTable) |
| Returns true if the symbol table is null. | |
| MLIR_CAPI_EXPORTED void | mlirSymbolTableDestroy (MlirSymbolTable symbolTable) |
| Destroys the symbol table created with mlirSymbolTableCreate. | |
| MLIR_CAPI_EXPORTED MlirOperation | mlirSymbolTableLookup (MlirSymbolTable symbolTable, MlirStringRef name) |
| Looks up a symbol with the given name in the given symbol table and returns the operation that corresponds to the symbol. | |
| MLIR_CAPI_EXPORTED MlirAttribute | mlirSymbolTableInsert (MlirSymbolTable symbolTable, MlirOperation operation) |
| Inserts the given operation into the given symbol table. | |
| MLIR_CAPI_EXPORTED void | mlirSymbolTableErase (MlirSymbolTable symbolTable, MlirOperation operation) |
| Removes the given operation from the symbol table and erases it. | |
| MLIR_CAPI_EXPORTED MlirLogicalResult | mlirSymbolTableReplaceAllSymbolUses (MlirStringRef oldSymbol, MlirStringRef newSymbol, MlirOperation from) |
| Attempt to replace all uses that are nested within the given operation of the given symbol 'oldSymbol' with the provided 'newSymbol'. | |
| MLIR_CAPI_EXPORTED void | mlirSymbolTableWalkSymbolTables (MlirOperation from, bool allSymUsesVisible, void(*callback)(MlirOperation, bool, void *userData), void *userData) |
| Walks all symbol table operations nested within, and including, op. | |
| #define DEFINE_C_API_STRUCT | ( | name, | |
| storage ) |
Opaque type declarations.
Types are exposed to C bindings as structs containing opaque pointers. They are not supposed to be inspected from C. This allows the underlying representation to change without affecting the API users. The use of structs instead of typedefs enables some type safety as structs are not implicitly convertible to each other.
Instances of these types may or may not own the underlying object (most often only point to an IR fragment without owning it). The ownership semantics is defined by how an instance of the type was obtained.
| #define MLIR_DECLARE_CAPI_DIALECT_REGISTRATION | ( | Name, | |
| Namespace ) |
| typedef MlirWalkResult(* MlirOperationWalkCallback) (MlirOperation, void *userData) |
| typedef enum MlirWalkOrder MlirWalkOrder |
Traversal order for operation walk.
| typedef enum MlirWalkResult MlirWalkResult |
Operation walk result.
| enum MlirWalkOrder |
| enum MlirWalkResult |
| DEFINE_C_API_STRUCT | ( | MlirAsmState | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirAttribute | , |
| const void | ) |
| DEFINE_C_API_STRUCT | ( | MlirBlock | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirBytecodeWriterConfig | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirContext | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirDialect | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirDialectRegistry | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirIdentifier | , |
| const void | ) |
| DEFINE_C_API_STRUCT | ( | MlirLocation | , |
| const void | ) |
| DEFINE_C_API_STRUCT | ( | MlirModule | , |
| const void | ) |
| DEFINE_C_API_STRUCT | ( | MlirOperation | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirOpOperand | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirOpPrintingFlags | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirRegion | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirSymbolTable | , |
| void | ) |
| DEFINE_C_API_STRUCT | ( | MlirType | , |
| const void | ) |
| DEFINE_C_API_STRUCT | ( | MlirValue | , |
| const void | ) |
| MLIR_CAPI_EXPORTED void mlirAttributeDump | ( | MlirAttribute | attr | ) |
| MLIR_CAPI_EXPORTED void mlirAttributePrint | ( | MlirAttribute | attr, |
| MlirStringCallback | callback, | ||
| void * | userData ) |
Prints a location by sending chunks of the string representation and forwarding userData to callback`.
Note that the callback may be called / several times with consecutive chunks of the string. MLIR_CAPI_EXPORTED void mlirTypePrint(MlirType type, MlirStringCallback callback, void *userData);
/ Prints the type to the standard error stream. MLIR_CAPI_EXPORTED void mlirTypeDump(MlirType type);
===-------------------------------------------------------------------—===// Attribute API. ===-------------------------------------------------------------------—===//
/ Parses an attribute. The attribute is owned by the context. MLIR_CAPI_EXPORTED MlirAttribute mlirAttributeParseGet(MlirContext context, MlirStringRef attr);
/ Gets the context that an attribute was created with. MLIR_CAPI_EXPORTED MlirContext mlirAttributeGetContext(MlirAttribute attribute);
/ Gets the type of this attribute. MLIR_CAPI_EXPORTED MlirType mlirAttributeGetType(MlirAttribute attribute);
/ Gets the type id of the attribute. MLIR_CAPI_EXPORTED MlirTypeID mlirAttributeGetTypeID(MlirAttribute attribute);
/ Gets the dialect of the attribute. MLIR_CAPI_EXPORTED MlirDialect mlirAttributeGetDialect(MlirAttribute attribute);
/ Checks whether an attribute is null. static inline bool mlirAttributeIsNull(MlirAttribute attr) { return !attr.ptr; }
/ Checks if two attributes are equal. MLIR_CAPI_EXPORTED bool mlirAttributeEqual(MlirAttribute a1, MlirAttribute a2);
/ Prints an attribute by sending chunks of the string representation and / forwarding userData to callback`. Note that the callback may be called several times with consecutive chunks of the string.
Definition at line 1293 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyConcreteAttribute< DerivedTy, BaseTy >::bind().
| MLIR_CAPI_EXPORTED MlirValue mlirBlockAddArgument | ( | MlirBlock | block, |
| MlirType | type, | ||
| MlirLocation | loc ) |
| MLIR_CAPI_EXPORTED void mlirBlockAppendOwnedOperation | ( | MlirBlock | block, |
| MlirOperation | operation ) |
Takes an operation owned by the caller and appends it to the block.
Definition at line 1010 of file IR.cpp.
References unwrap().
Referenced by mlirBlockInsertOwnedOperationBefore().
| MLIR_CAPI_EXPORTED MlirBlock mlirBlockCreate | ( | intptr_t | nArgs, |
| MlirType const * | args, | ||
| MlirLocation const * | locs ) |
| MLIR_CAPI_EXPORTED void mlirBlockDestroy | ( | MlirBlock | block | ) |
| MLIR_CAPI_EXPORTED void mlirBlockDetach | ( | MlirBlock | block | ) |
| MLIR_CAPI_EXPORTED bool mlirBlockEqual | ( | MlirBlock | block, |
| MlirBlock | other ) |
| MLIR_CAPI_EXPORTED void mlirBlockEraseArgument | ( | MlirBlock | block, |
| unsigned | index ) |
| MLIR_CAPI_EXPORTED MlirValue mlirBlockGetArgument | ( | MlirBlock | block, |
| intptr_t | pos ) |
| MLIR_CAPI_EXPORTED MlirOperation mlirBlockGetFirstOperation | ( | MlirBlock | block | ) |
Returns the first operation in the block.
Definition at line 993 of file IR.cpp.
References mlir::Block::empty(), mlir::Block::front(), unwrap(), and wrap().
Referenced by mlir::python::PyInsertionPoint::atBlockBegin().
| MLIR_CAPI_EXPORTED MlirBlock mlirBlockGetNextInRegion | ( | MlirBlock | block | ) |
| MLIR_CAPI_EXPORTED intptr_t mlirBlockGetNumArguments | ( | MlirBlock | block | ) |
| MLIR_CAPI_EXPORTED MlirOperation mlirBlockGetParentOperation | ( | MlirBlock | block | ) |
Returns the closest surrounding operation that contains this block.
Definition at line 981 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyValue::createFromCapsule().
| MLIR_CAPI_EXPORTED MlirRegion mlirBlockGetParentRegion | ( | MlirBlock | block | ) |
| MLIR_CAPI_EXPORTED MlirOperation mlirBlockGetTerminator | ( | MlirBlock | block | ) |
Returns the terminator operation in the block or null if no terminator.
Definition at line 1000 of file IR.cpp.
References mlir::Block::back(), mlir::Block::empty(), mlir::Operation::hasTrait(), unwrap(), and wrap().
Referenced by mlir::python::PyInsertionPoint::atBlockTerminator(), and mlir::python::PyInsertionPoint::insert().
| MLIR_CAPI_EXPORTED MlirValue mlirBlockInsertArgument | ( | MlirBlock | block, |
| intptr_t | pos, | ||
| MlirType | type, | ||
| MlirLocation | loc ) |
| MLIR_CAPI_EXPORTED void mlirBlockInsertOwnedOperation | ( | MlirBlock | block, |
| intptr_t | pos, | ||
| MlirOperation | operation ) |
| MLIR_CAPI_EXPORTED void mlirBlockInsertOwnedOperationAfter | ( | MlirBlock | block, |
| MlirOperation | reference, | ||
| MlirOperation | operation ) |
Takes an operation owned by the caller and inserts it after the (non-owned) reference operation in the given block.
If the reference is null, prepends the operation. Otherwise, the reference must belong to the block.
Definition at line 1020 of file IR.cpp.
References mlir::Block::begin(), mlir::Block::getOperations(), unwrap(), and unwrap().
| MLIR_CAPI_EXPORTED void mlirBlockInsertOwnedOperationBefore | ( | MlirBlock | block, |
| MlirOperation | reference, | ||
| MlirOperation | operation ) |
Takes an operation owned by the caller and inserts it before the (non-owned) reference operation in the given block.
If the reference is null, appends the operation. Otherwise, the reference must belong to the block.
Definition at line 1035 of file IR.cpp.
References mlirBlockAppendOwnedOperation(), and unwrap().
Referenced by mlir::python::PyInsertionPoint::insert().
|
inlinestatic |
Checks whether a block is null.
Definition at line 933 of file IR.h.
Referenced by mlir::python::PyOperation::getBlock(), pybind11::detail::type_caster< MlirBlock >::load(), mlirRegionInsertOwnedBlockAfter(), mlirRegionInsertOwnedBlockBefore(), and mlir::python::PyBlock::PyBlock().
| MLIR_CAPI_EXPORTED void mlirContextAppendDialectRegistry | ( | MlirContext | ctx, |
| MlirDialectRegistry | registry ) |
| MLIR_CAPI_EXPORTED MlirContext mlirContextCreate | ( | void | ) |
| MLIR_CAPI_EXPORTED MlirContext mlirContextCreateWithRegistry | ( | MlirDialectRegistry | registry, |
| bool | threadingEnabled ) |
Creates an MLIR context, setting the multithreading setting explicitly and pre-loading the dialects from the provided DialectRegistry.
Definition at line 60 of file IR.cpp.
References toThreadingEnum(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirContext mlirContextCreateWithThreading | ( | bool | threadingEnabled | ) |
Creates an MLIR context with an explicit setting of the multithreading setting and transfers its ownership to the caller.
Definition at line 55 of file IR.cpp.
References toThreadingEnum(), and wrap().
| MLIR_CAPI_EXPORTED void mlirContextDestroy | ( | MlirContext | context | ) |
Takes an MLIR context owned by the caller and destroys it.
Definition at line 71 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyMlirContext::~PyMlirContext().
| MLIR_CAPI_EXPORTED void mlirContextEnableMultithreading | ( | MlirContext | context, |
| bool | enable ) |
| MLIR_CAPI_EXPORTED bool mlirContextEqual | ( | MlirContext | ctx1, |
| MlirContext | ctx2 ) |
| MLIR_CAPI_EXPORTED bool mlirContextGetAllowUnregisteredDialects | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED intptr_t mlirContextGetNumLoadedDialects | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED intptr_t mlirContextGetNumRegisteredDialects | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED unsigned mlirContextGetNumThreads | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED MlirDialect mlirContextGetOrLoadDialect | ( | MlirContext | context, |
| MlirStringRef | name ) |
Gets the dialect instance owned by the given context using the dialect namespace to identify it, loads (i.e., constructs the instance of) the dialect if necessary.
If the dialect is not registered with the context, returns null. Use mlirContextLoad<Name>Dialect to load an unregistered dialect.
Definition at line 95 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyDialects::getDialectForKey().
| MLIR_CAPI_EXPORTED MlirLlvmThreadPool mlirContextGetThreadPool | ( | MlirContext | context | ) |
|
inlinestatic |
Checks whether a context is null.
Definition at line 104 of file IR.h.
Referenced by mlir::python::PyMlirContext::createFromCapsule(), and pybind11::detail::type_caster< MlirContext >::load().
| MLIR_CAPI_EXPORTED bool mlirContextIsRegisteredOperation | ( | MlirContext | context, |
| MlirStringRef | name ) |
| MLIR_CAPI_EXPORTED void mlirContextLoadAllAvailableDialects | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED void mlirContextSetAllowUnregisteredDialects | ( | MlirContext | context, |
| bool | allow ) |
| MLIR_CAPI_EXPORTED void mlirContextSetThreadPool | ( | MlirContext | context, |
| MlirLlvmThreadPool | threadPool ) |
Sets the thread pool of the context explicitly, enabling multithreading in the process.
This API should be used to avoid re-creating thread pools in long-running applications that perform multiple compilations, see the C++ documentation for MLIRContext for details.
Definition at line 112 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED bool mlirDialectEqual | ( | MlirDialect | dialect1, |
| MlirDialect | dialect2 ) |
| MLIR_CAPI_EXPORTED MlirContext mlirDialectGetContext | ( | MlirDialect | dialect | ) |
Returns the context that owns the dialect.
Definition at line 129 of file IR.cpp.
References getContext(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirStringRef mlirDialectGetNamespace | ( | MlirDialect | dialect | ) |
Returns the namespace of the given dialect.
Definition at line 137 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyGlobals::lookupTypeCaster(), and mlir::python::PyGlobals::lookupValueCaster().
| MLIR_CAPI_EXPORTED MlirStringRef mlirDialectHandleGetNamespace | ( | MlirDialectHandle | handle | ) |
Returns the namespace associated with the provided dialect handle.
Definition at line 16 of file DialectHandle.cpp.
References MlirDialectRegistrationHooks::getNamespaceHook, and unwrap().
| MLIR_CAPI_EXPORTED void mlirDialectHandleInsertDialect | ( | MlirDialectHandle | handle, |
| MlirDialectRegistry | registry ) |
Inserts the dialect associated with the provided dialect handle into the provided dialect registry.
Definition at line 20 of file DialectHandle.cpp.
References MlirDialectRegistrationHooks::insertHook, and unwrap().
Referenced by mlir::ExternalPass::getDependentDialects(), and mlirDialectHandleRegisterDialect().
| MLIR_CAPI_EXPORTED MlirDialect mlirDialectHandleLoadDialect | ( | MlirDialectHandle | handle, |
| MlirContext | ctx ) |
Loads the dialect associated with the provided dialect handle.
Definition at line 32 of file DialectHandle.cpp.
References MlirDialectRegistrationHooks::loadHook, and unwrap().
| MLIR_CAPI_EXPORTED void mlirDialectHandleRegisterDialect | ( | MlirDialectHandle | handle, |
| MlirContext | ctx ) |
Registers the dialect associated with the provided dialect handle.
Definition at line 25 of file DialectHandle.cpp.
References mlirDialectHandleInsertDialect(), unwrap(), and wrap().
|
inlinestatic |
Checks if the dialect is null.
Definition at line 182 of file IR.h.
Referenced by mlir::python::PyDialects::getDialectForKey().
| MLIR_CAPI_EXPORTED MlirDialectRegistry mlirDialectRegistryCreate | ( | void | ) |
Creates a dialect registry and transfers its ownership to the caller.
Definition at line 145 of file IR.cpp.
References wrap().
Referenced by mlir::python::PyDialectRegistry::PyDialectRegistry().
| MLIR_CAPI_EXPORTED void mlirDialectRegistryDestroy | ( | MlirDialectRegistry | registry | ) |
Takes a dialect registry owned by the caller and destroys it.
Definition at line 149 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyDialectRegistry::~PyDialectRegistry().
|
inlinestatic |
Checks if the dialect registry is null.
Definition at line 244 of file IR.h.
Referenced by mlir::python::PyDialectRegistry::createFromCapsule(), pybind11::detail::type_caster< MlirDialectRegistry >::load(), and mlir::python::PyDialectRegistry::~PyDialectRegistry().
| MLIR_CAPI_EXPORTED bool mlirIdentifierEqual | ( | MlirIdentifier | ident, |
| MlirIdentifier | other ) |
| MLIR_CAPI_EXPORTED MlirIdentifier mlirIdentifierGet | ( | MlirContext | context, |
| MlirStringRef | str ) |
Gets an identifier with the given string value.
Definition at line 1310 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyOperation::create(), and mlir::python::PyNamedAttribute::PyNamedAttribute().
| MLIR_CAPI_EXPORTED MlirContext mlirIdentifierGetContext | ( | MlirIdentifier | ident | ) |
Returns the context associated with this identifier.
Definition at line 1314 of file IR.cpp.
References getContext(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirStringRef mlirIdentifierStr | ( | MlirIdentifier | ident | ) |
Gets the string value of the identifier.
Definition at line 1322 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyOperation::createOpView(), getUniqueResult(), and mlir::python::PyConcreteOpInterface< ConcreteIface >::PyConcreteOpInterface().
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationCallSiteGet | ( | MlirLocation | callee, |
| MlirLocation | caller ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationCallSiteGetCallee | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationCallSiteGetCaller | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirTypeID mlirLocationCallSiteGetTypeID | ( | void | ) |
| MLIR_CAPI_EXPORTED bool mlirLocationEqual | ( | MlirLocation | l1, |
| MlirLocation | l2 ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationFileLineColGet | ( | MlirContext | context, |
| MlirStringRef | filename, | ||
| unsigned | line, | ||
| unsigned | col ) |
Creates an File/Line/Column location owned by the given context.
Definition at line 273 of file IR.cpp.
References mlir::FileLineColLoc::get(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationFileLineColRangeGet | ( | MlirContext | context, |
| MlirStringRef | filename, | ||
| unsigned | start_line, | ||
| unsigned | start_col, | ||
| unsigned | end_line, | ||
| unsigned | end_col ) |
| MLIR_CAPI_EXPORTED int mlirLocationFileLineColRangeGetEndColumn | ( | MlirLocation | location | ) |
Getter for end_column of FileLineColRange.
Definition at line 311 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED int mlirLocationFileLineColRangeGetEndLine | ( | MlirLocation | location | ) |
Getter for end_line of FileLineColRange.
Definition at line 305 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED MlirIdentifier mlirLocationFileLineColRangeGetFilename | ( | MlirLocation | location | ) |
Getter for filename of FileLineColRange.
| MLIR_CAPI_EXPORTED int mlirLocationFileLineColRangeGetStartColumn | ( | MlirLocation | location | ) |
Getter for start_column of FileLineColRange.
Definition at line 299 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED int mlirLocationFileLineColRangeGetStartLine | ( | MlirLocation | location | ) |
Getter for start_line of FileLineColRange.
Definition at line 293 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED MlirTypeID mlirLocationFileLineColRangeGetTypeID | ( | void | ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationFromAttribute | ( | MlirAttribute | attribute | ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationFusedGet | ( | MlirContext | ctx, |
| intptr_t | nLocations, | ||
| MlirLocation const * | locations, | ||
| MlirAttribute | metadata ) |
Creates a fused location with an array of locations and metadata.
Definition at line 347 of file IR.cpp.
References unwrap(), unwrapList(), and wrap().
| MLIR_CAPI_EXPORTED void mlirLocationFusedGetLocations | ( | MlirLocation | location, |
| MlirLocation * | locationsCPtr ) |
| MLIR_CAPI_EXPORTED MlirAttribute mlirLocationFusedGetMetadata | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED unsigned mlirLocationFusedGetNumLocations | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirTypeID mlirLocationFusedGetTypeID | ( | void | ) |
| MLIR_CAPI_EXPORTED MlirAttribute mlirLocationGetAttribute | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirContext mlirLocationGetContext | ( | MlirLocation | location | ) |
Gets the context that a location was created with.
Definition at line 411 of file IR.cpp.
References getContext(), unwrap(), and wrap().
Referenced by mlir::python::PyLocation::createFromCapsule(), mlir::python::PyDiagnostic::getLocation(), and populateDialectLLVMSubmodule().
| MLIR_CAPI_EXPORTED bool mlirLocationIsACallSite | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED bool mlirLocationIsAFileLineColRange | ( | MlirLocation | location | ) |
Checks whether the given location is an FileLineColRange.
Definition at line 321 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED bool mlirLocationIsAFused | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED bool mlirLocationIsAName | ( | MlirLocation | location | ) |
|
inlinestatic |
Checks if the location is null.
Definition at line 370 of file IR.h.
Referenced by mlir::python::PyLocation::createFromCapsule(), pybind11::detail::type_caster< MlirLocation >::load(), and mlirLocationNameGet().
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationNameGet | ( | MlirContext | context, |
| MlirStringRef | name, | ||
| MlirLocation | childLoc ) |
Creates a name location owned by the given context.
Providing null location for childLoc is allowed and if childLoc is null location, then the behavior is the same as having unknown child location.
Definition at line 379 of file IR.cpp.
References mlirLocationIsNull(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationNameGetChildLoc | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirIdentifier mlirLocationNameGetName | ( | MlirLocation | location | ) |
| MLIR_CAPI_EXPORTED MlirTypeID mlirLocationNameGetTypeID | ( | void | ) |
| MLIR_CAPI_EXPORTED MlirLocation mlirLocationUnknownGet | ( | MlirContext | context | ) |
| MLIR_CAPI_EXPORTED MlirNamedAttribute mlirNamedAttributeGet | ( | MlirIdentifier | name, |
| MlirAttribute | attr ) |
Associates an attribute with the name. Takes ownership of neither.
Definition at line 1301 of file IR.cpp.
Referenced by mlir::python::PyOperation::create(), and mlir::python::PyNamedAttribute::PyNamedAttribute().
| MLIR_CAPI_EXPORTED void mlirOperationDump | ( | MlirOperation | op | ) |
| MLIR_CAPI_EXPORTED MlirRegion mlirOperationGetFirstRegion | ( | MlirOperation | op | ) |
Returns first region attached to the operation.
Definition at line 689 of file IR.cpp.
References mlir::Operation::getNumRegions(), mlir::Operation::getRegion(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED bool mlirOperationIsBeforeInBlock | ( | MlirOperation | op, |
| MlirOperation | other ) |
Given an operation 'other' that is within the same parent block, return whether the current operation is before 'other' in the operation list of the parent block.
Note: This function has an average complexity of O(1), but worst case may take O(N) where N is the number of operations within the parent block.
Definition at line 869 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyOperationBase::isBeforeInBlock().
| MLIR_CAPI_EXPORTED void mlirOperationMoveAfter | ( | MlirOperation | op, |
| MlirOperation | other ) |
Moves the given operation immediately after the other operation in its parent block.
The given operation may be owned by the caller or by its current block. The other operation must belong to a block. In any case, the ownership is transferred to the block of the other operation.
Definition at line 861 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyOperationBase::moveAfter().
| MLIR_CAPI_EXPORTED void mlirOperationMoveBefore | ( | MlirOperation | op, |
| MlirOperation | other ) |
Moves the given operation immediately before the other operation in its parent block.
The given operation may be owner by the caller or by its current block. The other operation must belong to a block. In any case, the ownership is transferred to the block of the other operation.
Definition at line 865 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyOperationBase::moveBefore().
| MLIR_CAPI_EXPORTED void mlirOperationPrint | ( | MlirOperation | op, |
| MlirStringCallback | callback, | ||
| void * | userData ) |
Prints a location by sending chunks of the string representation and forwarding userData to callback`.
Note that the callback may be called / several times with consecutive chunks of the string. MLIR_CAPI_EXPORTED void mlirLocationPrint(MlirLocation location, MlirStringCallback callback, void *userData);
===-------------------------------------------------------------------—===// Module API. ===-------------------------------------------------------------------—===//
/ Creates a new, empty module and transfers ownership to the caller. MLIR_CAPI_EXPORTED MlirModule mlirModuleCreateEmpty(MlirLocation location);
/ Parses a module from the string and transfers ownership to the caller. MLIR_CAPI_EXPORTED MlirModule mlirModuleCreateParse(MlirContext context, MlirStringRef module);
/ Parses a module from file and transfers ownership to the caller. MLIR_CAPI_EXPORTED MlirModule mlirModuleCreateParseFromFile(MlirContext context, MlirStringRef fileName);
/ Gets the context that a module was created with. MLIR_CAPI_EXPORTED MlirContext mlirModuleGetContext(MlirModule module);
/ Gets the body of the module, i.e. the only block it contains. MLIR_CAPI_EXPORTED MlirBlock mlirModuleGetBody(MlirModule module);
/ Checks whether a module is null. static inline bool mlirModuleIsNull(MlirModule module) { return !module.ptr; }
/ Takes a module owned by the caller and deletes it. MLIR_CAPI_EXPORTED void mlirModuleDestroy(MlirModule module);
/ Views the module as a generic operation. MLIR_CAPI_EXPORTED MlirOperation mlirModuleGetOperation(MlirModule module);
/ Views the generic operation as a module. / The returned module is null when the input operation was not a ModuleOp. MLIR_CAPI_EXPORTED MlirModule mlirModuleFromOperation(MlirOperation op);
/ Checks if two modules are equal. MLIR_CAPI_EXPORTED bool mlirModuleEqual(MlirModule lhs, MlirModule rhs);
/ Compute a hash for the given module. MLIR_CAPI_EXPORTED size_t mlirModuleHashValue(MlirModule mod);
===-------------------------------------------------------------------—===// Operation state. ===-------------------------------------------------------------------—===//
/ An auxiliary class for constructing operations. / / This class contains all the information necessary to construct the / operation. It owns the MlirRegions it has pointers to and does not own / anything else. By default, the state can be constructed from a name and / location, the latter being also used to access the context, and has no other / components. These components can be added progressively until the operation / is constructed. Users are not expected to rely on the internals of this / class and should use mlirOperationState* functions instead.
struct MlirOperationState { MlirStringRef name; MlirLocation location; intptr_t nResults; MlirType *results; intptr_t nOperands; MlirValue *operands; intptr_t nRegions; MlirRegion *regions; intptr_t nSuccessors; MlirBlock *successors; intptr_t nAttributes; MlirNamedAttribute *attributes; bool enableResultTypeInference; }; typedef struct MlirOperationState MlirOperationState;
/ Constructs an operation state from a name and a location. MLIR_CAPI_EXPORTED MlirOperationState mlirOperationStateGet(MlirStringRef name, MlirLocation loc);
/ Adds a list of components to the operation state. MLIR_CAPI_EXPORTED void mlirOperationStateAddResults(MlirOperationState *state, intptr_t n, MlirType const *results); MLIR_CAPI_EXPORTED void mlirOperationStateAddOperands(MlirOperationState *state, intptr_t n, MlirValue const *operands); MLIR_CAPI_EXPORTED void mlirOperationStateAddOwnedRegions(MlirOperationState *state, intptr_t n, MlirRegion const *regions); MLIR_CAPI_EXPORTED void mlirOperationStateAddSuccessors(MlirOperationState *state, intptr_t n, MlirBlock const *successors); MLIR_CAPI_EXPORTED void mlirOperationStateAddAttributes(MlirOperationState *state, intptr_t n, MlirNamedAttribute const *attributes);
/ Enables result type inference for the operation under construction. If / enabled, then the caller must not have called / mlirOperationStateAddResults(). Note that if enabled, the / mlirOperationCreate() call is failable: it will return a null operation / on inference failure and will emit diagnostics. MLIR_CAPI_EXPORTED void mlirOperationStateEnableResultTypeInference(MlirOperationState *state);
===-------------------------------------------------------------------—===// AsmState API. While many of these are simple settings that could be represented in a struct, they are wrapped in a heap allocated object and accessed via functions to maximize the possibility of compatibility over time. ===-------------------------------------------------------------------—===//
/ Creates new AsmState, as with AsmState the IR should not be mutated / in-between using this state. / Must be freed with a call to mlirAsmStateDestroy(). TODO: This should be expanded to handle location & resouce map. MLIR_CAPI_EXPORTED MlirAsmState mlirAsmStateCreateForOperation(MlirOperation op, MlirOpPrintingFlags flags);
/ Creates new AsmState from value. / Must be freed with a call to mlirAsmStateDestroy(). TODO: This should be expanded to handle location & resouce map. MLIR_CAPI_EXPORTED MlirAsmState mlirAsmStateCreateForValue(MlirValue value, MlirOpPrintingFlags flags);
/ Destroys printing flags created with mlirAsmStateCreate. MLIR_CAPI_EXPORTED void mlirAsmStateDestroy(MlirAsmState state);
===-------------------------------------------------------------------—===// Op Printing flags API. While many of these are simple settings that could be represented in a struct, they are wrapped in a heap allocated object and accessed via functions to maximize the possibility of compatibility over time. ===-------------------------------------------------------------------—===//
/ Creates new printing flags with defaults, intended for customization. / Must be freed with a call to mlirOpPrintingFlagsDestroy(). MLIR_CAPI_EXPORTED MlirOpPrintingFlags mlirOpPrintingFlagsCreate(void);
/ Destroys printing flags created with mlirOpPrintingFlagsCreate. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsDestroy(MlirOpPrintingFlags flags);
/ Enables the elision of large elements attributes by printing a lexically / valid but otherwise meaningless form instead of the element data. The / largeElementLimit is used to configure what is considered to be a "large" / ElementsAttr by providing an upper limit to the number of elements. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsElideLargeElementsAttrs(MlirOpPrintingFlags flags, intptr_t largeElementLimit);
/ Enables the elision of large resources strings by omitting them from the / dialect_resources section. The largeResourceLimit is used to configure / what is considered to be a "large" resource by providing an upper limit to / the string size. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsElideLargeResourceString(MlirOpPrintingFlags flags, intptr_t largeResourceLimit);
/ Enable or disable printing of debug information (based on enable). If / 'prettyForm' is set to true, debug information is printed in a more readable / 'pretty' form. Note: The IR generated with 'prettyForm' is not parsable. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsEnableDebugInfo(MlirOpPrintingFlags flags, bool enable, bool prettyForm);
/ Always print operations in the generic form. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsPrintGenericOpForm(MlirOpPrintingFlags flags);
/ Print the name and location, if NamedLoc, as a prefix to the SSA ID. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsPrintNameLocAsPrefix(MlirOpPrintingFlags flags);
/ Use local scope when printing the operation. This allows for using the / printer in a more localized and thread-safe setting, but may not / necessarily be identical to what the IR will look like when dumping / the full module. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsUseLocalScope(MlirOpPrintingFlags flags);
/ Do not verify the operation when using custom operation printers. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsAssumeVerified(MlirOpPrintingFlags flags);
/ Skip printing regions. MLIR_CAPI_EXPORTED void mlirOpPrintingFlagsSkipRegions(MlirOpPrintingFlags flags);
===-------------------------------------------------------------------—===// Bytecode printing flags API. ===-------------------------------------------------------------------—===//
/ Creates new printing flags with defaults, intended for customization. / Must be freed with a call to mlirBytecodeWriterConfigDestroy(). MLIR_CAPI_EXPORTED MlirBytecodeWriterConfig mlirBytecodeWriterConfigCreate(void);
/ Destroys printing flags created with mlirBytecodeWriterConfigCreate. MLIR_CAPI_EXPORTED void mlirBytecodeWriterConfigDestroy(MlirBytecodeWriterConfig config);
/ Sets the version to emit in the writer config. MLIR_CAPI_EXPORTED void mlirBytecodeWriterConfigDesiredEmitVersion(MlirBytecodeWriterConfig flags, int64_t version);
===-------------------------------------------------------------------—===// Operation API. ===-------------------------------------------------------------------—===//
/ Creates an operation and transfers ownership to the caller. / Note that caller owned child objects are transferred in this call and must / not be further used. Particularly, this applies to any regions added to / the state (the implementation may invalidate any such pointers). / / This call can fail under the following conditions, in which case, it will / return a null operation and emit diagnostics: / - Result type inference is enabled and cannot be performed. MLIR_CAPI_EXPORTED MlirOperation mlirOperationCreate(MlirOperationState *state);
/ Parses an operation, giving ownership to the caller. If parsing fails a null / operation will be returned, and an error diagnostic emitted. / / sourceStr may be either the text assembly format, or binary bytecode / format. sourceName is used as the file name of the source; any IR without / locations will get a FileLineColLoc location with sourceName as the file / name. MLIR_CAPI_EXPORTED MlirOperation mlirOperationCreateParse( MlirContext context, MlirStringRef sourceStr, MlirStringRef sourceName);
/ Creates a deep copy of an operation. The operation is not inserted and / ownership is transferred to the caller. MLIR_CAPI_EXPORTED MlirOperation mlirOperationClone(MlirOperation op);
/ Takes an operation owned by the caller and destroys it. MLIR_CAPI_EXPORTED void mlirOperationDestroy(MlirOperation op);
/ Removes the given operation from its parent block. The operation is not / destroyed. The ownership of the operation is transferred to the caller. MLIR_CAPI_EXPORTED void mlirOperationRemoveFromParent(MlirOperation op);
/ Checks whether the underlying operation is null. static inline bool mlirOperationIsNull(MlirOperation op) { return !op.ptr; }
/ Checks whether two operation handles point to the same operation. This does / not perform deep comparison. MLIR_CAPI_EXPORTED bool mlirOperationEqual(MlirOperation op, MlirOperation other);
/ Compute a hash for the given operation. MLIR_CAPI_EXPORTED size_t mlirOperationHashValue(MlirOperation op);
/ Gets the context this operation is associated with MLIR_CAPI_EXPORTED MlirContext mlirOperationGetContext(MlirOperation op);
/ Gets the location of the operation. MLIR_CAPI_EXPORTED MlirLocation mlirOperationGetLocation(MlirOperation op);
/ Sets the location of the operation. MLIR_CAPI_EXPORTED void mlirOperationSetLocation(MlirOperation op, MlirLocation loc);
/ Gets the type id of the operation. / Returns null if the operation does not have a registered operation / description. MLIR_CAPI_EXPORTED MlirTypeID mlirOperationGetTypeID(MlirOperation op);
/ Gets the name of the operation as an identifier. MLIR_CAPI_EXPORTED MlirIdentifier mlirOperationGetName(MlirOperation op);
/ Gets the block that owns this operation, returning null if the operation is / not owned. MLIR_CAPI_EXPORTED MlirBlock mlirOperationGetBlock(MlirOperation op);
/ Gets the operation that owns this operation, returning null if the operation / is not owned. MLIR_CAPI_EXPORTED MlirOperation mlirOperationGetParentOperation(MlirOperation op);
/ Returns the number of regions attached to the given operation. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumRegions(MlirOperation op);
/ Returns pos-th region attached to the operation. MLIR_CAPI_EXPORTED MlirRegion mlirOperationGetRegion(MlirOperation op, intptr_t pos);
/ Returns an operation immediately following the given operation it its / enclosing block. MLIR_CAPI_EXPORTED MlirOperation mlirOperationGetNextInBlock(MlirOperation op);
/ Returns the number of operands of the operation. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumOperands(MlirOperation op);
/ Returns pos-th operand of the operation. MLIR_CAPI_EXPORTED MlirValue mlirOperationGetOperand(MlirOperation op, intptr_t pos);
/ Sets the pos-th operand of the operation. MLIR_CAPI_EXPORTED void mlirOperationSetOperand(MlirOperation op, intptr_t pos, MlirValue newValue);
/ Replaces the operands of the operation. MLIR_CAPI_EXPORTED void mlirOperationSetOperands(MlirOperation op, intptr_t nOperands, MlirValue const *operands);
/ Returns the number of results of the operation. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumResults(MlirOperation op);
/ Returns pos-th result of the operation. MLIR_CAPI_EXPORTED MlirValue mlirOperationGetResult(MlirOperation op, intptr_t pos);
/ Returns the number of successor blocks of the operation. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumSuccessors(MlirOperation op);
/ Returns pos-th successor of the operation. MLIR_CAPI_EXPORTED MlirBlock mlirOperationGetSuccessor(MlirOperation op, intptr_t pos);
/ Set pos-th successor of the operation. MLIR_CAPI_EXPORTED void mlirOperationSetSuccessor(MlirOperation op, intptr_t pos, MlirBlock block);
/ Returns true if this operation defines an inherent attribute with this name. / Note: the attribute can be optional, so / mlirOperationGetInherentAttributeByName can still return a null attribute. MLIR_CAPI_EXPORTED bool mlirOperationHasInherentAttributeByName(MlirOperation op, MlirStringRef name);
/ Returns an inherent attribute attached to the operation given its name. MLIR_CAPI_EXPORTED MlirAttribute mlirOperationGetInherentAttributeByName(MlirOperation op, MlirStringRef name);
/ Sets an inherent attribute by name, replacing the existing if it exists. / This has no effect if "name" does not match an inherent attribute. MLIR_CAPI_EXPORTED void mlirOperationSetInherentAttributeByName(MlirOperation op, MlirStringRef name, MlirAttribute attr);
/ Returns the number of discardable attributes attached to the operation. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumDiscardableAttributes(MlirOperation op);
/ Return pos-th discardable attribute of the operation. MLIR_CAPI_EXPORTED MlirNamedAttribute mlirOperationGetDiscardableAttribute(MlirOperation op, intptr_t pos);
/ Returns a discardable attribute attached to the operation given its name. MLIR_CAPI_EXPORTED MlirAttribute mlirOperationGetDiscardableAttributeByName( MlirOperation op, MlirStringRef name);
/ Sets a discardable attribute by name, replacing the existing if it exists or / adding a new one otherwise. The new attr Attribute is not allowed to be / null, use mlirOperationRemoveDiscardableAttributeByName to remove an / Attribute instead. MLIR_CAPI_EXPORTED void mlirOperationSetDiscardableAttributeByName(MlirOperation op, MlirStringRef name, MlirAttribute attr);
/ Removes a discardable attribute by name. Returns false if the attribute was / not found and true if removed. MLIR_CAPI_EXPORTED bool mlirOperationRemoveDiscardableAttributeByName(MlirOperation op, MlirStringRef name);
/ Returns the number of attributes attached to the operation. / Deprecated, please use mlirOperationGetNumInherentAttributes or / mlirOperationGetNumDiscardableAttributes. MLIR_CAPI_EXPORTED intptr_t mlirOperationGetNumAttributes(MlirOperation op);
/ Return pos-th attribute of the operation. / Deprecated, please use mlirOperationGetInherentAttribute or / mlirOperationGetDiscardableAttribute. MLIR_CAPI_EXPORTED MlirNamedAttribute mlirOperationGetAttribute(MlirOperation op, intptr_t pos);
/ Returns an attribute attached to the operation given its name. / Deprecated, please use mlirOperationGetInherentAttributeByName or / mlirOperationGetDiscardableAttributeByName. MLIR_CAPI_EXPORTED MlirAttribute mlirOperationGetAttributeByName(MlirOperation op, MlirStringRef name);
/ Sets an attribute by name, replacing the existing if it exists or / adding a new one otherwise. / Deprecated, please use mlirOperationSetInherentAttributeByName or / mlirOperationSetDiscardableAttributeByName. MLIR_CAPI_EXPORTED void mlirOperationSetAttributeByName(MlirOperation op, MlirStringRef name, MlirAttribute attr);
/ Removes an attribute by name. Returns false if the attribute was not found / and true if removed. / Deprecated, please use mlirOperationRemoveInherentAttributeByName or / mlirOperationRemoveDiscardableAttributeByName. MLIR_CAPI_EXPORTED bool mlirOperationRemoveAttributeByName(MlirOperation op, MlirStringRef name);
/ Prints an operation by sending chunks of the string representation and / forwarding userData to callback`. Note that the callback may be called several times with consecutive chunks of the string.
Definition at line 821 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED void mlirOperationPrintWithFlags | ( | MlirOperation | op, |
| MlirOpPrintingFlags | flags, | ||
| MlirStringCallback | callback, | ||
| void * | userData ) |
| MLIR_CAPI_EXPORTED void mlirOperationPrintWithState | ( | MlirOperation | op, |
| MlirAsmState | state, | ||
| MlirStringCallback | callback, | ||
| void * | userData ) |
| MLIR_CAPI_EXPORTED bool mlirOperationVerify | ( | MlirOperation | op | ) |
Verify the operation and return true if it passes, false if it fails.
Definition at line 857 of file IR.cpp.
References unwrap(), and mlir::verify().
Referenced by mlir::python::PyOperationBase::verify().
| MLIR_CAPI_EXPORTED void mlirOperationWalk | ( | MlirOperation | op, |
| MlirOperationWalkCallback | callback, | ||
| void * | userData, | ||
| MlirWalkOrder | walkOrder ) |
Walks operation op in walkOrder and calls callback on that operation.
*userData is passed to the callback as well and can be used to tunnel some context or other data into the callback.
Definition at line 887 of file IR.cpp.
References MlirWalkPostOrder, MlirWalkPreOrder, mlir::PostOrder, mlir::PreOrder, unwrap(), and wrap().
Referenced by mlir::python::PyOperationBase::walk().
| MLIR_CAPI_EXPORTED void mlirOperationWriteBytecode | ( | MlirOperation | op, |
| MlirStringCallback | callback, | ||
| void * | userData ) |
Same as mlirOperationPrint but writing the bytecode format.
Definition at line 841 of file IR.cpp.
References unwrap(), and mlir::writeBytecodeToFile().
Referenced by mlir::python::PyOperationBase::writeBytecode().
| MLIR_CAPI_EXPORTED MlirLogicalResult mlirOperationWriteBytecodeWithConfig | ( | MlirOperation | op, |
| MlirBytecodeWriterConfig | config, | ||
| MlirStringCallback | callback, | ||
| void * | userData ) |
Same as mlirOperationWriteBytecode but with writer config and returns failure only if desired bytecode could not be honored.
Definition at line 848 of file IR.cpp.
References mlir::config, unwrap(), wrap(), and mlir::writeBytecodeToFile().
Referenced by mlir::python::PyOperationBase::writeBytecode().
| MLIR_CAPI_EXPORTED MlirOpOperand mlirOpOperandGetNextUse | ( | MlirOpOperand | opOperand | ) |
Returns an op operand representing the next use of the value, or a null op operand if there is no next use.
Definition at line 1218 of file IR.cpp.
References mlirOpOperandIsNull(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED unsigned mlirOpOperandGetOperandNumber | ( | MlirOpOperand | opOperand | ) |
| MLIR_CAPI_EXPORTED MlirOperation mlirOpOperandGetOwner | ( | MlirOpOperand | opOperand | ) |
| MLIR_CAPI_EXPORTED MlirValue mlirOpOperandGetValue | ( | MlirOpOperand | opOperand | ) |
Returns the value of an op operand.
Definition at line 1210 of file IR.cpp.
References mlir::get(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED bool mlirOpOperandIsNull | ( | MlirOpOperand | opOperand | ) |
Returns whether the op operand is null.
Definition at line 1204 of file IR.cpp.
Referenced by mlirOpOperandGetNextUse().
| MLIR_CAPI_EXPORTED void mlirRegionAppendOwnedBlock | ( | MlirRegion | region, |
| MlirBlock | block ) |
Takes a block owned by the caller and appends it to the given region.
Definition at line 922 of file IR.cpp.
References unwrap().
Referenced by mlirRegionInsertOwnedBlockBefore().
| MLIR_CAPI_EXPORTED MlirRegion mlirRegionCreate | ( | void | ) |
Creates a new empty region and transfers ownership to the caller.
Definition at line 909 of file IR.cpp.
References wrap().
Referenced by mlir::python::PyOperation::create().
| MLIR_CAPI_EXPORTED void mlirRegionDestroy | ( | MlirRegion | region | ) |
| MLIR_CAPI_EXPORTED bool mlirRegionEqual | ( | MlirRegion | region, |
| MlirRegion | other ) |
| MLIR_CAPI_EXPORTED MlirBlock mlirRegionGetFirstBlock | ( | MlirRegion | region | ) |
Gets the first block in the region.
Definition at line 915 of file IR.cpp.
References mlir::Region::empty(), mlir::Region::front(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirRegion mlirRegionGetNextInOperation | ( | MlirRegion | region | ) |
Returns the region immediately following the given region in its parent operation.
Definition at line 696 of file IR.cpp.
References mlir::Operation::getNumRegions(), mlir::Region::getParentOp(), mlir::Operation::getRegion(), mlir::Region::getRegionNumber(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED void mlirRegionInsertOwnedBlock | ( | MlirRegion | region, |
| intptr_t | pos, | ||
| MlirBlock | block ) |
| MLIR_CAPI_EXPORTED void mlirRegionInsertOwnedBlockAfter | ( | MlirRegion | region, |
| MlirBlock | reference, | ||
| MlirBlock | block ) |
Takes a block owned by the caller and inserts it after the (non-owned) reference block in the given region.
The reference block must belong to the region. If the reference block is null, prepends the block to the region.
Definition at line 932 of file IR.cpp.
References mlir::Region::begin(), mlir::Region::getBlocks(), mlirBlockIsNull(), unwrap(), and unwrap().
| MLIR_CAPI_EXPORTED void mlirRegionInsertOwnedBlockBefore | ( | MlirRegion | region, |
| MlirBlock | reference, | ||
| MlirBlock | block ) |
Takes a block owned by the caller and inserts it before the (non-owned) reference block in the given region.
The reference block must belong to the region. If the reference block is null, appends the block to the region.
Definition at line 946 of file IR.cpp.
References mlirBlockIsNull(), mlirRegionAppendOwnedBlock(), and unwrap().
|
inlinestatic |
Checks whether a region is null.
Definition at line 872 of file IR.h.
Referenced by mlir::python::PyRegion::PyRegion().
| MLIR_CAPI_EXPORTED void mlirRegionTakeBody | ( | MlirRegion | target, |
| MlirRegion | source ) |
| MLIR_CAPI_EXPORTED MlirSymbolTable mlirSymbolTableCreate | ( | MlirOperation | operation | ) |
Creates a symbol table for the given operation.
If the operation does not have the SymbolTable trait, returns a null symbol table.
Definition at line 1338 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PySymbolTable::PySymbolTable().
| MLIR_CAPI_EXPORTED void mlirSymbolTableDestroy | ( | MlirSymbolTable | symbolTable | ) |
Destroys the symbol table created with mlirSymbolTableCreate.
This does not affect the operations in the table.
Definition at line 1344 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PySymbolTable::~PySymbolTable().
| MLIR_CAPI_EXPORTED void mlirSymbolTableErase | ( | MlirSymbolTable | symbolTable, |
| MlirOperation | operation ) |
Removes the given operation from the symbol table and erases it.
Definition at line 1358 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PySymbolTable::erase().
| MLIR_CAPI_EXPORTED MlirStringRef mlirSymbolTableGetSymbolAttributeName | ( | void | ) |
Returns the name of the attribute used to store symbol names compatible with symbol tables.
Definition at line 1330 of file IR.cpp.
References mlir::SymbolTable::getSymbolAttrName(), and wrap().
Referenced by mlir::python::PySymbolTable::getSymbolName(), mlir::python::PySymbolTable::insert(), and mlir::python::PySymbolTable::setSymbolName().
| MLIR_CAPI_EXPORTED MlirStringRef mlirSymbolTableGetVisibilityAttributeName | ( | void | ) |
Returns the name of the attribute used to store symbol visibility.
Definition at line 1334 of file IR.cpp.
References mlir::SymbolTable::getVisibilityAttrName(), and wrap().
Referenced by mlir::python::PySymbolTable::getVisibility(), and mlir::python::PySymbolTable::setVisibility().
| MLIR_CAPI_EXPORTED MlirAttribute mlirSymbolTableInsert | ( | MlirSymbolTable | symbolTable, |
| MlirOperation | operation ) |
Inserts the given operation into the given symbol table.
The operation must have the symbol trait. If the symbol table already has a symbol with the same name, renames the symbol being inserted to ensure name uniqueness. Note that this does not move the operation itself into the block of the symbol table operation, this should be done separately. Returns the name of the symbol after insertion.
Definition at line 1353 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PySymbolTable::insert().
|
inlinestatic |
Returns true if the symbol table is null.
Definition at line 1238 of file IR.h.
Referenced by mlir::python::PySymbolTable::PySymbolTable().
| MLIR_CAPI_EXPORTED MlirOperation mlirSymbolTableLookup | ( | MlirSymbolTable | symbolTable, |
| MlirStringRef | name ) |
Looks up a symbol with the given name in the given symbol table and returns the operation that corresponds to the symbol.
If the symbol cannot be found, returns a null operation.
Definition at line 1348 of file IR.cpp.
References MlirStringRef::data, MlirStringRef::length, unwrap(), and wrap().
Referenced by mlir::python::PySymbolTable::dunderGetItem().
| MLIR_CAPI_EXPORTED MlirLogicalResult mlirSymbolTableReplaceAllSymbolUses | ( | MlirStringRef | oldSymbol, |
| MlirStringRef | newSymbol, | ||
| MlirOperation | from ) |
Attempt to replace all uses that are nested within the given operation of the given symbol 'oldSymbol' with the provided 'newSymbol'.
This does not traverse into nested symbol tables. Will fail atomically if there are any unknown operations that may be potential symbol tables.
Definition at line 1363 of file IR.cpp.
References mlir::SymbolTable::replaceAllSymbolUses(), unwrap(), and wrap().
Referenced by mlir::python::PySymbolTable::replaceAllSymbolUses().
| MLIR_CAPI_EXPORTED void mlirSymbolTableWalkSymbolTables | ( | MlirOperation | from, |
| bool | allSymUsesVisible, | ||
| void(* | callback )(MlirOperation, bool, void *userData), | ||
| void * | userData ) |
Walks all symbol table operations nested within, and including, op.
For each symbol table operation, the provided callback is invoked with the op and a boolean signifying if the symbols within that symbol table can be treated as if all uses within the IR are visible to the caller. allSymUsesVisible identifies whether all of the symbol uses of symbols within op are visible.
Definition at line 1374 of file IR.cpp.
References unwrap(), mlir::SymbolTable::walkSymbolTables(), and wrap().
Referenced by mlir::python::PySymbolTable::walkSymbolTables().
| MLIR_CAPI_EXPORTED bool mlirTypeEqual | ( | MlirType | t1, |
| MlirType | t2 ) |
Checks if two types are equal.
Definition at line 1251 of file IR.cpp.
References unwrap().
Referenced by mlir::python::PyType::operator==().
| MLIR_CAPI_EXPORTED MlirContext mlirTypeGetContext | ( | MlirType | type | ) |
Gets the context that a type was created with.
Definition at line 1239 of file IR.cpp.
References getContext(), unwrap(), and wrap().
Referenced by mlir::python::PyType::createFromCapsule().
| MLIR_CAPI_EXPORTED MlirDialect mlirTypeGetDialect | ( | MlirType | type | ) |
Gets the dialect a type belongs to.
Definition at line 1247 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyType::maybeDownCast(), and mlir::python::PyValue::maybeDownCast().
| MLIR_CAPI_EXPORTED MlirTypeID mlirTypeGetTypeID | ( | MlirType | type | ) |
Gets the type ID of the type.
Definition at line 1243 of file IR.cpp.
References unwrap(), and wrap().
Referenced by mlir::python::PyType::maybeDownCast(), and mlir::python::PyValue::maybeDownCast().
|
inlinestatic |
Checks whether a type is null.
Definition at line 1148 of file IR.h.
Referenced by mlir::python::PyType::createFromCapsule(), pybind11::detail::type_caster< MlirType >::load(), populateDialectLLVMSubmodule(), and populateDialectQuantSubmodule().
| MLIR_CAPI_EXPORTED MlirType mlirTypeParseGet | ( | MlirContext | context, |
| MlirStringRef | type ) |
Parses a type. The type is owned by the context.
Definition at line 1235 of file IR.cpp.
References mlir::parseType(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirContext mlirValueGetContext | ( | MlirValue | v | ) |
Gets the context that a value was created with.
Definition at line 1196 of file IR.cpp.
References getContext(), unwrap(), and wrap().
| MLIR_CAPI_EXPORTED MlirOpOperand mlirValueGetFirstUse | ( | MlirValue | value | ) |
Returns an op operand representing the first use of the value, or a null op operand if there are no uses.
Definition at line 1164 of file IR.cpp.
References mlir::ValueUseIterator< OperandType >::getOperand(), unwrap(), mlir::Value::use_begin(), mlir::Value::use_empty(), and wrap().
| MLIR_CAPI_EXPORTED MlirLocation mlirValueGetLocation | ( | MlirValue | v | ) |
| MLIR_CAPI_EXPORTED void mlirValuePrint | ( | MlirValue | value, |
| MlirStringCallback | callback, | ||
| void * | userData ) |
Prints a block by sending chunks of the string representation and forwarding userData to callback`.
Note that the callback may be called / several times with consecutive chunks of the string. MLIR_CAPI_EXPORTED void mlirBlockPrint(MlirBlock block, MlirStringCallback callback, void *userData);
/ Returns the number of successor blocks of the block. MLIR_CAPI_EXPORTED intptr_t mlirBlockGetNumSuccessors(MlirBlock block);
/ Returns pos-th successor of the block. MLIR_CAPI_EXPORTED MlirBlock mlirBlockGetSuccessor(MlirBlock block, intptr_t pos);
/ Returns the number of predecessor blocks of the block. MLIR_CAPI_EXPORTED intptr_t mlirBlockGetNumPredecessors(MlirBlock block);
/ Returns pos-th predecessor of the block. / / WARNING: This getter is more expensive than the others here because / the impl actually iterates the use-def chain (of block operands) anew for / each indexed access. MLIR_CAPI_EXPORTED MlirBlock mlirBlockGetPredecessor(MlirBlock block, intptr_t pos);
===-------------------------------------------------------------------—===// Value API. ===-------------------------------------------------------------------—===//
/ Returns whether the value is null. static inline bool mlirValueIsNull(MlirValue value) { return !value.ptr; }
/ Returns 1 if two values are equal, 0 otherwise. MLIR_CAPI_EXPORTED bool mlirValueEqual(MlirValue value1, MlirValue value2);
/ Returns 1 if the value is a block argument, 0 otherwise. MLIR_CAPI_EXPORTED bool mlirValueIsABlockArgument(MlirValue value);
/ Returns 1 if the value is an operation result, 0 otherwise. MLIR_CAPI_EXPORTED bool mlirValueIsAOpResult(MlirValue value);
/ Returns the block in which this value is defined as an argument. Asserts if / the value is not a block argument. MLIR_CAPI_EXPORTED MlirBlock mlirBlockArgumentGetOwner(MlirValue value);
/ Returns the position of the value in the argument list of its block. MLIR_CAPI_EXPORTED intptr_t mlirBlockArgumentGetArgNumber(MlirValue value);
/ Sets the type of the block argument to the given type. MLIR_CAPI_EXPORTED void mlirBlockArgumentSetType(MlirValue value, MlirType type);
/ Returns an operation that produced this value as its result. Asserts if the / value is not an op result. MLIR_CAPI_EXPORTED MlirOperation mlirOpResultGetOwner(MlirValue value);
/ Returns the position of the value in the list of results of the operation / that produced it. MLIR_CAPI_EXPORTED intptr_t mlirOpResultGetResultNumber(MlirValue value);
/ Returns the type of the value. MLIR_CAPI_EXPORTED MlirType mlirValueGetType(MlirValue value);
/ Set the type of the value. MLIR_CAPI_EXPORTED void mlirValueSetType(MlirValue value, MlirType type);
/ Prints the value to the standard error stream. MLIR_CAPI_EXPORTED void mlirValueDump(MlirValue value);
/ Prints a value by sending chunks of the string representation and / forwarding userData to callback`. Note that the callback may be called several times with consecutive chunks of the string.
Definition at line 1151 of file IR.cpp.
References unwrap().
| MLIR_CAPI_EXPORTED void mlirValuePrintAsOperand | ( | MlirValue | value, |
| MlirAsmState | state, | ||
| MlirStringCallback | callback, | ||
| void * | userData ) |
Prints a value as an operand (i.e., the ValueID).
Definition at line 1157 of file IR.cpp.
References mlir::Value::printAsOperand(), and unwrap().
| MLIR_CAPI_EXPORTED void mlirValueReplaceAllUsesExcept | ( | MlirValue | of, |
| MlirValue | with, | ||
| intptr_t | numExceptions, | ||
| MlirOperation * | exceptions ) |
Replace all uses of 'of' value with 'with' value, updating anything in the IR that uses 'of' to use 'with' instead, except if the user is listed in 'exceptions'.
The 'exceptions' parameter is an array of MlirOperation pointers with a length of 'numExceptions'.
Definition at line 1178 of file IR.cpp.
References mlir::Value::replaceAllUsesExcept(), and unwrap().
| MLIR_CAPI_EXPORTED void mlirValueReplaceAllUsesOfWith | ( | MlirValue | of, |
| MlirValue | with ) |