[PATCH] D64174: [DAGCombine] Do several rounds of combine for addcarry nodes.
Craig Topper via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 16 09:57:22 PDT 2019
craig.topper added inline comments.
================
Comment at: test/CodeGen/X86/addcarry.ll:326
+; CHECK-NEXT: adcq %rdi, %rbx
+; CHECK-NEXT: addq %r10, %rdx
+; CHECK-NEXT: adcq %rdi, %rcx
----------------
RKSimon wrote:
> deadalnix wrote:
> > craig.topper wrote:
> > > Doesn't this add and adc compute the same result as line 321 and 325?
> > There is a lot of duplication that is generated by this. But once the carry propagation is "linearized" because you removed all the diamonds, then a simple set of optimization can get rid of it all. See D57317 for that specific case.
> Would adding X86ISD::ADD to X86TargetLowering::isCommutativeBinOp help with this?
If I remember right from what I saw in the DAG. We need to CSE ISD::ADDCARRY with commuted operands in DAG combine. Not sure about the X86ISD node.
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64174/new/
https://reviews.llvm.org/D64174
More information about the llvm-commits
mailing list