CPUID на процессорах Intel i7

У меня проблема с моим кодом на базе CPUID на новых машинах на базе i7. Он обнаруживает, что процессор имеет одно ядро ​​с 8 модулями HT вместо 4 ядер с двумя модулями HT.

Должно быть, я неверно истолковываю результаты информации CPUID, возвращаемой из CPU, но я не понимаю, как это сделать.

По сути, я перебираю каждый процессор, видимый для Windows, устанавливаю привязку потока к этому потоку, а затем выполняю последовательность вызовов CPUID.

args = new CPUID_Args();
args.eax = 1;
executeHandler(ref args);
if (0 != (args.edx & (0x1 << 28)))
{
  //If the 28th bit in EDX is flagged, this processor supports multiple logical processors per physical package
  // in this case bits 23:16 of EBX should give the count.
//** EBX here is 0x2100800
  logicalProcessorCount = (args.ebx & 0x00FF0000) >> 16;
//** this tells me there are 16 logical processors (wrong)
}
else
{ logicalProcessorCount = 1; }
apic = unchecked((byte)((0xFF000000 & args.ebx) >> 24));

if (maximumSupportedCPUID >= 4)
{
  args = new CPUID_Args();
  args.eax = 4;
  executeHandler(ref args);
//EAX now contains 0x1C004121
  coreCount = 1 + ((args.eax & 0xFC000000) >> 26);
//This calculates coreCount as 8
}
else
{ coreCount = 1; }

Эта последовательность повторяется для остальных процессоров в системе.

Кто-нибудь сталкивался с этим раньше?

1 ответ

Интересный вопрос - к сожалению, у меня нет i7, чтобы играть, поэтому я могу только догадываться здесь.

Может быть полезно взглянуть на эту статью - хотя в принципе ваш подход кажется правильным, в них изложено несколько предостережений. Может быть, прочитайте и посмотрите, может ли на каком-то этапе ваши предположения могут быть неверными. Они по существу используют CPUID.1.EBX[23:16] (max # log процессоров в физическом пакете), CPUID.4.EAX[31:26]+1 (max # ядер в физическом пакете) и CPUID.4.EAX[25:14]+1 (максимальное количество процессоров журналов в физическом пакете, совместно использующих кэш целевого уровня), чтобы вывести топологию процессора - что соответствует тому, что вы делаете.

Во-вторых, в качестве альтернативы, на процессоре, который поддерживает функцию CPUID EAX = 0Bh (см . Документацию Intel здесь), вы можете использовать эту функцию вместо того, чтобы получить требуемые спецификации. Может быть, сравнение результатов двух подходов может быть осветительным?

- Редактировать-- Это очень полезная статья, которая охватывает оба подхода выше. По сути, я понимаю, что на i7 CPUID.0B является предпочтительным вариантом.

Другие вопросы по тегам