[Mlir-commits] [mlir] 1618d09 - [TypeID] Update private typeid definition in `DeferredLocInfo` (#128968)
llvmlistbot at llvm.org
llvmlistbot at llvm.org
Thu Feb 27 13:36:41 PST 2025
Author: Stef Lindall
Date: 2025-02-27T13:36:38-08:00
New Revision: 1618d09ce7846aca3d193aa02843ad29c8e638be
URL: https://github.com/llvm/llvm-project/commit/1618d09ce7846aca3d193aa02843ad29c8e638be
DIFF: https://github.com/llvm/llvm-project/commit/1618d09ce7846aca3d193aa02843ad29c8e638be.diff
LOG: [TypeID] Update private typeid definition in `DeferredLocInfo` (#128968)
The parser's `DeferredLocInfo` uses an uncommon TypeID setup, where it
defines a private TypeID for pointers to the struct.
When using the fallback TypeID mechanism introduced in
https://github.com/llvm/llvm-project/pull/126999, the fallback TypeID
mechanism doesn't support anonymous namespaces, and the
`INTERNAL_INLINE` mechanism doesn't support pointer types.
Explicitly use `SELF_OWNING_TYPE_ID` for this case. This should always
be safe for anonymous namespaces.
Added:
Modified:
mlir/lib/AsmParser/Parser.cpp
Removed:
################################################################################
diff --git a/mlir/lib/AsmParser/Parser.cpp b/mlir/lib/AsmParser/Parser.cpp
index c316f34d977e9..168231af9b410 100644
--- a/mlir/lib/AsmParser/Parser.cpp
+++ b/mlir/lib/AsmParser/Parser.cpp
@@ -839,8 +839,8 @@ class OperationParser : public Parser {
};
} // namespace
-MLIR_DECLARE_EXPLICIT_TYPE_ID(OperationParser::DeferredLocInfo *)
-MLIR_DEFINE_EXPLICIT_TYPE_ID(OperationParser::DeferredLocInfo *)
+MLIR_DECLARE_EXPLICIT_SELF_OWNING_TYPE_ID(OperationParser::DeferredLocInfo *)
+MLIR_DEFINE_EXPLICIT_SELF_OWNING_TYPE_ID(OperationParser::DeferredLocInfo *)
OperationParser::OperationParser(ParserState &state, ModuleOp topLevelOp)
: Parser(state), opBuilder(topLevelOp.getRegion()), topLevelOp(topLevelOp) {
More information about the Mlir-commits
mailing list