[PATCH] D60982: [SimplifyCFG] Use lookup tables when they are more space efficient or a huge speed win.
Shawn Landden via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 25 11:52:05 PDT 2019
shawnl marked 2 inline comments as done.
shawnl added a comment.
Thanks for the review!
I've split the other patch into 5 distinct patches, which I will submit once I run the tests.
There is one part of this review that I need some clarification on before I can rev this patch. (see below comment)
================
Comment at: lib/Transforms/Utils/SimplifyCFG.cpp:5386
+ Value *V;
+ if (match(SI->getCondition(), m_Add(m_Value(V), m_ConstantInt(CAdd))) ||
+ match(SI->getCondition(), m_Sub(m_Value(V), m_ConstantInt(CSub))) ||
----------------
jmolloy wrote:
> This assumes whatever constant add/sub/xor was planted still exists. There's no guarantee of that; for example if V is a constant, IRBuilder would have constant folded immediately.
>
> In general unstitching code like this is inherently problematic. Note that isn't the same as planting an inverting code sequence - that's fine. We can use the optimizer to clean the duplicated stuff up and everyone is happy. That is much preferable to hamhandedly unstitching stuff and looking for patterns of code you've just emitted. It also adds an implicit contract between different parts of SimplifyCFG that I guarantee someone will miss when they update this code :)
The Xor wasn't added by this stuff. The problem is that this pass gets run multiple times, sometimes without the table generation (because it can make the code analyzable). There is nowhere else this optimization can go, because it is an optimization specific to switch statements, where the operands can be re-ordered arbitrarily. Also, there is no assumption that these things are there. It simply sees if they are there and if so removed them and then returns true so that the other optimizations run before we continue.
So I feel this is a planted inverting code sequence: this is not "unstitching" (and the code does not generate xors but does remove them): it is an optimization specific to covered tables.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D60982/new/
https://reviews.llvm.org/D60982
More information about the llvm-commits
mailing list