-
Notifications
You must be signed in to change notification settings - Fork 11
Home
Guillaume Piolat edited this page Jun 13, 2021
·
12 revisions
Intrinsics should be sorted in a file in the same order as the Intel Intrinsics Guide:
Intrinsics should always work with all compilers, in x86 32-bit and 64-bit targets. Often, the implementation of intrinsics can be shared between compilers, but often it cannot.
static if(DMD_with_DSIMD) // DMD D_SIMD version, currently disabled. To test it, turn `SSESizedVectorsAreEmulated` to false;
{
// DMD D_SIMD implementation
}
static if(GDC_with_SSE2) // GDC version, guarded by effective use of
{
// GDC x86_64 implementation
}
else static if (LDC_with_SSE2)
{
// LDC implementation
}
else static if (LDC_with_ARM64)
{
// ARM64 + LDC implementation
}
else static if (LDC_with_ARM32)
{
// (optional) If you are interested in ARM32.
}
else
{
// Fallback implementation,
// used by DMD and GDC x86 implementation
// Also used by LDC and GDC with the instruction sets disabled.
}
unittest
{
// Same test for every compiler
}
All new or touched intrinsics should be covered by unittests.
- Use
vec.ptr[ind] = stuff;
for assignment of one vector element, as this keeps compatibility with the older GDC found in Travis CI. - Using intel-intrinsics should not lead to MMX instructions being generated (as it incurs annoying FPU/MMX transitions). Often, a reasonably fast equivalent exist using higher intruction sets.
- When you use a builtin, make sure it exist over a large range of existing LDC versions. When it does, do use it though.