Currently auto-vectorization lacks the ability to analyze
memory dependencies caused by function calls, only dependencies
caused by explicit load and store instructions are considered.
In order to still be able to vectorize loops with calls
to basic mathematical functions, any function listed in
include/llvm/Analysis/VecFuncs.def was implicitly assumed
to be safe.
This prevents addition of sincos() and other functions returning
multiple values via pointer operands to VecFuncs.def.
As a first step we only vectorize functions with pointer
arguments if the user forcibly skips dependency checks
via #pragma clang loop vectorize(assume_safety).
Is this correct? This looks like it creates a sincos signature that takes vectors of pointers to doubles, but I expect most sincos vector implementations to actually use pointers to vectors of doubles. Something like:
I hit something almost identical here: https://llvm.org/PR38424