<div dir="ltr"><div>Thank You so much...</div><div>The hardware is designed already and it cannot afford large size masks for large vectors. So I m opting for direction 2. Also I did try the patch but i was getting some errors.</div><div><br></div><div>Can you please guide me how to proceed with direction 2?</div><div><br></div><div>Thank You</div><div>Regards<br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Aug 3, 2018 at 3:28 AM, Saito, Hideki <span dir="ltr"><<a href="mailto:hideki.saito@intel.com" target="_blank">hideki.saito@intel.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
Hi Hameeza,<br>
<br>
Aside from Ashutosh's patch.....<br>
<br>
When the vector width is that large, we can't keep vectorizing remainder like below. It'll be a huge code size if nothing else ---- hitting ITLB miss because of this is very bad, for example.<br>
        VF=2048 // main vector loop<br>
        VF=1024 // vectorized remainder 1<br>
        VF=512   // vectorized remainder 2<br>
        ...<br>
        Vectorize remainder until trip count is small enough for scalar execution.<br>
<br>
Direction #1<br>
Does your HW support efficient masking? If so, the first thing to try is VF=2048 with masking so that you won't have any remainder loop. In other words, bump up the trip count to the multiple of 2048 and then have an IF branch inside the loop body so that beyond the original trip count is a no-op. Then vectorize that loop.<br>
<br>
        For (i=0;i<N;i++){<br>
                body<br>
        }<br>
==><br>
        For (i=0;i<M;i++){ // where M is a multiple of 2048<br>
                If (I < N) {<br>
                        Body<br>
                }<br>
        }<br>
<br>
If your HW can't execute vector version of the above loop efficiently enough, it's already busted. Typically, when VF is that large, what you'll get in the remainder is masked vector like below, and vec_remainder_body is reasonably hot as you say in your original mail. As such, remainder loop vectorization isn't a solution for that problem.<br>
<br>
        for (i=0;i<N;i+=2048){<br>
                Vec_body<br>
        }<br>
        for (i<M;i+=1024){ // where M is the smallest multiple of 1024 over N<br>
                If (I < N) {<br>
                        Vec_Remainder_Body<br>
                }<br>
        }<br>
<br>
If your HW designers insist that the compiler to generate<br>
        VF=2048 // main vector loop<br>
        VF=1024 // vectorized remainder 1<br>
        VF=512  // vectorized remainder 2<br>
        ...<br>
        Remainder is small enough for scalar.<br>
I suggest you go back and tell them to reconsider the HW design such that the Direction #1 works well enough on the HW.<br>
<br>
Direction #2<br>
In the meantime, if you are really stuck in the situation (i.e,, HW is already built and you don't have much time), the simplest thing for you to do is to run the LV second (third/fourth/...) time, after marking the remainder loop with the metadata so that you know which loops you want to deal with in the second round. It's very much of a hack but it'll be a small change you need to make and that way you are not much impacted by other changes VPlan project is making. If you have a major change outside of the trunk, you may be hit hard.<br>
<br>
Direction #3<br>
If you are given time to do the right implementation of remainder loop vectorization, please join the VPlan bandwagon and work on it there. Major development like this should happen on VPlans. Please let us know if you can do that. Ashutosh, how about you?<br>
<br>
Hopefully, one or more of the four alternative directions to consider, including Ashutosh's patch, would work for you.<br>
<br>
Thanks,<br>
Hideki<br>
-------------------<br>
Date: Mon, 30 Jul 2018 05:16:15 +0000<br>
From: "Nema, Ashutosh via llvm-dev" <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>><br>
<span class="im HOEnZb">To: hameeza ahmed <<a href="mailto:hahmed2305@gmail.com">hahmed2305@gmail.com</a>>, Craig Topper<br>
        <<a href="mailto:craig.topper@gmail.com">craig.topper@gmail.com</a>>, Hal Finkel <<a href="mailto:hfinkel@anl.gov">hfinkel@anl.gov</a>>, "Friedman,<br>
        Eli" <<a href="mailto:efriedma@codeaurora.org">efriedma@codeaurora.org</a>><br>
Cc: llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>><br>
</span><span class="im HOEnZb">Subject: Re: [llvm-dev] Vectorizing remainder loop<br>
<br>
Hi Hameeza,<br>
<br>
At this point Loop Vectorizer does not have capability to vectorize epilog/remainder loop.<br>
Sometime back there is an RFC on epilog loop vectorization but it did not went through because of concerns.<br>
This RFC has a patch as well, maybe you can give a try with it.<br>
<a href="http://llvm.1065342.n5.nabble.com/llvm-dev-Proposal-RFC-Epilog-loop-vectorization-tt106322.html#none" rel="noreferrer" target="_blank">http://llvm.1065342.n5.nabble.<wbr>com/llvm-dev-Proposal-RFC-<wbr>Epilog-loop-vectorization-<wbr>tt106322.html#none</a><br>
<br>
- Ashutosh<br>
<br>
From: llvm-dev <<a href="mailto:llvm-dev-bounces@lists.llvm.org">llvm-dev-bounces@lists.llvm.<wbr>org</a>> On Behalf Of hameeza ahmed via llvm-dev<br>
Sent: Sunday, July 29, 2018 10:24 PM<br>
To: llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>>; Craig Topper <<a href="mailto:craig.topper@gmail.com">craig.topper@gmail.com</a>>; Hal Finkel <<a href="mailto:hfinkel@anl.gov">hfinkel@anl.gov</a>>; Friedman, Eli <<a href="mailto:efriedma@codeaurora.org">efriedma@codeaurora.org</a>><br>
Subject: Re: [llvm-dev] Vectorizing remainder loop<br>
<br>
Please help in solving this issue. the issue of scalar remainder loop is really big and significant with large vector widths.<br>
<br>
Please help<br>
<br>
Thank You<br>
<br>
</span><div class="HOEnZb"><div class="h5">On Sun, Jul 29, 2018 at 2:52 PM, hameeza ahmed <<a href="mailto:hahmed2305@gmail.com">hahmed2305@gmail.com</a><mailto:<a href="mailto:hahmed2305@gmail.com">h<wbr>ahmed2305@gmail.com</a>>> wrote:<br>
Hello, I m working on a hardware with very large vector width till v2048. Now when I vectorize using llvm default vectorizer maximum 2047 iterations are scalar remainder loop. These are not vectorized by llvm which increases the cost. However these should be vectorized using next available vector width I.e v1024, v512, v256, v128, v64, v32, v16, v8, v4.....<br>
<br>
The issue of scalar remainder loop has been there in llvm but this issue is enhanced and can't be ignored with large vector width. This is very important and significant to solve this issue.<br>
<br>
Please help. I m trying to see loopvectorizer.cpp but unable to figure out actual code to make changes.<br>
<br>
It's very important for me to solve this issue.<br>
<br>
Please help.<br>
<br>
Thank you<br>
<br>
<br>
</div></div></blockquote></div><br></div>