mirror of
https://github.com/gnif/LookingGlass.git
synced 2024-11-22 13:37:22 +00:00
[common] cpuinfo: handle more than 64 threads on Windows
The old code will not correctly report the number of threads on CPUs with more than one processor group, i.e. when there are more than 64 logical processors (threads).
This commit is contained in:
parent
286da11172
commit
ab033d84b1
@ -24,16 +24,6 @@
|
|||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
static void getProcessorCount(int * procs)
|
|
||||||
{
|
|
||||||
if (!procs)
|
|
||||||
return;
|
|
||||||
|
|
||||||
SYSTEM_INFO si;
|
|
||||||
GetSystemInfo(&si);
|
|
||||||
*procs = si.dwNumberOfProcessors;
|
|
||||||
}
|
|
||||||
|
|
||||||
static bool getCPUModel(char * model, size_t modelSize)
|
static bool getCPUModel(char * model, size_t modelSize)
|
||||||
{
|
{
|
||||||
if (!model)
|
if (!model)
|
||||||
@ -58,9 +48,9 @@ static bool getCPUModel(char * model, size_t modelSize)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool getCoreCount(int * cores)
|
static bool getCoreCount(int * cores, int * procs)
|
||||||
{
|
{
|
||||||
if (!cores)
|
if (!cores && !procs)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
DWORD cb = 0;
|
DWORD cb = 0;
|
||||||
@ -79,14 +69,26 @@ static bool getCoreCount(int * cores)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
*cores = 0;
|
if (cores)
|
||||||
|
*cores = 0;
|
||||||
|
|
||||||
|
if (procs)
|
||||||
|
*procs = 0;
|
||||||
|
|
||||||
DWORD offset = 0;
|
DWORD offset = 0;
|
||||||
while (offset < cb)
|
while (offset < cb)
|
||||||
{
|
{
|
||||||
PSYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX lpi =
|
PSYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX lpi =
|
||||||
(PSYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX) (buffer + offset);
|
(PSYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX) (buffer + offset);
|
||||||
if (lpi->Relationship == RelationProcessorCore)
|
if (lpi->Relationship == RelationProcessorCore)
|
||||||
++*cores;
|
{
|
||||||
|
if (cores)
|
||||||
|
++*cores;
|
||||||
|
|
||||||
|
if (procs)
|
||||||
|
for (int i = 0; i < lpi->Processor.GroupCount; ++i)
|
||||||
|
*procs += __builtin_popcount(lpi->Processor.GroupMask[i].Mask);
|
||||||
|
}
|
||||||
offset += lpi->Size;
|
offset += lpi->Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,6 +97,5 @@ static bool getCoreCount(int * cores)
|
|||||||
|
|
||||||
bool lgCPUInfo(char * model, size_t modelSize, int * procs, int * cores)
|
bool lgCPUInfo(char * model, size_t modelSize, int * procs, int * cores)
|
||||||
{
|
{
|
||||||
getProcessorCount(procs);
|
return getCPUModel(model, modelSize) && getCoreCount(cores, procs);
|
||||||
return getCPUModel(model, modelSize) && getCoreCount(cores);
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user