[LLVMdev] NEON intrinsics preventing redundant load optimization?

Jim Grosbach grosbach at apple.com
Mon Dec 8 18:20:45 PST 2014


> On Dec 8, 2014, at 1:05 AM, Simon Taylor <simontaylor1 at ntlworld.com> wrote:
> 
> On 8 Dec 2014, at 00:13, Renato Golin <renato.golin at linaro.org> wrote:
> 
>> On 7 December 2014 at 19:15, Simon Taylor <simontaylor1 at ntlworld.com> wrote:
>>> Is there something about the use of intrinsics that prevents the compiler optimizing out the redundant store on the stack? Is there any hope for this improving in the future, or anything I can do now to improve the generated code?
>> 
>> If I had to guess, I'd say the intrinsic got in the way of recognising
>> the pattern. vmulq_f32 got correctly lowered to IR as "fmul", but
>> vld1q_f32 is still kept as an intrinsic, so register allocators and
>> schedulers get confused and, when lowering to assembly, you're left
>> with garbage around it.
>> 
>> Creating a bug for this is probably the best thing to do, since this
>> is a common pattern that needs looking into to produce optimal code.
> 
> Thanks for the responses. I’ve filed bug #21778 for this:
> http://llvm.org/bugs/show_bug.cgi?id=21778
> 
> I’ve also tried replacing the vst1.32 with setting the data[i] elements individually with vgetq_lane, which gets at least the single multiply case back to optimal code. There’s still an unneeded temporary when doing res = a * b * c though. Anyway, let’s continue this on the bug tracker :)
> 

FWIW, with top of tree clang, I get the same (good) code for both of the implementations of operator* in the original email. That appears to be a fairly recent improvement, though I haven’t bisected it down or anything.

-Jim

> Simon
> 
> 
> _______________________________________________
> LLVM Developers mailing list
> LLVMdev at cs.uiuc.edu         http://llvm.cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev





More information about the llvm-dev mailing list