ldc/tests/semantic/target_traits.d
Johan Engelen 5ffd34f7b6 Add LDC-specific traits for CTFE information about the target machine.
__traits(targetCPU) == "broadwell"
__traits(targetHasFeature, "sse2") == bool
2016-06-06 11:19:07 +02:00

57 lines
1.8 KiB
D

// Tests LDC-specific target __traits
// REQUIRES: target_X86
// RUN: %ldc -mcpu=haswell -d-version=CPU_HASWELL -c %s
// RUN: %ldc -mcpu=pentium -mattr=+fma -d-version=ATTR_FMA -c %s
// RUN: %ldc -mcpu=pentium -mattr=+fma,-sse -d-version=ATTR_FMA_MINUS_SSE -c %s
// Important: LLVM's default CPU selection already enables some features (like sse3)
// Querying feature information is only available from LLVM 3.7.
// Below 3.7, __traits(targetHasFeature,...) should always return false.
version (LDC_LLVM_305)
{
}
else version (LDC_LLVM_306)
{
}
else
{
version = HASFEATURE;
}
void main()
{
version (CPU_HASWELL)
{
static assert(__traits(targetCPU) == "haswell");
version (HASFEATURE)
{
static assert(__traits(targetHasFeature, "sse3"));
static assert(__traits(targetHasFeature, "sse4.1"));
}
static assert(!__traits(targetHasFeature, "sse4"));
static assert(!__traits(targetHasFeature, "sse4a"));
static assert(!__traits(targetHasFeature, "unrecognized feature"));
}
version (ATTR_FMA)
{
version (HASFEATURE)
{
static assert(__traits(targetHasFeature, "sse"));
static assert(__traits(targetHasFeature, "sse2"));
static assert(__traits(targetHasFeature, "sse3"));
static assert(__traits(targetHasFeature, "sse4.1"));
static assert(__traits(targetHasFeature, "fma"));
static assert(__traits(targetHasFeature, "avx"));
}
static assert(!__traits(targetHasFeature, "avx2"));
static assert(!__traits(targetHasFeature, "unrecognized feature"));
}
version (ATTR_FMA_MINUS_SSE)
{
// All implied features must be enabled for targetHasFeature to return true
static assert(!__traits(targetHasFeature, "fma"));
}
}