[llvm] Introducing a new ISD::POISON SDNode to represent the poison value in the IR. (PR #125883)
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 26 22:40:15 PST 2025
================
@@ -690,8 +690,17 @@ END_TWO_BYTE_PACK()
/// \<target\>ISD namespace).
bool isTargetOpcode() const { return NodeType >= ISD::BUILTIN_OP_END; }
- /// Return true if the type of the node type undefined.
- bool isUndef() const { return NodeType == ISD::UNDEF; }
+ /// Returns true if the node type is UNDEF or, when DoNotIncludeExplicitPoison
+ /// is false, POISON.
+ /// @param DoNotIncludeExplicitPoison Determines whether to check only for
+ /// UNDEF.
+ bool isUndef(bool DoNotIncludeExplicitPoison = false) const {
+ return NodeType == ISD::UNDEF ||
+ (!DoNotIncludeExplicitPoison && NodeType == ISD::POISON);
----------------
arsenm wrote:
I don't see much point in the parameter. The helper is for checking the 2 opcodes. If you wanted just one or the other you can directly check the opcode
https://github.com/llvm/llvm-project/pull/125883
More information about the llvm-commits
mailing list