-
Notifications
You must be signed in to change notification settings - Fork 11
Home
Guillaume Piolat edited this page Jun 13, 2021
·
12 revisions
Welcome to intel-intrincs
! This is a fun, but very detailed-oriented library to contribute for.
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
}
else 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 exists over a large range of existing LDC versions. When it does, do use it though.
-
nothrow @nogc
. All new intrinsics should be as @trusted if possible, if they they cannot produce a memory safety error. This is WIP. - Basically, it's best to test every path in https://d.godbolt.org/