<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Mar 15, 2016 at 2:21 PM, Krzysztof Parzyszek via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span class="">On 3/15/2016 4:16 PM, Rail Shafigulin via llvm-dev wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
Below is the output of llc with a -debug-only=isel. As you could see the<br>
output type for load, store, and add changes from v4i32 to i32 during<br>
legalization. How can I preserve the output type to v4i32?<br>
</blockquote>
<br></span>
Make sure that there is a register class associated with v4i32.<br>
<br>
See TargetLoweringBase::addRegisterClass. It's generally called in <target>ISelLowering.cpp.<span class=""><font color="#888888"><br>
<br>
-Krzysztof<br>
<br>
-- <br>
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation<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="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</font></span></blockquote></div><br>I'd like to ask you another question (if you don't mind). My EsenciaISelLowering.cpp contains the following code in the EsenciaTargetLowering class constructor:</div><div class="gmail_extra"><br></div><div class="gmail_extra"><div class="gmail_extra">  setOperationAction(ISD::BR_CC,             MVT::i32, Custom);</div><div class="gmail_extra">  setOperationAction(ISD::BR_CC,             MVT::f32, Custom);</div><div class="gmail_extra">  setOperationAction(ISD::BR_JT,             MVT::Other, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::BRCOND,            MVT::Other, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::SETCC,             MVT::i32, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::SETCC,             MVT::f32, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::SELECT,            MVT::i32, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::SELECT,            MVT::f32, Expand);</div><div class="gmail_extra">  setOperationAction(ISD::SELECT_CC,         MVT::i32, Custom);</div><div class="gmail_extra">  setOperationAction(ISD::SELECT_CC,         MVT::f32, Custom);</div><div><br></div><div>I sort of have an intuition what it is doing, but quite nail it.Do you mind explaining it? Also I didn't add any of the setOperationAction for the MVT::v4i32 and my simple test case worked. How come?</div><div><br></div><div><br></div>-- <br><div class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div>Rail Shafigulin<br></div>Software Engineer <br>Esencia Technologies<br></div></div></div></div>
</div></div>