[PATCH] D67572: [VectorUtils] Introduce the Vector Function Database (VFDatabase).
    Mikael Holmén via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Fri Dec 13 03:12:36 PST 2019
    
    
  
uabelho added a comment.
In D67572#1781924 <https://reviews.llvm.org/D67572#1781924>, @fpetrogalli wrote:
> Ah, OK. I see what you mean. I think we could solve this by scalarizing after vectorization, instead of doing it in the vectorizer.
>
> We could have a IR pass that runs after the vectorizer that looks for intrinsics calls .When it sees an intrinsics that operates on vector, it checks whether the target is able to lower it to some function or instruction. If not, it scalarizes it. With this we wouldn't have to introduce special behavior in the vectorizer for handling intrinsics: it could just vectorize any call to intrinsics for which vectorization make sense.
That would mean we would have to introduce vector versions of of all intrinsics, that would just be used between the vectorizer and the scalarizer, right? Sounds a little bit cumbersome since those vector versions don't exist today, but perhaps it's the best way anyway, I don't know.
Btw, in case you didn't know, there is already an existing scalarizer pass, though I don't think it's widely used.
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D67572/new/
https://reviews.llvm.org/D67572
    
    
More information about the llvm-commits
mailing list