Fixed cpuid reported supported on unsupported compilers
Former-commit-id: 4f5fc2251882ae04d9131242d0f9d7f8a3a3e6dc
This commit is contained in:
parent
531fa2ce84
commit
55fe71ee21
|
|
@ -14,16 +14,16 @@
|
||||||
|
|
||||||
void NzHardwareInfoImpl::Cpuid(nzUInt32 code, nzUInt32 result[4])
|
void NzHardwareInfoImpl::Cpuid(nzUInt32 code, nzUInt32 result[4])
|
||||||
{
|
{
|
||||||
#if defined(NAZARA_COMPILER_MSVC)
|
#if defined(NAZARA_COMPILER_MSVC)
|
||||||
__cpuid(reinterpret_cast<int*>(result), static_cast<int>(code)); // Visual propose une fonction intrinsèque pour le cpuid
|
__cpuid(reinterpret_cast<int*>(result), static_cast<int>(code)); // Visual propose une fonction intrinsèque pour le cpuid
|
||||||
#elif defined(NAZARA_COMPILER_CLANG) || defined(NAZARA_COMPILER_GCC) || defined(NAZARA_COMPILER_INTEL)
|
#elif defined(NAZARA_COMPILER_CLANG) || defined(NAZARA_COMPILER_GCC) || defined(NAZARA_COMPILER_INTEL)
|
||||||
// Source: http://stackoverflow.com/questions/1666093/cpuid-implementations-in-c
|
// Source: http://stackoverflow.com/questions/1666093/cpuid-implementations-in-c
|
||||||
asm volatile ("cpuid" // Besoin d'être volatile ?
|
asm volatile ("cpuid" // Besoin d'être volatile ?
|
||||||
: "=a" (result[0]), "=b" (result[1]), "=c" (result[2]), "=d" (result[3]) // output
|
: "=a" (result[0]), "=b" (result[1]), "=c" (result[2]), "=d" (result[3]) // output
|
||||||
: "a" (code), "c" (0)); // input
|
: "a" (code), "c" (0)); // input
|
||||||
#else
|
#else
|
||||||
NazaraInternalError("Cpuid has been called although it is not supported");
|
NazaraInternalError("Cpuid has been called although it is not supported");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int NzHardwareInfoImpl::GetProcessorCount()
|
unsigned int NzHardwareInfoImpl::GetProcessorCount()
|
||||||
|
|
@ -37,10 +37,10 @@ unsigned int NzHardwareInfoImpl::GetProcessorCount()
|
||||||
|
|
||||||
bool NzHardwareInfoImpl::IsCpuidSupported()
|
bool NzHardwareInfoImpl::IsCpuidSupported()
|
||||||
{
|
{
|
||||||
|
#if defined(NAZARA_COMPILER_MSVC)
|
||||||
#ifdef NAZARA_PLATFORM_x64
|
#ifdef NAZARA_PLATFORM_x64
|
||||||
return true; // Toujours supporté sur un processeur 64 bits
|
return true; // Toujours supporté sur un processeur 64 bits
|
||||||
#else
|
#else
|
||||||
#if defined(NAZARA_COMPILER_MSVC)
|
|
||||||
int supported;
|
int supported;
|
||||||
__asm
|
__asm
|
||||||
{
|
{
|
||||||
|
|
@ -59,7 +59,11 @@ bool NzHardwareInfoImpl::IsCpuidSupported()
|
||||||
};
|
};
|
||||||
|
|
||||||
return supported != 0;
|
return supported != 0;
|
||||||
#elif defined(NAZARA_COMPILER_CLANG) || defined(NAZARA_COMPILER_GCC) || defined(NAZARA_COMPILER_INTEL)
|
#endif // NAZARA_PLATFORM_x64
|
||||||
|
#elif defined(NAZARA_COMPILER_CLANG) || defined(NAZARA_COMPILER_GCC) || defined(NAZARA_COMPILER_INTEL)
|
||||||
|
#ifdef NAZARA_PLATFORM_x64
|
||||||
|
return true; // Toujours supporté sur un processeur 64 bits
|
||||||
|
#else
|
||||||
int supported;
|
int supported;
|
||||||
asm volatile (" pushfl\n"
|
asm volatile (" pushfl\n"
|
||||||
" pop %%eax\n"
|
" pop %%eax\n"
|
||||||
|
|
@ -78,8 +82,8 @@ bool NzHardwareInfoImpl::IsCpuidSupported()
|
||||||
: "eax", "ecx", "memory"); // clobbered register
|
: "eax", "ecx", "memory"); // clobbered register
|
||||||
|
|
||||||
return supported != 0;
|
return supported != 0;
|
||||||
#else
|
#endif // NAZARA_PLATFORM_x64
|
||||||
|
#else
|
||||||
return false;
|
return false;
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue