[LLVMdev] Enabling vectorization with LLVM 3.3 for a DSL emitting LLVM IR

Vesa Norilo vnorilo at siba.fi
Fri Jul 5 05:59:36 PDT 2013


Hi,

For libfaust, perhaps? :)

Could it be something as simple as a target triple defined for the module?  
Without knowledge of the target machine vector width, the vectorizer will  
assume maximum width of 1. You can override this without a triple by using  
the -force-vector-width switch.

Vesa

> Hi,
>
> Our DSL can generate C or directly generate LLVM IR. With LLVM 3.3, we  
> can vectorize the C produced code using clang with -O3, or clang with  
> -O1 then opt -O3 -vectorize-loops. But the same program generating LLVM  
> IR version cannot be vectorized with opt -O3 -vectorize-loops. So our  
> guess is that our generated LLVM IR lacks some informations that are  
> needed by the vectorization passes to correctly work.
>
> Any idea of what could be lacking?
>
> Thanks
>
> St?phane Letz



More information about the llvm-dev mailing list