<div dir="ltr"><div>[adding back llvm-dev and cc'ing Craig]<br></div><div><br></div><div>I think you are asking if we are missing a fold (or your target is missing enabling another hook) to transform the sext+add into shift+or? I think the answer is 'yes'. We probably should add that fold. This seems like a similar case as the recent:<a href="https://reviews.llvm.org/D48466" rel="noreferrer" target="_blank"> https://reviews.llvm.org/<wbr>D48466</a><br></div><div><br></div><div>Note that on x86, the sext+add becomes zext+sub:</div><div> t20: i8 = setcc t3, Constant:i16<-1>, setgt:ch<br> t24: i16 = zero_extend t20<br> t17: i16 = sub Constant:i16<5>, t24<br><br></div><div>Would that transform help your target?<br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Jul 3, 2018 at 3:55 PM, Yuan Lin <span dir="ltr"><<a href="mailto:yualin@google.com" target="_blank">yualin@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi, Roman and Sanjay,<div><br></div><div> Thank you for your reply! We currently do run DAGCombiner, but didn't implement this specific transformation. I just tried turning on convertSelectOfCosntantsToMath<wbr>() in our ISelLowering, but that doesn't quite work because it generated a sign_extend op from i1 to i16, which our backend currently doesn't support. </div><div><br></div><div> Does the DAGCombiner already has this transformation implemented?</div><div><br></div><div>Thanks,</div><div>--Yuan</div></div><div class="HOEnZb"><div class="h5"><br><div class="gmail_quote"><div dir="ltr">On Tue, Jul 3, 2018 at 11:22 AM Sanjay Patel <<a href="mailto:spatel@rotateright.com" target="_blank">spatel@rotateright.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>Do you run DAGCombiner? And are you overriding TLI.<wbr>convertSelectOfConstantsToMath<wbr>(VT) for your target?</div><div><br></div><div>For the stated example (true val and false val constants in the select differ by 1), that should already be converted.<br></div><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Jul 3, 2018 at 12:13 PM, Roman Lebedev <span dir="ltr"><<a href="mailto:lebedev.ri@gmail.com" target="_blank">lebedev.ri@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>On Tue, Jul 3, 2018 at 9:06 PM, Yuan Lin via llvm-dev<br>
<<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
> Hi, Sanjay/all,<br>
><br>
> I noticed in rL331486 that some compare-select optimizations are disabled<br>
> in favor of providing canonicalized cmp+select to the backend.<br>
><br>
> I am currently working on a private backend target, and the target has a<br>
> small code size limit. With this change, some of the apps went over the<br>
> codesize limit. As an example,<br>
><br>
> C code:<br>
> b = (a > -1) ? 4 : 5;<br>
><br>
> ll code:<br>
> Before rL331486:<br>
> %0 = lshr i16 %a.0.a.0., 15<br>
> %1 = or i16 %0, 4<br>
><br>
> After rL331486:<br>
> %cmp = icmp sgt i16 %a.0.a.0., -1<br>
> %cond = select i1 %cmp, i16 4, i16 5<br>
><br>
> With the various encoding restrictions of my particular target, the<br>
> cmp/select generated slightly larger code size. However, because the apps<br>
> were very close to the code size limit, this slight change pushed them over<br>
> the limit.<br>
><br>
> If I still prefer to have this optimization performed, then is my best<br>
> strategy moving forward to implement this optimization as a peephole opt in<br>
> my backend?<br>
</span>I personally think it should probably be a DAGCombine transform,<br>
driven by a Target Transform Info hook (e.g. like hasAndNot()).<br>
<br>
> Thanks,<br>
> --Yuan<br>
Roman.<br>
<br>
> ______________________________<wbr>_________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-dev</a><br>
><br>
</blockquote></div><br></div>
</blockquote></div>
</div></div></blockquote></div><br></div>