This is modeled after the same functionality for jump tables, which was added in r357067.
Details
Diff Detail
Event Timeline
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2622 | Please pre-commit this and other cosmetic diffs. | |
llvm/test/CodeGen/X86/switch-bt.ll | ||
161–179 | Please add this test with baseline CHECK lines as a pre-commit for this patch, so we show the functional difference from this patch. Does this test cover both sides of the 'if' in the new code? (MBB != NextBlock(SwitchBB)) and (MBB == NextBlock(SwitchBB)) If not, can you add another test to provide that coverage? |
Thanks for the patch! Just some small thoughts on style.
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2662–2663 | Please prefer: if true: foo() else: bar() to if !true: bar() else foo() | |
2665 | If you declared a SDValue before the conditional, you could simply initialize it in these branches, and share the setRoot assignment after the conditional. |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2630–2633 | Can we sink RangeCmp into the !OmitRangeCheck block below? As written, we are potentially creating a node with no uses? | |
2666–2667 | Is the optional branch to MBB identical on both sides of this if/else? If so, sink it after the if/else (and that simplifies the if/else to just !OmitRangeCheck)? |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2674 | This statement and conditional matches L2667. I think we could flip the conditionals/check for this first? DRY |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2630–2633 | It's a bit annoying, because by the time we're down here, the code above has changed the value of Sub which we would use in RangeCmp. But that can be fixed of course.. doing that. |
llvm/test/CodeGen/X86/switch-bt.ll | ||
---|---|---|
165 | Can you (re)generate CHECKs with update_llc_test_checks.py? |
llvm/test/CodeGen/X86/switch-bt.ll | ||
---|---|---|
165 | Why? It's a hand-written test, and the point of the patch is specifically to omit the cmp here. |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2655 | So it seems to me that CopyTo might not even end up as the root. It looks like we have 3 cases that affect the root:
For cases 1 and 2, we do all this wasteful work to create CopyTo and Sub, just to throw it away. It seems like RangeSub isn't needed for case 2. I think it would be clearer and do less work for each case to have a simple 3 arm conditional, rather than successive conditionals that may just throw away previous work to reassign to Root. |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2655 | Note that Root below isn't just assigned to, it's also passed as an argument when creating BRCOND or the BR node. So in the cases where CopyTo doesn't end up being the root, it's been passed as the chain element to one of those instructions. In all cases, it is on the chain -- it's never thrown away. (And neither is RangeSub since it's an input to CopyTo.) I realize that's maybe not super clear, but I think this style of updating the selection dag root by using the old root as the chain of the new root is common. |
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | ||
---|---|---|
2655 | yep, sorry I missed that. |
@hans This is causing EXPENSIVE_CHECKS failures, please can you take a look? http://lab.llvm.org:8011/builders/llvm-clang-x86_64-expensive-checks-win/builds/19967
Sorry about that. Reverted in r373454 until I can investigate it properly. Hopefully it's just a simple fix :-)
Please pre-commit this and other cosmetic diffs.