[llvm] [SelectionDAG] Simplify classof of MemSDNode and MemIntrinsicSDNode (NFC) (PR #115720)

Sergei Barannikov via llvm-commits llvm-commits at lists.llvm.org
Mon Nov 11 12:10:38 PST 2024


================
@@ -708,15 +708,7 @@ END_TWO_BYTE_PACK()
   bool isUndef() const { return NodeType == ISD::UNDEF; }
 
   /// Test if this node is a memory intrinsic (with valid pointer information).
-  /// INTRINSIC_W_CHAIN and INTRINSIC_VOID nodes are sometimes created for
-  /// non-memory intrinsics (with chains) that are not really instances of
-  /// MemSDNode. For such nodes, we need some extra state to determine the
-  /// proper classof relationship.
-  bool isMemIntrinsic() const {
-    return (NodeType == ISD::INTRINSIC_W_CHAIN ||
-            NodeType == ISD::INTRINSIC_VOID) &&
-           SDNodeBits.IsMemIntrinsic;
-  }
+  bool isMemIntrinsic() const { return SDNodeBits.IsMemIntrinsic; }
----------------
s-barannikov wrote:

structs other than `SDNodeBitfields` have first `NumSDNodeBits` reserved.
That is, `IsMemIntrinsic` is shared between all structs in the union.

I think the opcode check is a historical artefact.


https://github.com/llvm/llvm-project/pull/115720


More information about the llvm-commits mailing list