[llvm] [LegalizeTypes] Use UpdateNodeOperands in SoftPromoteHalfOp_STACKMAP/PATCHPOINT. (PR #165927)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Oct 31 14:48:48 PDT 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-llvm-selectiondag
Author: Craig Topper (topperc)
<details>
<summary>Changes</summary>
---
Full diff: https://github.com/llvm/llvm-project/pull/165927.diff
1 Files Affected:
- (modified) llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp (+4-18)
``````````diff
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp
index bf1abfe50327e..1178b6fba6f0b 100644
--- a/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp
@@ -3957,28 +3957,14 @@ SDValue DAGTypeLegalizer::SoftPromoteHalfOp_ATOMIC_STORE(SDNode *N,
SDValue DAGTypeLegalizer::SoftPromoteHalfOp_STACKMAP(SDNode *N, unsigned OpNo) {
assert(OpNo > 1); // Because the first two arguments are guaranteed legal.
SmallVector<SDValue> NewOps(N->ops());
- SDValue Op = N->getOperand(OpNo);
- NewOps[OpNo] = GetSoftPromotedHalf(Op);
- SDValue NewNode =
- DAG.getNode(N->getOpcode(), SDLoc(N), N->getVTList(), NewOps);
-
- for (unsigned ResNum = 0; ResNum < N->getNumValues(); ResNum++)
- ReplaceValueWith(SDValue(N, ResNum), NewNode.getValue(ResNum));
-
- return SDValue(); // Signal that we replaced the node ourselves.
+ NewOps[OpNo] = GetSoftPromotedHalf(NewOps[OpNo]);
+ return SDValue(DAG.UpdateNodeOperands(N, NewOps), 0);
}
SDValue DAGTypeLegalizer::SoftPromoteHalfOp_PATCHPOINT(SDNode *N,
unsigned OpNo) {
assert(OpNo >= 7);
SmallVector<SDValue> NewOps(N->ops());
- SDValue Op = N->getOperand(OpNo);
- NewOps[OpNo] = GetSoftPromotedHalf(Op);
- SDValue NewNode =
- DAG.getNode(N->getOpcode(), SDLoc(N), N->getVTList(), NewOps);
-
- for (unsigned ResNum = 0; ResNum < N->getNumValues(); ResNum++)
- ReplaceValueWith(SDValue(N, ResNum), NewNode.getValue(ResNum));
-
- return SDValue(); // Signal that we replaced the node ourselves.
+ NewOps[OpNo] = GetSoftPromotedHalf(NewOps[OpNo]);
+ return SDValue(DAG.UpdateNodeOperands(N, NewOps), 0);
}
``````````
</details>
https://github.com/llvm/llvm-project/pull/165927
More information about the llvm-commits
mailing list