9#ifndef MLIR_BINDINGS_PYTHON_IRCORE_H
10#define MLIR_BINDINGS_PYTHON_IRCORE_H
55 static void set(nanobind::object &o,
bool enable);
56 static bool get(
const nanobind::object &);
57 static void bind(nanobind::module_ &m);
60 static nanobind::ft_mutex mutex;
69 : referrent(referrent), object(std::move(object)) {
70 assert(this->referrent &&
71 "cannot construct PyObjectRef with null referrent");
72 assert(this->
object &&
"cannot construct PyObjectRef with null object");
75 : referrent(other.referrent), object(std::move(other.object)) {
76 other.referrent =
nullptr;
77 assert(!other.object);
80 : referrent(other.referrent), object(other.object ) {}
82 referrent = other.referrent;
83 object = other.object;
87 referrent = other.referrent;
88 object = std::move(other.object);
89 other.referrent =
nullptr;
90 assert(!other.object);
98 return Py_REFCNT(
object.
ptr());
105 assert(referrent &&
object);
107 auto stolen = std::move(
object);
111 T *
get() {
return referrent; }
113 assert(referrent &&
object);
117 assert(referrent &&
object);
120 operator bool()
const {
return referrent && object; }
122 using NBTypedT = nanobind::typed<nanobind::object, T>;
126 nanobind::object object;
146 nanobind::object insertionPoint,
147 nanobind::object location)
148 : context(std::move(context)), insertionPoint(std::move(insertionPoint)),
149 location(std::move(location)), frameKind(frameKind) {}
167 static nanobind::object pushContext(nanobind::object context);
169 static nanobind::object pushInsertionPoint(nanobind::object insertionPoint);
171 static nanobind::object pushLocation(nanobind::object location);
172 static void popLocation(
PyLocation &location);
175 static std::vector<PyThreadContextEntry> &getStack();
178 static void push(FrameKind frameKind, nanobind::object context,
179 nanobind::object insertionPoint, nanobind::object location);
182 nanobind::object context;
184 nanobind::object insertionPoint;
186 nanobind::object location;
201 MlirLlvmThreadPool
get() {
return threadPool; }
203 std::string _mlir_thread_pool_ptr()
const;
206 MlirLlvmThreadPool threadPool;
224 MlirContext
get() {
return context; }
231 nanobind::object getCapsule();
237 static nanobind::object createFromCapsule(nanobind::object capsule);
240 static size_t getLiveCount();
244 size_t getLiveModuleCount();
247 static nanobind::object contextEnter(nanobind::object context);
248 void contextExit(
const nanobind::object &excType,
249 const nanobind::object &excVal,
250 const nanobind::object &excTb);
254 nanobind::object attachDiagnosticHandler(nanobind::object callback);
269 using LiveContextMap = std::unordered_map<void *, PyMlirContext *>;
270 static nanobind::ft_mutex live_contexts_mutex;
271 static LiveContextMap &getLiveContexts();
277 using LiveModuleMap =
278 std::unordered_map<const void *, std::pair<nanobind::handle, PyModule *>>;
279 LiveModuleMap liveModules;
281 bool emitErrorDiagnostics =
false;
291 :
public Defaulting<DefaultingPyMlirContext, PyMlirContext> {
305 assert(this->contextRef &&
306 "context object constructed with null context ref");
322 operator MlirLocation()
const {
return loc; }
323 MlirLocation
get()
const {
return loc; }
326 static nanobind::object contextEnter(nanobind::object location);
327 void contextExit(
const nanobind::object &excType,
328 const nanobind::object &excVal,
329 const nanobind::object &excTb);
332 nanobind::object getCapsule();
338 static PyLocation createFromCapsule(nanobind::object capsule);
342 nanobind::typed<nanobind::object, PyLocation> maybeDownCast();
379 nanobind::str getMessage();
380 nanobind::typed<nanobind::tuple, PyDiagnostic> getNotes();
399 std::optional<nanobind::tuple> materializedNotes;
435 const nanobind::object &excVal,
436 const nanobind::object &excTb) {
442 nanobind::object callback;
443 std::optional<MlirDiagnosticHandlerID> registeredID;
444 bool hadError =
false;
453 ctx->
get(), handler, this,
457 assert(errors.empty() &&
"unhandled captured errors");
460 std::vector<PyDiagnostic::DiagnosticInfo>
take() {
461 return std::move(errors);
467 std::vector<PyDiagnostic::DiagnosticInfo> errors;
482 MlirDialect
get() {
return dialect; }
495 MlirDialect getDialectForKey(
const std::string &key,
bool attrError);
503 PyDialect(nanobind::object descriptor) : descriptor(std::move(descriptor)) {}
508 nanobind::object descriptor;
524 : registry(other.registry) {
525 other.registry = {
nullptr};
528 operator MlirDialectRegistry()
const {
return registry; }
529 MlirDialectRegistry
get()
const {
return registry; }
531 nanobind::object getCapsule();
535 MlirDialectRegistry registry;
541 :
public Defaulting<DefaultingPyLocation, PyLocation> {
547 operator MlirLocation()
const {
return *
get(); }
564 MlirModule
get() {
return module; }
568 return PyModuleRef(
this, nanobind::borrow<nanobind::object>(handle));
575 nanobind::object getCapsule();
580 static nanobind::object createFromCapsule(nanobind::object capsule);
587 nanobind::handle handle;
598 void print(std::optional<int64_t> largeElementsLimit,
599 std::optional<int64_t> largeResourceLimit,
bool enableDebugInfo,
600 bool prettyDebugInfo,
bool printGenericOpForm,
bool useLocalScope,
601 bool useNameLocAsPrefix,
bool assumeVerified,
602 nanobind::object fileObject,
bool binary,
bool skipRegions);
603 void print(
PyAsmState &state, nanobind::object fileObject,
bool binary);
606 getAsm(
bool binary, std::optional<int64_t> largeElementsLimit,
607 std::optional<int64_t> largeResourceLimit,
bool enableDebugInfo,
608 bool prettyDebugInfo,
bool printGenericOpForm,
bool useLocalScope,
609 bool useNameLocAsPrefix,
bool assumeVerified,
bool skipRegions);
613 std::optional<int64_t> bytecodeVersion);
657 nanobind::object parentKeepAlive = nanobind::object());
663 nanobind::object parentKeepAlive = nanobind::object());
668 const std::string &sourceStr,
669 const std::string &sourceName);
673 void detachFromParent();
676 operator MlirOperation()
const {
return get(); }
677 MlirOperation
get()
const;
682 void setAttached(
const nanobind::object &parent = nanobind::object());
684 void checkValid()
const;
692 std::optional<PyOperationRef> getParentOperation();
695 nanobind::object getCapsule();
700 static nanobind::object createFromCapsule(
const nanobind::object &capsule);
703 static nanobind::object
704 create(std::string_view name, std::optional<std::vector<PyType *>> results,
705 const MlirValue *operands,
size_t numOperands,
706 std::optional<nanobind::dict> attributes,
707 std::optional<std::vector<PyBlock *>> successors,
int regions,
708 PyLocation &location,
const nanobind::object &ip,
bool inferType);
711 nanobind::object createOpView();
721 nanobind::object
clone(
const nanobind::object &ip);
727 MlirOperation operation,
728 nanobind::object parentKeepAlive);
730 MlirOperation operation;
731 nanobind::handle handle;
738 nanobind::object parentKeepAlive;
739 bool attached =
true;
753 PyOpView(
const nanobind::object &operationObject);
758 static nanobind::typed<nanobind::object, PyOperation>
759 buildGeneric(std::string_view name, std::tuple<int, bool> opRegionSpec,
760 nanobind::object operandSegmentSpecObj,
761 nanobind::object resultSegmentSpecObj,
762 std::optional<nanobind::sequence> resultTypeList,
763 nanobind::sequence operandList,
764 std::optional<nanobind::dict> attributes,
765 std::optional<std::vector<PyBlock *>> successors,
766 std::optional<int> regions,
PyLocation &location,
767 const nanobind::object &maybeIp);
776 static nanobind::object constructDerived(
const nanobind::object &cls,
777 const nanobind::object &operation);
781 nanobind::object operationObject;
790 : parentOperation(std::move(parentOperation)), region(region) {
793 operator MlirRegion()
const {
return region; }
795 MlirRegion
get() {
return region; }
808 PyAsmState(MlirValue value,
bool useLocalScope);
815 MlirAsmState
get() {
return state; }
819 MlirOpPrintingFlags flags;
828 : parentOperation(std::move(parentOperation)), block(block) {
832 MlirBlock
get() {
return block; }
838 nanobind::object getCapsule();
871 static nanobind::object
contextEnter(nanobind::object insertionPoint);
873 const nanobind::object &excVal,
874 const nanobind::object &excTb);
883 : refOperation(std::move(refOperation)), block(std::move(block)) {}
885 std::optional<PyOperationRef> refOperation;
896 operator MlirType()
const {
return type; }
897 MlirType
get()
const {
return type; }
900 nanobind::object getCapsule();
906 static PyType createFromCapsule(nanobind::object capsule);
908 nanobind::typed<nanobind::object, PyType> maybeDownCast();
924 operator MlirTypeID()
const {
return typeID; }
925 MlirTypeID
get() {
return typeID; }
928 nanobind::object getCapsule();
931 static PyTypeID createFromCapsule(nanobind::object capsule);
942template <
typename DerivedTy,
typename BaseTy = PyType>
948 using ClassTy = nanobind::class_<DerivedTy, BaseTy>;
957 : BaseTy(std::move(contextRef), t) {}
962 if (!DerivedTy::isaFunction(orig)) {
964 nanobind::cast<std::string>(nanobind::repr(nanobind::cast(orig)));
965 throw nanobind::value_error((std::string(
"Cannot cast type to ") +
966 DerivedTy::pyClassName +
" (from " +
973 static void bind(nanobind::module_ &m) {
974 auto cls =
ClassTy(m, DerivedTy::pyClassName, nanobind::is_generic());
975 cls.def(nanobind::init<PyType &>(), nanobind::keep_alive<0, 1>(),
976 nanobind::arg(
"cast_from_type"));
977 cls.def_prop_ro_static(
"static_typeid", [](nanobind::object & ) {
978 if (DerivedTy::getTypeIdFunction)
979 return PyTypeID(DerivedTy::getTypeIdFunction());
980 throw nanobind::attribute_error(
981 (DerivedTy::pyClassName + std::string(
" has no typeid.")).c_str());
983 cls.def_prop_ro(
"typeid", [](
PyType &self) {
984 return nanobind::cast<PyTypeID>(nanobind::cast(self).attr(
"typeid"));
986 cls.def(
"__repr__", [](
DerivedTy &self) {
988 printAccum.
parts.append(DerivedTy::pyClassName);
989 printAccum.
parts.append(
"(");
991 printAccum.
parts.append(
")");
992 return printAccum.
join();
995 if (DerivedTy::getTypeIdFunction) {
997 DerivedTy::getTypeIdFunction(),
998 nanobind::cast<nanobind::callable>(nanobind::cpp_function(
1003 if (DerivedTy::name.length != 0) {
1004 cls.def_prop_ro_static(
"type_name", [](nanobind::object & ) {
1005 return nanobind::str(DerivedTy::name.data, DerivedTy::name.length);
1009 DerivedTy::bindDerived(cls);
1023 operator MlirAttribute()
const {
return attr; }
1024 MlirAttribute
get()
const {
return attr; }
1027 nanobind::object getCapsule();
1033 static PyAttribute createFromCapsule(
const nanobind::object &capsule);
1035 nanobind::typed<nanobind::object, PyAttribute> maybeDownCast();
1061 std::unique_ptr<std::string> ownedName;
1069template <
typename DerivedTy,
typename BaseTy = PyAttribute>
1075 using ClassTy = nanobind::class_<DerivedTy, BaseTy>;
1084 : BaseTy(std::move(contextRef), attr) {}
1089 if (!DerivedTy::isaFunction(orig)) {
1091 nanobind::cast<std::string>(nanobind::repr(nanobind::cast(orig)));
1092 throw nanobind::value_error((std::string(
"Cannot cast attribute to ") +
1093 DerivedTy::pyClassName +
" (from " +
1100 static void bind(nanobind::module_ &m, PyType_Slot *slots =
nullptr) {
1103 cls =
ClassTy(m, DerivedTy::pyClassName, nanobind::type_slots(slots),
1104 nanobind::is_generic());
1106 cls =
ClassTy(m, DerivedTy::pyClassName, nanobind::is_generic());
1108 cls.def(nanobind::init<PyAttribute &>(), nanobind::keep_alive<0, 1>(),
1109 nanobind::arg(
"cast_from_attr"));
1112 [](
PyAttribute &attr) -> nanobind::typed<nanobind::object, PyType> {
1116 cls.def_prop_ro_static(
"static_typeid", [](nanobind::object & ) {
1117 if (DerivedTy::getTypeIdFunction)
1118 return PyTypeID(DerivedTy::getTypeIdFunction());
1119 throw nanobind::attribute_error(
1120 (DerivedTy::pyClassName + std::string(
" has no typeid.")).c_str());
1123 return nanobind::cast<PyTypeID>(nanobind::cast(self).attr(
"typeid"));
1125 cls.def(
"__repr__", [](
DerivedTy &self) {
1127 printAccum.
parts.append(DerivedTy::pyClassName);
1128 printAccum.
parts.append(
"(");
1131 printAccum.
parts.append(
")");
1132 return printAccum.
join();
1135 if (DerivedTy::getTypeIdFunction) {
1137 DerivedTy::getTypeIdFunction(),
1138 nanobind::cast<nanobind::callable>(
1145 if (DerivedTy::name.length != 0) {
1146 cls.def_prop_ro_static(
"attr_name", [](nanobind::object & ) {
1147 return nanobind::str(DerivedTy::name.data, DerivedTy::name.length);
1151 DerivedTy::bindDerived(cls);
1173template <
typename DerivedTy,
typename BaseTy = PyLocation>
1179 using ClassTy = nanobind::class_<DerivedTy, BaseTy>;
1187 : BaseTy(std::move(contextRef), loc) {}
1192 if (!DerivedTy::isaFunction(orig.
get())) {
1194 nanobind::cast<std::string>(nanobind::repr(nanobind::cast(orig)));
1195 throw nanobind::value_error((std::string(
"Cannot cast location to ") +
1196 DerivedTy::pyClassName +
" (from " +
1203 static void bind(nanobind::module_ &m) {
1204 ClassTy cls(m, DerivedTy::pyClassName, nanobind::is_generic());
1205 cls.def(nanobind::init<PyLocation &>(), nanobind::keep_alive<0, 1>(),
1206 nanobind::arg(
"cast_from_loc"));
1207 cls.def_prop_ro_static(
"static_typeid", [](nanobind::object & ) {
1208 if (DerivedTy::getTypeIdFunction)
1209 return PyTypeID(DerivedTy::getTypeIdFunction());
1210 throw nanobind::attribute_error(
1211 (DerivedTy::pyClassName + std::string(
" has no typeid.")).c_str());
1213 cls.def(
"__repr__", [](
DerivedTy &self) {
1215 printAccum.
parts.append(DerivedTy::pyClassName);
1216 printAccum.
parts.append(
"(");
1219 printAccum.
parts.append(
")");
1220 return printAccum.
join();
1222 if (DerivedTy::getTypeIdFunction) {
1224 DerivedTy::getTypeIdFunction(),
1225 nanobind::cast<nanobind::callable>(nanobind::cpp_function(
1229 DerivedTy::bindDerived(cls);
1311 : parentOperation(std::move(parentOperation)), value(value) {}
1312 operator MlirValue()
const {
return value; }
1314 MlirValue
get() {
return value; }
1320 nanobind::object getCapsule();
1322 nanobind::typed<nanobind::object,
1323 std::variant<PyBlockArgument, PyOpResult, PyValue>>
1328 static PyValue createFromCapsule(nanobind::object capsule);
1341 operator MlirAffineExpr()
const {
return affineExpr; }
1342 MlirAffineExpr
get()
const {
return affineExpr; }
1345 nanobind::object getCapsule();
1351 static PyAffineExpr createFromCapsule(
const nanobind::object &capsule);
1359 nanobind::typed<nanobind::object, PyAffineExpr>
maybeDownCast();
1362 MlirAffineExpr affineExpr;
1370 operator MlirAffineMap()
const {
return affineMap; }
1371 MlirAffineMap
get()
const {
return affineMap; }
1374 nanobind::object getCapsule();
1380 static PyAffineMap createFromCapsule(
const nanobind::object &capsule);
1383 MlirAffineMap affineMap;
1391 operator MlirIntegerSet()
const {
return integerSet; }
1392 MlirIntegerSet
get()
const {
return integerSet; }
1395 nanobind::object getCapsule();
1400 static PyIntegerSet createFromCapsule(
const nanobind::object &capsule);
1403 MlirIntegerSet integerSet;
1417 nanobind::object dunderGetItem(
const std::string &name);
1424 void dunderDel(
const std::string &name);
1432 static void setSymbolName(
PyOperationBase &symbol,
const std::string &name);
1437 const std::string &visibility);
1441 static void replaceAllSymbolUses(
const std::string &oldSymbol,
1442 const std::string &newSymbol,
1446 static void walkSymbolTables(
PyOperationBase &from,
bool allSymUsesVisible,
1447 nanobind::object callback);
1450 operator MlirSymbolTable() {
return symbolTable; }
1454 MlirSymbolTable symbolTable;
1462 : message(std::move(message)),
1463 errorDiagnostics(std::move(errorDiagnostics)) {}
1464 const char *
what() const noexcept
override {
return message.c_str(); }
1467 static void bind(nanobind::module_ &m);
1492createBlock(
const nanobind::typed<nanobind::sequence, PyType> &pyArgTypes,
1493 const std::optional<nanobind::typed<nanobind::sequence, PyLocation>>
1498 static nanobind::callable
1501 nanobind::callable
func,
bool replace,
1502 bool allow_existing);
1504 static void bind(nanobind::module_ &m);
1514 :
public Sliceable<PyRegionList, PyRegion> {
1537 : operation(std::move(operation)), next(next) {}
1541 nanobind::typed<nanobind::object, PyBlock> dunderNext();
1543 static void bind(nanobind::module_ &m);
1556 : operation(std::move(operation)), region(region) {}
1564 PyBlock appendBlock(
const nanobind::args &pyArgTypes,
1565 const std::optional<nanobind::sequence> &pyArgLocs);
1567 static void bind(nanobind::module_ &m);
1577 : parentOperation(std::move(parentOperation)), next(next) {}
1581 nanobind::typed<nanobind::object, PyOpView> dunderNext();
1583 static void bind(nanobind::module_ &m);
1597 : parentOperation(std::move(parentOperation)), block(block) {}
1603 nanobind::typed<nanobind::object, PyOpView> dunderGetItem(
intptr_t index);
1605 static void bind(nanobind::module_ &m);
1615 operator MlirOpOperand()
const {
return opOperand; }
1617 nanobind::typed<nanobind::object, PyOpView> getOwner()
const;
1619 size_t getOperandNumber()
const;
1621 static void bind(nanobind::module_ &m);
1624 MlirOpOperand opOperand;
1633 nanobind::typed<nanobind::object, PyOpOperand> dunderNext();
1635 static void bind(nanobind::module_ &m);
1638 MlirOpOperand opOperand;
1644template <
typename DerivedTy>
1651 using ClassTy = nanobind::class_<DerivedTy, PyValue>;
1659 :
PyValue(operationRef, value) {}
1666 if (!DerivedTy::isaFunction(orig.
get())) {
1668 nanobind::cast<std::string>(nanobind::repr(nanobind::cast(orig)));
1669 throw nanobind::value_error((std::string(
"Cannot cast value to ") +
1670 DerivedTy::pyClassName +
" (from " +
1678 static void bind(nanobind::module_ &m) {
1679 auto cls =
ClassTy(m, DerivedTy::pyClassName, nanobind::is_generic(),
1680 nanobind::sig((std::string(
"class ") +
1681 DerivedTy::pyClassName +
"(Value[_T])")
1683 cls.def(nanobind::init<PyValue &>(), nanobind::keep_alive<0, 1>(),
1684 nanobind::arg(
"value"));
1687 [](
DerivedTy &self) -> nanobind::typed<nanobind::object, DerivedTy> {
1688 return self.maybeDownCast();
1690 cls.def(
"__str__", [](
PyValue &self) {
1692 printAccum.
parts.append(std::string(DerivedTy::pyClassName) +
"(");
1695 printAccum.
parts.append(
")");
1696 return printAccum.
join();
1699 if (DerivedTy::getTypeIdFunction) {
1701 DerivedTy::getTypeIdFunction(),
1702 nanobind::cast<nanobind::callable>(nanobind::cpp_function(
1707 DerivedTy::bindDerived(cls);
1729 :
public Sliceable<PyOpResultList, PyOpResult> {
1732 static constexpr std::array<const char *, 1>
typeParams = {
"_T"};
1772 :
public Sliceable<PyBlockArgumentList, PyBlockArgument> {
1806 :
public Sliceable<PyOpOperandList, PyValue> {
1809 static constexpr std::array<const char *, 1>
typeParams = {
"_T"};
1838 :
public Sliceable<PyOpSuccessors, PyBlock> {
1868 :
public Sliceable<PyBlockSuccessors, PyBlock> {
1899 :
public Sliceable<PyBlockPredecessors, PyBlock> {
1927 : operation(std::move(operation)) {}
1929 nanobind::typed<nanobind::object, PyAttribute>
1930 dunderGetItemNamed(
const std::string &name);
1934 nanobind::typed<nanobind::object, std::optional<PyAttribute>>
1935 get(
const std::string &key, nanobind::object defaultValue);
1937 void dunderSetItem(
const std::string &name,
const PyAttribute &attr);
1939 void dunderDelItem(
const std::string &name);
1943 bool dunderContains(
const std::string &name);
1945 static void forEachAttr(MlirOperation op,
1948 static void bind(nanobind::module_ &m);
1958 : operands(std::move(operands)), attributes(std::move(attributes)) {}
1960 : operands(std::move(operands)),
1961 attributes(opView.getOperation().getRef()) {}
1963 static void bind(nanobind::module_ &m);
1966 nanobind::list operands;
1972 static bool attach(
const nanobind::object &opName,
1975 static void bind(nanobind::module_ &m);
1985 static void bind(nanobind::module_ &m);
1991 static void bind(nanobind::module_ &m);
2001template <
class Func,
typename... Args>
2003 nanobind::object
cf = nanobind::cpp_function(f, args...);
2005 return std::make_unique<nanobind::object>(
2006 nanobind::module_::import_(
"builtins").attr(
"classmethod"));
2008 return classmethodFn.
get()(
cf);
2019 mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::DefaultingPyMlirContext>
2021 mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::DefaultingPyMlirContext> {
2025 mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::DefaultingPyLocation>
2027 mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::DefaultingPyLocation> {};
MLIR_FLOAT16_EXPORT bool operator==(const f16 &f1, const f16 &f2)
bool mlirValueIsABlockArgument(MlirValue value)
void mlirLocationPrint(MlirLocation location, MlirStringCallback callback, void *userData)
MlirType mlirAttributeGetType(MlirAttribute attribute)
bool mlirValueIsAOpResult(MlirValue value)
void mlirOpPrintingFlagsDestroy(MlirOpPrintingFlags flags)
void mlirTypePrint(MlirType type, MlirStringCallback callback, void *userData)
#define MLIR_PYTHON_MAYBE_DOWNCAST_ATTR
Attribute on MLIR Python objects that expose a function for downcasting the corresponding Python obje...
static std::string diag(const llvm::Value &value)
static void print(spirv::VerCapExtAttr triple, DialectAsmPrinter &printer)
static sycl::context getDefaultContext()
A CRTP base class for pseudo-containers willing to support Python-type slicing access on top of index...
nanobind::class_< PyOpResultList > ClassTy
Sliceable(intptr_t startIndex, intptr_t length, intptr_t step)
ReferrentTy * get() const
Defaulting()=default
Type casters require the type to be default constructible, but using such an instance is illegal.
PyMlirContextRef & getContext()
Accesses the context reference.
BaseContextObject(PyMlirContextRef ref)
Used in function arguments when None should resolve to the current context manager set instance.
static constexpr const char kTypeDescription[]
static PyLocation & resolve()
Defaulting()=default
Type casters require the type to be default constructible, but using such an instance is illegal.
Used in function arguments when None should resolve to the current context manager set instance.
static constexpr const char kTypeDescription[]
static PyMlirContext & resolve()
Defaulting()=default
Type casters require the type to be default constructible, but using such an instance is illegal.
Wrapper around MlirAffineExpr. Affine expressions are owned by the context.
PyAffineExpr ceilDiv(const PyAffineExpr &other) const
PyAffineExpr floorDiv(const PyAffineExpr &other) const
PyAffineExpr add(const PyAffineExpr &other) const
MlirAffineExpr get() const
PyAffineExpr mod(const PyAffineExpr &other) const
PyAffineExpr(PyMlirContextRef contextRef, MlirAffineExpr affineExpr)
nanobind::typed< nanobind::object, PyAffineExpr > maybeDownCast()
PyAffineExpr mul(const PyAffineExpr &other) const
PyAffineMap(PyMlirContextRef contextRef, MlirAffineMap affineMap)
MlirAffineMap get() const
Wrapper around an MlirAsmState.
PyAsmState(MlirValue value, bool useLocalScope)
PyAsmState(const PyAsmState &other)=delete
PyAsmState(PyAsmState &other)=delete
Wrapper around the generic MlirAttribute.
PyAttribute(PyMlirContextRef contextRef, MlirAttribute attr)
MlirAttribute get() const
Sliceable< PyBlockArgumentList, PyBlockArgument > SliceableT
PyBlockArgumentList(PyOperationRef operation, MlirBlock block, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
static constexpr const char * pyClassName
static void bindDerived(ClassTy &c)
Python wrapper for MlirBlockArgument.
static void bindDerived(ClassTy &c)
PyConcreteValue()=default
static constexpr IsAFunctionTy isaFunction
static constexpr const char * pyClassName
PyBlockIterator & dunderIter()
PyBlockIterator(PyOperationRef operation, MlirBlock next)
PyBlockList(PyOperationRef operation, MlirRegion region)
PyBlockPredecessors(PyBlock block, PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
static constexpr const char * pyClassName
PyBlockSuccessors(PyBlock block, PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
static constexpr const char * pyClassName
Wrapper around an MlirBlock.
PyOperationRef & getParentOperation()
PyBlock(PyOperationRef parentOperation, MlirBlock block)
static constexpr IsAFunctionTy isaFunction
static constexpr const char * pyClassName
PyConcreteLocation()=default
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static void bindDerived(ClassTy &c)
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static void bindDerived(ClassTy &m)
Implemented by derived classes to add methods to the Python subclass.
PyConcreteAttribute(PyMlirContextRef contextRef, MlirAttribute attr)
static void bind(nanobind::module_ &m, PyType_Slot *slots=nullptr)
nanobind::class_< DerivedTy, BaseTy > ClassTy
PyConcreteAttribute(PyAttribute &orig)
PyConcreteAttribute()=default
static MlirAttribute castFrom(PyAttribute &orig)
bool(*)(MlirAttribute) IsAFunctionTy
MlirTypeID(*)() GetTypeIDFunctionTy
static const MlirStringRef name
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static void bind(nanobind::module_ &m)
static void bindDerived(ClassTy &m)
Implemented by derived classes to add methods to the Python subclass.
PyConcreteLocation()=default
static MlirLocation castFrom(PyLocation &orig)
MlirTypeID(*)() GetTypeIDFunctionTy
PyConcreteLocation(PyLocation &orig)
PyConcreteLocation(PyMlirContextRef contextRef, MlirLocation loc)
nanobind::class_< DerivedTy, BaseTy > ClassTy
bool(*)(MlirLocation) IsAFunctionTy
nanobind::class_< DerivedTy, BaseTy > ClassTy
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static void bind(nanobind::module_ &m)
MlirTypeID(*)() GetTypeIDFunctionTy
PyConcreteType(PyMlirContextRef contextRef, MlirType t)
PyConcreteType(PyType &orig)
static const MlirStringRef name
static MlirType castFrom(PyType &orig)
bool(*)(MlirType) IsAFunctionTy
static void bindDerived(ClassTy &m)
Implemented by derived classes to add methods to the Python subclass.
PyConcreteValue(PyOperationRef operationRef, MlirValue value)
static constexpr GetTypeIDFunctionTy getTypeIdFunction
MlirTypeID(*)() GetTypeIDFunctionTy
PyConcreteValue(PyValue &orig)
PyConcreteValue()=default
static void bind(nanobind::module_ &m)
Binds the Python module objects to functions of this class.
nanobind::class_< DerivedTy, PyValue > ClassTy
bool(*)(MlirValue) IsAFunctionTy
static MlirValue castFrom(PyValue &orig)
Attempts to cast the original value to the derived type and throws on type mismatches.
static void bindDerived(ClassTy &m)
Implemented by derived classes to add methods to the Python subclass.
Represents a diagnostic handler attached to the context.
void detach()
Detaches the handler. Does nothing if not attached.
nanobind::object contextEnter()
PyDiagnosticHandler(MlirContext context, nanobind::object callback)
void contextExit(const nanobind::object &excType, const nanobind::object &excVal, const nanobind::object &excTb)
friend class PyMlirContext
Python class mirroring the C MlirDiagnostic struct.
PyDiagnostic(MlirDiagnostic diagnostic)
PyDialectDescriptor(PyMlirContextRef contextRef, MlirDialect dialect)
Wrapper around an MlirDialectRegistry.
PyDialectRegistry(PyDialectRegistry &&other) noexcept
MlirDialectRegistry get() const
PyDialectRegistry(MlirDialectRegistry registry)
PyDialectRegistry(PyDialectRegistry &)=delete
nanobind::object getDescriptor()
PyDialect(nanobind::object descriptor)
PyDialects(PyMlirContextRef contextRef)
static void bind(nanobind::module_ &m)
static const char * typeIDAttr
static bool attach(const nanobind::object &opName, const nanobind::object &target, PyMlirContext &context)
static bool attach(const nanobind::object &opName, PyMlirContext &context)
static void bind(nanobind::module_ &m)
static void bind(nanobind::module_ &m)
static bool attach(const nanobind::object &opName, PyMlirContext &context)
static constexpr IsAFunctionTy isaFunction
static void bindDerived(ClassTy &c)
static constexpr GetTypeIDFunctionTy getTypeIdFunction
PyConcreteLocation()=default
static constexpr const char * pyClassName
static void bindDerived(ClassTy &c)
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static constexpr IsAFunctionTy isaFunction
PyConcreteLocation()=default
static constexpr const char * pyClassName
static PyGlobals & get()
Most code should get the globals via this static accessor.
An insertion point maintains a pointer to a Block and a reference operation.
void insert(PyOperationBase &operationBase)
Inserts an operation.
void contextExit(const nanobind::object &excType, const nanobind::object &excVal, const nanobind::object &excTb)
static PyInsertionPoint atBlockTerminator(PyBlock &block)
Shortcut to create an insertion point before the block terminator.
static PyInsertionPoint after(PyOperationBase &op)
Shortcut to create an insertion point to the node after the specified operation.
std::optional< PyOperationRef > & getRefOperation()
static PyInsertionPoint atBlockBegin(PyBlock &block)
Shortcut to create an insertion point at the beginning of the block.
PyInsertionPoint(const PyBlock &block)
Creates an insertion point positioned after the last operation in the block, but still inside the blo...
static nanobind::object contextEnter(nanobind::object insertionPoint)
Enter and exit the context manager.
MlirIntegerSet get() const
PyIntegerSet(PyMlirContextRef contextRef, MlirIntegerSet integerSet)
Wrapper around an MlirLocation.
PyLocation(PyMlirContextRef contextRef, MlirLocation loc)
static PyMlirContextRef forContext(MlirContext context)
Returns a context reference for the singleton PyMlirContext wrapper for the given context.
PyMlirContext(PyMlirContext &&)=delete
MlirContext get()
Accesses the underlying MlirContext.
PyMlirContext(const PyMlirContext &)=delete
bool getEmitErrorDiagnostics()
void setEmitErrorDiagnostics(bool value)
Controls whether error diagnostics should be propagated to diagnostic handlers, instead of being capt...
PyModule(PyModule &)=delete
PyModuleRef getRef()
Gets a strong reference to this module.
MlirModule get()
Gets the backing MlirModule.
static PyModuleRef forModule(MlirModule module)
Returns a PyModule reference for the given MlirModule.
PyModule(PyMlirContext &&)=delete
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static constexpr IsAFunctionTy isaFunction
static constexpr const char * pyClassName
PyConcreteLocation()=default
static void bindDerived(ClassTy &c)
Represents a Python MlirNamedAttr, carrying an optional owned name.
PyNamedAttribute(MlirAttribute attr, std::string ownedName)
Constructs a PyNamedAttr that retains an owned name.
MlirNamedAttribute namedAttr
Template for a reference to a concrete type which captures a python reference to its underlying pytho...
nanobind::typed< nanobind::object, T > NBTypedT
PyObjectRef & operator=(const PyObjectRef &other)
PyObjectRef(PyObjectRef &&other) noexcept
nanobind::object releaseObject()
Releases the object held by this instance, returning it.
PyObjectRef(T *referrent, nanobind::object object)
nanobind::object getObject()
PyObjectRef & operator=(PyObjectRef &&other) noexcept
PyObjectRef(const PyObjectRef &other)
PyOpAdaptor(nanobind::list operands, PyOpAttributeMap attributes)
PyOpAdaptor(nanobind::list operands, PyOpView &opView)
A list of operation attributes.
PyOpAttributeMap(PyOperationRef operation)
PyOpOperandIterator(MlirOpOperand opOperand)
PyOpOperandIterator & dunderIter()
static constexpr const char * pyClassName
Sliceable< PyOpOperandList, PyValue > SliceableT
static constexpr std::array< const char *, 1 > typeParams
static void bindDerived(ClassTy &c)
PyOpOperandList(PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
void dunderSetItem(intptr_t index, PyValue value)
PyOpOperand(MlirOpOperand opOperand)
A list of operation results.
static void bindDerived(ClassTy &c)
Sliceable< PyOpResultList, PyOpResult > SliceableT
static constexpr std::array< const char *, 1 > typeParams
PyOpResultList(PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
PyOperationRef & getOperation()
static constexpr const char * pyClassName
Python wrapper for MlirOpResult.
static constexpr const char * pyClassName
static void bindDerived(ClassTy &c)
PyConcreteValue()=default
static constexpr IsAFunctionTy isaFunction
static void bindDerived(ClassTy &c)
static constexpr const char * pyClassName
PyOpSuccessors(PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
void dunderSetItem(intptr_t index, PyBlock block)
A PyOpView is equivalent to the C++ "Op" wrappers: these are the basis for providing more instance-sp...
PyOpView(const nanobind::object &operationObject)
PyOperation & getOperation() override
Each must provide access to the raw Operation.
nanobind::object getOperationObject()
Base class for PyOperation and PyOpView which exposes the primary, user visible methods for manipulat...
bool isBeforeInBlock(PyOperationBase &other)
Given an operation 'other' that is within the same parent block, return whether the current operation...
nanobind::object getAsm(bool binary, std::optional< int64_t > largeElementsLimit, std::optional< int64_t > largeResourceLimit, bool enableDebugInfo, bool prettyDebugInfo, bool printGenericOpForm, bool useLocalScope, bool useNameLocAsPrefix, bool assumeVerified, bool skipRegions)
virtual ~PyOperationBase()=default
void writeBytecode(const nanobind::object &fileObject, std::optional< int64_t > bytecodeVersion)
bool verify()
Verify the operation.
virtual PyOperation & getOperation()=0
Each must provide access to the raw Operation.
void moveAfter(PyOperationBase &other)
Moves the operation before or after the other operation.
void moveBefore(PyOperationBase &other)
void walk(std::function< PyWalkResult(MlirOperation)> callback, PyWalkOrder walkOrder)
PyOperationIterator(PyOperationRef parentOperation, MlirOperation next)
PyOperationIterator & dunderIter()
PyOperationList(PyOperationRef parentOperation, MlirBlock block)
MlirOperation get() const
void setInvalid()
Invalidate the operation.
friend class PyOperationBase
PyOperation & getOperation() override
Each must provide access to the raw Operation.
friend class PySymbolTable
PyOperation(PyMlirContextRef contextRef, MlirOperation operation)
static constexpr const char * pyClassName
PyRegionList(PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
Wrapper around an MlirRegion.
PyOperationRef & getParentOperation()
PyRegion(PyOperationRef parentOperation, MlirRegion region)
static constexpr const char * pyClassName
static void bindDerived(ClassTy &c)
static constexpr IsAFunctionTy isaFunction
static constexpr GetTypeIDFunctionTy getTypeIdFunction
PyConcreteAttribute()=default
static const MlirStringRef name
Bindings for MLIR symbol tables.
PySymbolTable(PyOperationBase &operation)
Constructs a symbol table for the given operation.
~PySymbolTable()
Destroys the symbol table.
Tracks an entry in the thread context stack.
PyThreadContextEntry(FrameKind frameKind, nanobind::object context, nanobind::object insertionPoint, nanobind::object location)
int getMaxConcurrency() const
PyThreadPool(PyThreadPool &&)=delete
PyThreadPool(const PyThreadPool &)=delete
A TypeID provides an efficient and unique identifier for a specific C++ type.
PyTypeID(MlirTypeID typeID)
Wrapper around the generic MlirType.
PyType(PyMlirContextRef contextRef, MlirType type)
nanobind::typed< nanobind::object, PyType > maybeDownCast()
static constexpr GetTypeIDFunctionTy getTypeIdFunction
static constexpr const char * pyClassName
PyConcreteLocation()=default
static constexpr IsAFunctionTy isaFunction
static void bindDerived(ClassTy &c)
virtual ~PyValue()=default
PyOperationRef & getParentOperation()
PyValue(PyOperationRef parentOperation, MlirValue value)
Safely calls Python initialization code on first use, avoiding deadlocks.
MlirDiagnosticSeverity
Severity of a diagnostic.
MLIR_CAPI_EXPORTED MlirDiagnosticHandlerID mlirContextAttachDiagnosticHandler(MlirContext context, MlirDiagnosticHandler handler, void *userData, void(*deleteUserData)(void *))
Attaches the diagnostic handler to the context.
MLIR_CAPI_EXPORTED void mlirContextDetachDiagnosticHandler(MlirContext context, MlirDiagnosticHandlerID id)
Detaches an attached diagnostic handler from the context given its identifier.
uint64_t MlirDiagnosticHandlerID
Opaque identifier of a diagnostic handler, useful to detach a handler.
MLIR_CAPI_EXPORTED MlirTypeID mlirStringAttrGetTypeID(void)
Returns the typeID of a String attribute.
MLIR_CAPI_EXPORTED bool mlirAttributeIsAString(MlirAttribute attr)
Checks whether the given attribute is a string attribute.
MLIR_CAPI_EXPORTED MlirStringRef mlirStringAttrGetName(void)
MLIR_CAPI_EXPORTED bool mlirLocationIsAUnknown(MlirLocation location)
Checks whether the given location is an Unknown.
MLIR_CAPI_EXPORTED MlirTypeID mlirLocationUnknownGetTypeID(void)
TypeID Getter for Unknown.
MLIR_CAPI_EXPORTED void mlirDialectRegistryDestroy(MlirDialectRegistry registry)
Takes a dialect registry owned by the caller and destroys it.
MLIR_CAPI_EXPORTED bool mlirLocationIsAFileLineColRange(MlirLocation location)
Checks whether the given location is an FileLineColRange.
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`...
@ MlirWalkResultInterrupt
MLIR_CAPI_EXPORTED bool mlirLocationIsACallSite(MlirLocation location)
Checks whether the given location is an CallSite.
static bool mlirBlockIsNull(MlirBlock block)
Checks whether a block is null.
MLIR_CAPI_EXPORTED bool mlirLocationIsAFused(MlirLocation location)
Checks whether the given location is an Fused.
MLIR_CAPI_EXPORTED void mlirSymbolTableDestroy(MlirSymbolTable symbolTable)
Destroys the symbol table created with mlirSymbolTableCreate.
MLIR_CAPI_EXPORTED bool mlirLocationIsAName(MlirLocation location)
Checks whether the given location is an Name.
static bool mlirDialectRegistryIsNull(MlirDialectRegistry registry)
Checks if the dialect registry is null.
MLIR_CAPI_EXPORTED MlirTypeID mlirLocationFileLineColRangeGetTypeID(void)
TypeID Getter for FileLineColRange.
static bool mlirRegionIsNull(MlirRegion region)
Checks whether a region is null.
MLIR_CAPI_EXPORTED MlirTypeID mlirLocationCallSiteGetTypeID(void)
TypeID Getter for CallSite.
MLIR_CAPI_EXPORTED MlirDialectRegistry mlirDialectRegistryCreate(void)
Creates a dialect registry and transfers its ownership to the caller.
MLIR_CAPI_EXPORTED MlirTypeID mlirLocationNameGetTypeID(void)
TypeID Getter for Name.
MLIR_CAPI_EXPORTED MlirTypeID mlirLocationFusedGetTypeID(void)
TypeID Getter for Fused.
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`.
static MlirStringRef mlirStringRefCreate(const char *str, size_t length)
Constructs a string reference from the pointer and length.
#define MLIR_PYTHON_API_EXPORTED
MLIR_PYTHON_API_EXPORTED MlirValue getUniqueResult(MlirOperation operation)
MLIR_PYTHON_API_EXPORTED void populateRoot(nanobind::module_ &m)
PyObjectRef< PyMlirContext > PyMlirContextRef
Wrapper around MlirContext.
PyObjectRef< PyOperation > PyOperationRef
MlirStringRef toMlirStringRef(const std::string &s)
PyObjectRef< PyModule > PyModuleRef
MlirBlock MLIR_PYTHON_API_EXPORTED createBlock(const nanobind::typed< nanobind::sequence, PyType > &pyArgTypes, const std::optional< nanobind::typed< nanobind::sequence, PyLocation > > &pyArgLocs)
Create a block, using the current location context if no locations are specified.
PyWalkOrder
Traversal order for operation walk.
MLIR_PYTHON_API_EXPORTED void populateIRCore(nanobind::module_ &m)
nanobind::object classmethod(Func f, Args... args)
Helper for creating an @classmethod.
Include the generated interface declarations.
Operation * clone(OpBuilder &b, Operation *op, TypeRange newResultTypes, ValueRange newOperands)
auto get(MLIRContext *context, Ts &&...params)
Helper method that injects context only if needed, this helps unify some of the attribute constructio...
An opaque reference to a diagnostic, always owned by the diagnostics engine (context).
A logical result value, essentially a boolean with named states.
A pointer to a sized fragment of a string, not necessarily null-terminated.
Accumulates into a python string from a method that accepts an MlirStringCallback.
MlirStringCallback getCallback()
MLIRError(std::string message, std::vector< PyDiagnostic::DiagnosticInfo > &&errorDiagnostics={})
std::vector< PyDiagnostic::DiagnosticInfo > errorDiagnostics
const char * what() const noexcept override
static bool dunderContains(const std::string &attributeKind)
static nanobind::callable dunderGetItemNamed(const std::string &attributeKind)
static void bind(nanobind::module_ &m)
static void dunderSetItemNamed(const std::string &attributeKind, nanobind::callable func, bool replace, bool allow_existing)
Materialized diagnostic information.
std::vector< DiagnosticInfo > notes
PyDiagnosticSeverity severity
Wrapper for the global LLVM debugging flag.
static void set(nanobind::object &o, bool enable)
static bool get(const nanobind::object &)
static void bind(nanobind::module_ &m)
std::vector< PyDiagnostic::DiagnosticInfo > take()
ErrorCapture(PyMlirContextRef ctx)