<div dir="ltr">Hello,<div><br></div><div>thank you for your feedback guys!</div><div><br></div><div>Answers to everybody:</div><div><br></div><div>- Pete: Thanks for that, seems like clang-format-diff doesn't understand DEBUG() macros ... :P</div>
<div>- Philip: I removed as much whitespace changes as I could find</div><div>- Eric: I changed the comment in head to switchConvert to explain the new Upper and LowerBound arguments (is that what you meant?)</div><div><br>
</div><div>Cheers,</div><div>Marcello</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">2014-06-10 18:14 GMT+01:00 Eric Christopher <span dir="ltr"><<a href="mailto:echristo@gmail.com" target="_blank">echristo@gmail.com</a>></span>:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">While you're in there updating the documentation for switchConvert<br>
would be good as well.<br>
<span class="HOEnZb"><font color="#888888"><br>
-eric<br>
</font></span><div class="im HOEnZb"><br>
On Tue, Jun 10, 2014 at 5:26 AM, Marcello Maggioni <<a href="mailto:hayarms@gmail.com">hayarms@gmail.com</a>> wrote:<br>
</div><div class="HOEnZb"><div class="h5">> Hello,<br>
><br>
> when LowerSwitch transforms a switch instruction into a tree of ifs it is<br>
> actually performing a binary search into the various case ranges, to see if<br>
> the current value falls into one cases range of values.<br>
><br>
> So, if we have a program with something like this:<br>
><br>
> switch (a) {<br>
> case 0:<br>
>   do0();<br>
>   break;<br>
> case 1:<br>
>   do1();<br>
>   break;<br>
> case 2:<br>
>   do2();<br>
>   break;<br>
> default:<br>
>   break;<br>
> }<br>
><br>
> the code produced is something like this:<br>
><br>
>   if (a < 1) {<br>
>     if (a == 0) {<br>
>       do0();<br>
>     }<br>
>   } else {<br>
>     if (a < 2) {<br>
>       if (a == 1) {<br>
>         do1();<br>
>       }<br>
>     } else {<br>
>       if (a == 2) {<br>
>         do2();<br>
>       }<br>
>     }<br>
>   }<br>
><br>
> This code is inefficient because the check (a == 1) to execute do1() is not<br>
> needed.<br>
><br>
> The reason is that because we already checked that (a >= 1) initially by<br>
> checking that also  (a < 2) we basically already inferred that (a == 1)<br>
> without the need of an extra basic block spawned to check if actually (a ==<br>
> 1).<br>
><br>
> The proposed patch addresses this problem by keeping track of already<br>
> checked bounds in the LowerSwitch algorithm, so that when the time arrives<br>
> to produce a Leaf Block that checks the equality with the case value / range<br>
> the algorithm can decide if that block is really needed depending on the<br>
> already checked bounds .<br>
><br>
> For example, the above with "a = 1" would work like this:<br>
><br>
> the bounds start as LB: NONE , UB: NONE<br>
> as (a < 1) is emitted the bounds for the else path become LB: 1 UB: NONE.<br>
> This happens because by failing the test (a < 1) we know that the value "a"<br>
> cannot be smaller than 1 if we enter the else branch.<br>
> After the emitting the check (a < 2) the bounds in the if branch become LB:<br>
> 1 UB: 1. This is because by checking that "a" is smaller than 2 then the<br>
> upper bound becomes 2 - 1 = 1.<br>
><br>
> When is time to emit the leaf block for "case 1:" we notice that 1 is<br>
> squeezed exactly in between the LB and UB, which means that if we arrived to<br>
> that block there is no need to emit a block that checks if (a == 1).<br>
><br>
><br>
> Please let me know if I did something wrong here and if the reasoning is<br>
> correct :)<br>
><br>
> The proposed patch also sets as XFAIL the test:<br>
> "test/Transforms/LowerSwitch/feature.ll".<br>
> This test checks that the emitted lowered CFG is exactly the one expected by<br>
> the previous algorithm without this optimization. Of course this test starts<br>
> failing when this optimization is added. I added another test that is the<br>
> same, but is updated with the new expected CFG.<br>
><br>
> Don't know what is the best thing to do with the original "feature.ll" test<br>
> in the case this patch gets accepted. Should we remove it or keep it as a<br>
> reference?<br>
><br>
> Cheers,<br>
> Marcello<br>
><br>
</div></div><div class="HOEnZb"><div class="h5">> _______________________________________________<br>
> llvm-commits mailing list<br>
> <a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
><br>
</div></div></blockquote></div><br></div>