aboutsummaryrefslogtreecommitdiffstats
path: root/util/system/cpu_id.cpp
diff options
context:
space:
mode:
authorEvgueni Petrov <evgueni.s.petrov@gmail.com>2022-02-10 16:46:59 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:46:59 +0300
commit19d7d7947f95423df4b50d3a6e858cd689db06ed (patch)
treeb31e808f1761fed50236a1ae5bda03cd3bb9d428 /util/system/cpu_id.cpp
parent122c87ebe5797d52f1800afb02c87f751135d0a4 (diff)
downloadydb-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.cpp56
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 {