diff options
author | Evgueni Petrov <evgueni.s.petrov@gmail.com> | 2022-02-10 16:46:59 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:59 +0300 |
commit | 19d7d7947f95423df4b50d3a6e858cd689db06ed (patch) | |
tree | b31e808f1761fed50236a1ae5bda03cd3bb9d428 /util/system/cpu_id.cpp | |
parent | 122c87ebe5797d52f1800afb02c87f751135d0a4 (diff) | |
download | ydb-19d7d7947f95423df4b50d3a6e858cd689db06ed.tar.gz |
Restoring authorship annotation for Evgueni Petrov <evgueni.s.petrov@gmail.com>. Commit 1 of 2.
Diffstat (limited to 'util/system/cpu_id.cpp')
-rw-r--r-- | util/system/cpu_id.cpp | 56 |
1 files changed, 28 insertions, 28 deletions
diff --git a/util/system/cpu_id.cpp b/util/system/cpu_id.cpp index 598c71f4d9..70157f3bac 100644 --- a/util/system/cpu_id.cpp +++ b/util/system/cpu_id.cpp @@ -139,23 +139,23 @@ bool NX86::HaveOSXSAVE() noexcept { } bool NX86::HaveAVX() noexcept { -#if defined(_x86_) - // http://www.intel.com/content/dam/www/public/us/en/documents/manuals/64-ia-32-architectures-optimization-manual.pdf +#if defined(_x86_) + // http://www.intel.com/content/dam/www/public/us/en/documents/manuals/64-ia-32-architectures-optimization-manual.pdf // https://bugs.chromium.org/p/chromium/issues/detail?id=375968 return HaveOSXSAVE() // implies HaveXSAVE() && (_xgetbv(0) & 6u) == 6u // XMM state and YMM state are enabled by OS && ((TX86CpuInfo(0x1).ECX >> 28) & 1u); // AVX bit #else - return false; + return false; #endif } bool NX86::HaveFMA() noexcept { - return HaveAVX() && ((TX86CpuInfo(0x1).ECX >> 12) & 1u); -} - + return HaveAVX() && ((TX86CpuInfo(0x1).ECX >> 12) & 1u); +} + bool NX86::HaveAVX2() noexcept { - return HaveAVX() && ((TX86CpuInfo(0x7, 0).EBX >> 5) & 1u); + return HaveAVX() && ((TX86CpuInfo(0x7, 0).EBX >> 5) & 1u); } bool NX86::HaveBMI1() noexcept { @@ -167,80 +167,80 @@ bool NX86::HaveBMI2() noexcept { } bool NX86::HaveAVX512F() noexcept { -#if defined(_x86_) - // https://software.intel.com/en-us/articles/how-to-detect-knl-instruction-support +#if defined(_x86_) + // https://software.intel.com/en-us/articles/how-to-detect-knl-instruction-support return HaveOSXSAVE() // implies HaveXSAVE() && (_xgetbv(0) & 6u) == 6u // XMM state and YMM state are enabled by OS && ((_xgetbv(0) >> 5) & 7u) == 7u // ZMM state is enabled by OS && TX86CpuInfo(0x0).EAX >= 0x7 // leaf 7 is present && ((TX86CpuInfo(0x7).EBX >> 16) & 1u); // AVX512F bit -#else - return false; -#endif +#else + return false; +#endif } bool NX86::HaveAVX512DQ() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 17) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 17) & 1u); } bool NX86::HaveRDSEED() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 18) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 18) & 1u); } bool NX86::HaveADX() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 19) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 19) & 1u); } bool NX86::HaveAVX512IFMA() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 21) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 21) & 1u); } bool NX86::HavePCOMMIT() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 22) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 22) & 1u); } bool NX86::HaveCLFLUSHOPT() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 23) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 23) & 1u); } bool NX86::HaveCLWB() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 24) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 24) & 1u); } bool NX86::HaveAVX512PF() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 26) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 26) & 1u); } bool NX86::HaveAVX512ER() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 27) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 27) & 1u); } bool NX86::HaveAVX512CD() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 28) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 28) & 1u); } bool NX86::HaveSHA() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 29) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).EBX >> 29) & 1u); } bool NX86::HaveAVX512BW() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 30) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 30) & 1u); } bool NX86::HaveAVX512VL() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 31) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).EBX >> 31) & 1u); } bool NX86::HavePREFETCHWT1() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).ECX >> 0) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x7, 0).ECX >> 0) & 1u); } bool NX86::HaveAVX512VBMI() noexcept { - return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).ECX >> 1) & 1u); + return HaveAVX512F() && ((TX86CpuInfo(0x7, 0).ECX >> 1) & 1u); } bool NX86::HaveRDRAND() noexcept { - return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x1).ECX >> 30) & 1u); + return TX86CpuInfo(0x0).EAX >= 0x7 && ((TX86CpuInfo(0x1).ECX >> 30) & 1u); } const char* CpuBrand(ui32* store) noexcept { |