[LLVMdev] Disable vectorization for unaligned data

Arnold Schwaighofer aschwaighofer at apple.com
Sat Jul 20 09:52:13 PDT 2013


On Jul 19, 2013, at 3:14 PM, Francois Pichet <pichet2000 at gmail.com> wrote:

> 
> What is the proper solution to disable auto-vectorization for unaligned data?
> 
> I have an out of tree target and I added this:
> 
> bool OpusTargetLowering::allowsUnalignedMemoryAccesses(EVT VT, bool *Fast) const {
>   if (VT.isVector())
>     return false;
> ....
> }
> 
> After that, I could see that vectorization is still done on unaligned data except that llvm will copy the data back and forth from the source to the top of the stack and work from there. This is very costly, I rather get scalar operations.
> 
> Then I tried to add:
>   unsigned getMemoryOpCost(unsigned Opcode, Type *Src,
>                            unsigned Alignment,
>                            unsigned AddressSpace) const {
>     if (Src->isVectorTy() && Alignment != 16)
>       return 10000; // <== high number to try to avoid unaligned load/store.
>     return TargetTransformInfo::getMemoryOpCost(Opcode, Src, Alignment, AddressSpace);
>   }
> 
> Except that this doesn't work because Alignment will always be 4 even for data like:
>        int   data[16][16] __attribute__ ((aligned (16))),
> 
> Because individual element are still 4-byte aligned.

We will have to hook up some logic in the loop vectorizer that computes the alignment of the vectorized version of the memory access so that we can pass it to “getMemoryOpCost". Currently, as you have observed, we will just pass the scalar loop’s memory access alignment which will be pessimistic.

Instcombine will later replace the alignment to a stronger variant for vectorized code but that is obviously to late for the cost model in the vectorizer.



More information about the llvm-dev mailing list