<div dir="ltr"><div>At the very least I've fixed my current patch to take DAG.getLibInfo().getIntSize() into account:</div><div><a href="https://reviews.llvm.org/D110508">https://reviews.llvm.org/D110508</a></div><div><br></div><div>I'm not sure regarding the point about ExpandIntRes_Rotate (or rather, TargetLowering::expandROT);</div><div>I do see other methods of TargetLowering that use getShiftAmountTy() (e.g. expandCTPOP, expandCTLZ),</div><div>whereas expandROT simply uses Op1.getValueType().</div><div><br></div><div>Itay<br></div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, 27 Sept 2021 at 18:03, Björn Pettersson A <<a href="mailto:bjorn.a.pettersson@ericsson.com">bjorn.a.pettersson@ericsson.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Could it perhaps be two bugs here?<br>
<br>
After legalization the shift amount type should match TLI.getShiftAmountTy()<br>
for SHL/SRL/ROT etc.<br>
<br>
So if DAGTypeLegalizer::ExpandIntRes_Rotate is emitting SHL/SRL nodes that<br>
has a different type for the shift amount that sounds a bit weird to me.<br>
Or is that supposed to be legalized after having expanded the rotate result?<br>
<br>
<br>
Nevertheless, DAGTypeLegalizer::ExpandIntRes_Shift can't assume that<br>
the shift amount operand already has a been legalized, so it must<br>
handle that the type isn't matching TLI.getShiftAmountTy().<br>
Although, I don't know if TLI.getShiftAmountTy() necessarily need to<br>
match with "si_int" that the LIBC function is expecting. For the libcall<br>
to be correct (ABI wise), then I think the shift amount should be converted<br>
to something that matches with DAG.getLibInfo().getIntSize().<br>
<br>
/Björn<br>
<br>
> -----Original Message-----<br>
> From: llvm-dev <<a href="mailto:llvm-dev-bounces@lists.llvm.org" target="_blank">llvm-dev-bounces@lists.llvm.org</a>> On Behalf Of Itay<br>
> Bookstein via llvm-dev<br>
> Sent: den 26 september 2021 21:21<br>
> To: llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>><br>
> Subject: [llvm-dev] [SelectionDAG] Wrong type for shift libcalls when<br>
> expanding funnelled shifts<br>
> <br>
> Hey all,<br>
> <br>
> I've recently encountered a problem after upgrading the LLVM version<br>
> of our downstream,<br>
> and it seems to reproduce in other backends as well. It's a bit<br>
> esoteric, as it's rare for<br>
> shift libcalls to be emitted at all, but I've reproduced it on top of<br>
> latest trunk and can<br>
> demonstrate the subtle codegen issue on e.g. RISCV32 (using minsize to<br>
> induce libcall<br>
> instead of expand):<br>
> <br>
> // fshr.ll<br>
> declare i64 @llvm.fshr.i64(i64, i64, i64)<br>
> <br>
> define i64 @foo(i64 %__val, i64 %__shift) minsize {<br>
>   %cond = tail call i64 @llvm.fshr.i64(i64 %__val, i64 %__val, i64<br>
> %__shift)<br>
>   ret i64 %cond<br>
> }<br>
> <br>
> RUN:<br>
> llc --mtriple=riscv32 fshr.ll -o -<br>
> <br>
> OUTPUT:<br>
> [snipped]<br>
> mv s0, a2<br>
> mv s2, a1<br>
> mv s1, a0<br>
> andi a2, a2, 63<br>
> mv a3, zero ; This is redundant<br>
> call __lshrdi3@plt<br>
> mv s3, a0<br>
> mv s4, a1<br>
> neg a0, s0<br>
> andi a2, a0, 63<br>
> mv a0, s1<br>
> mv a1, s2<br>
> mv a3, zero ; This is redundant<br>
> call __ashldi3@plt<br>
> or a0, s3, a0<br>
> or a1, s4, a1<br>
> [snipped]<br>
> <br>
> The problem is that TargetLowering::makeLibCall is called with<br>
> Ops[1].getValueType() == MVT::i64<br>
> from DAGTypeLegalizer::ExpandIntRes_Shift, which is incorrect because<br>
> shift libcalls have MVT::i32<br>
> for their second argument (. In this particular case, this leads to a<br>
> harmless-but-redundant zeroing<br>
> of a register, but in the general case it's an ABI mismatch.<br>
> <br>
> The path that the SelectionDAG node undergoes is:<br>
> 1. SelectionDAGBuilder::visitIntrinsicCall, Intrinsic::fshr, X == Y =><br>
> create ISD::ROTR.<br>
> 2. DAGTypeLegalizer::ExpandIntRes_Rotate<br>
> 3. TargetLowering::expandROT => No support for rotate, create shifts<br>
> (but with ShVT = Op1.getValueType(), so MVT::i64)<br>
> 4. DAGTypeLegalizer::ExpandIntRes_Shift => Libcallize => called with {<br>
> N->getOperand(0), N->getOperand(1) } as operands, but the second<br>
> operand is MVT::i64.<br>
> <br>
> When I traced the path that regular shifts undergo, they start out<br>
> life already with shift amount type according to TLI<br>
> getShiftAmountType() + some logic to extend/truncate, see<br>
> SelectionDAGBuilder::visitShift.<br>
> <br>
> I think a correct fix would be to change ExpandIntRes_Shift's<br>
> libcallization flow to ZExtOrTrunc (or potentially AnyExtOrTrunc) the<br>
> second argument to MVT::i32,<br>
> but I don't have enough perspective to be confident that that's a<br>
> correct and sufficient fix.<br>
> <br>
> Appreciate your input!<br>
> --<br>
> Itay Bookstein<br>
> Software Engineer<br>
> NEXTSILICON<br>
> <br>
> --<br>
> This e-mail message and any attachments thereto are intended only for the<br>
> person or entity to which it is addressed and may contain confidential<br>
> and/or privileged material. Any retransmission, dissemination, copying or<br>
> other use of, or taking of any action in reliance upon this information is<br>
> prohibited. If you are not the intended addressee, please contact the<br>
> sender immediately and delete the materials and information from your<br>
> device and system and confirm the deletion by reply e-mail.<br>
> _______________________________________________<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="https://protect2.fireeye.com/v1/url?k=44f7d169-1b6ce86c-44f791f2-" rel="noreferrer" target="_blank">https://protect2.fireeye.com/v1/url?k=44f7d169-1b6ce86c-44f791f2-</a><br>
> 86d2114eab2f-a8ea707c0a15247d&q=1&e=f01c1b77-b865-48b7-88fc-<br>
> 96d7dd0e603e&u=https%3A%2F%<a href="http://2Flists.llvm.org" rel="noreferrer" target="_blank">2Flists.llvm.org</a>%2Fcgi-<br>
> bin%2Fmailman%2Flistinfo%2Fllvm-dev<br>
</blockquote></div><br clear="all"><br>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr"><br><div dir="ltr" style="margin-left:0pt" align="left"><table style="border:medium none;border-collapse:collapse"><colgroup><col width="161"><col width="7"><col width="456"></colgroup><tbody><tr style="height:66pt"><td style="border-right:0.99609pt solid rgb(0,0,0);vertical-align:middle;overflow:hidden"><p dir="ltr" style="line-height:1.44;margin-top:0pt;margin-bottom:0pt"><span style="font-size:11pt;font-family:Arial;color:rgb(0,0,0);background-color:transparent;font-weight:400;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap"><span style="border:medium none;display:inline-block;overflow:hidden;width:116px;height:95px"><img src="https://lh4.googleusercontent.com/7rYiGOh3UBk77Ckm5RrwmnTFsVLTXFJtNn82VN6DNeLI6URbhWJhs_KhgzoUAOGTWegGg3FLlgVRLcjB_QCtYp6AcQ6H5gvzlBpzHUf31_OUDAScABI5mI4k1PyFfCoaInRKJfAY" style="margin-left: 0px; margin-top: 0px;" width="116" height="95"></span></span><span style="font-size:11pt;font-family:Arial;color:rgb(0,0,0);background-color:transparent;font-weight:400;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap">    </span></p></td><td style="border-left:0.99609pt solid rgb(0,0,0);vertical-align:top;overflow:hidden"><br></td><td style="vertical-align:middle;overflow:hidden"><p dir="ltr" style="line-height:1.44;margin-left:6.75pt;margin-top:0pt;margin-bottom:0pt"><span style="font-family:arial,sans-serif"><span style="font-size:14pt;color:rgb(34,34,34);background-color:transparent;font-weight:700;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap">Itay Bookstein</span></span></p><p dir="ltr" style="line-height:1.44;margin-left:6.75pt;margin-top:0pt;margin-bottom:0pt"><span style="font-family:arial,sans-serif"><span style="font-size:10pt;color:rgb(34,34,34);background-color:transparent;font-weight:400;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap">Software Engineer</span></span></p><span style="font-family:arial,sans-serif"><br></span><p dir="ltr" style="line-height:1.44;margin-left:6.75pt;margin-top:0pt;margin-bottom:0pt"><span style="font-family:arial,sans-serif"><span style="font-size:10pt;color:rgb(34,34,34);background-color:rgb(255,255,255);font-weight:700;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap">NEXT</span><span style="font-size:10pt;color:rgb(34,34,34);background-color:rgb(255,255,255);font-weight:400;font-style:normal;font-variant:normal;text-decoration:none;vertical-align:baseline;white-space:pre-wrap">SILICON</span></span></p><br></td></tr></tbody></table></div></div></div>

<br>
<font size="1">This e-mail message and any attachments thereto are intended only for the person or entity to which it is addressed and may contain confidential and/or privileged material. Any retransmission, dissemination, copying or other use of, or taking of any action in reliance upon this information is prohibited. If you are not the intended addressee, please contact the sender immediately and delete the materials and information from your device and system and confirm the deletion by reply e-mail.</font>