Cpuid 906e9h что за процессор

Обновлено: 07.07.2024

CPUID - это инструкция процессора Intel x86 и x86_64, которая возвращает тип процессора и наличие определенных функций.

Я строю топологическое дерево сокетов, узлов NUMA, кешей, ядер и потоков для любой системы Intel или AMD на C. Создавая эту иерархию, я хочу, чтобы аппаратные потоки были правильно сгруппированы вместе, чтобы было ясно, кто и что именно разделяет. Я обнаружил, что могу установить привязку потока, а.

Я выполняю cpuid(leaf 0), который дает мне строку поставщика. Код (под block1) работает нормально и отображает GenuineIntel, как я и ожидал. В asm block2 ниже я хочу напрямую сопоставить значения ebx, edx, ecx с массивом vendor вместо использования явных инструкций mov. В настоящее время я пытаюсь.

Я написал следующую встроенную сборку, чтобы попробовать проверить флаг ID. Я знаю, что это должно быть установлено, потому что я могу использовать инструкцию cpuid, однако эта функция возвращает 0, когда я ее проверяю. _Bool / * .

Если я запускаю lscpu или смотрю /proc/cpuinfo, они оба говорят, что мой процессор поддерживает AVX2. $ lscpu | grep -o avx2 avx2 Однако когда я использовал vpsllvw в своем коде, он давал SIGILL. bits 64 global main section .text main: movdqa xmm0, [initial] vpsllvw xmm0, [shift] .

Информация кеша llc, отображаемая с помощью cpuid command в Linux: --- cache 3 --- cache type = unified cache (3) cache level = 0x3 (3) self-initializing cache level = true fully associative cache = fals.

Я получаю размер бит физического и виртуального адреса с помощью C, используя команду CPUID в Windows. Таким образом я могу получить информацию о процессоре, но меня сбивают с толку биты адреса. Похоже, я должен вам использовать инструкцию 80000008, но я делаю так, постоянно отображаются только 7-.

Описание инструкции lahf: Эта инструкция выполняется, как описано выше, в режиме совместимости и в устаревшем режиме. Он действителен в 64-битном режиме, только если CPUID.80000001H: ECX.LAHF-SAHF [bit 0] = 1. Первый вопрос: что такое совместимость и устаревший режим. Чем они отличаются от реально.

Должен ли я искать в справочнике по набору инструкций Intel и AMD x86 значение битов CPUID? Это вызывает у меня подозрение (из Википедии): ABM реализована AMD только как единый набор инструкций; все процессоры AMD поддерживают обе инструкции или ни одну из них. Intel считает POPCNT частью SSE4.2, .

Предположим, я хочу использовать инструкцию, которая может быть недоступна. И эта инструкция не из тех прозрачных резервных вариантов, это неопределенная инструкция, когда она недоступна. Скажем, это popcnt, например. Могу я вместо того, чтобы использовать cpuid, просто попробовать позвонить ему? .

В первой части я рассказал о необходимости идентификации расширений, присутствующих на конкретном процессоре. Это нужно для того, чтобы исполняющийся код (операционная система, компилятор или пользовательское приложение) смог надёжно определить, какие возможности аппаратуры он может задействовать. Также в предыдущей статье я сравнил несколько популярных архитектур центральных процессоров общего назначения. Возможности по идентификации между ними сильно разнятся: некоторые предоставляют полную информацию о расширениях ISA, тогда как другие ограничиваются парой чисел для различения вендора и ревизии.
В этой части я расскажу об одной инструкции архитектуры Intel IA-32 — CPUID, введённой специально для перечисления декларируемых процессором расширений. Немного о том, что было до её появления, что она умеет сообщать, какие неожиданности могут поджидать и какой софт позволяет интерпретировать её вывод.



Источник изображения: [1]

История

Как я уже утверждал в первой части, присутствует следующая тенденция: чем более «встраиваемая» природа у процессора, тем меньше возможностей для идентификации заложено в его архитектуру. Создатели встраиваемых систем почему-то не волнуются о переносимости двоичного кода.

Не являлся исключением и Intel 8086 — микропроцессор 1970-х годов, выросший из «калькуляторной» серии 8008, 8080, 8085. Изначально в него не было заложено никаких средств идентификации.
Начиная с 808386 сведения о модели, степпинге и семействе стали сообщаться в регистре EDX сразу после перезагрузки (получения сигнала RESET). Инструкция CPUID, кодируемая байтами 0x0f 0xa2, была введена в процессорах 80486. Наличие CPUID можно было распознать по возможности записи в бит 21 регистра флагов. Для поддержки работы на более старых ЦПУ приходилось идти на очень изощрённые методы для того, чтобы различать процессоры серий от 8086 до 80386.

Перечисленные в оригинальной статье техники были опробованы преимущественно на ЦПУ от Intel. В статье автор признаёт, что они не позволяют надёжно классифицировать клоны x86 других производителей.

Интерфейс

Для системного программиста работа по идентификации некоторого расширения обычно заключается в установке входных значений в регистрах EAX (лист, англ. leaf) и ECX (подлист, англ. subleaf), исполнению CPUID и прочтению результата в четырёх регистрах: EAX, EBX, ECX, EDX. Отдельные битовые поля выходных регистров будут содержать информацию о значениях связанных с ними архитектурных параметров конкретного ядра процессора.

Все валидные сочетания входных листов-подлистов и четвёрок регистров на выходе формируют таблицу CPUID. Для современных процессоров она содержит около двух десятков строк по четыре 32-битных столбца.
Я не буду расписывать детально все официально описанные поля этой таблицы. Интересующиеся всегда могут найти их в Intel SDM [1] (рекомендую запастись терпением — около 40 страниц текста только про CPUID). Болеее того, для уже заявленных, но ещё не выпущенных в физических продуктах расширений ISA соответствующие им новые поля CPUID могут быть найдены в [3]. Вместо этого я классифицирую информацию, которую можно извлечь из вывода этой инструкции. Для обозначения битовых полей таблицы я буду использовать принятую для этого нотацию: CPUID.leaf.subleaf.reg[bitstart:bitend]. Например, CPUID.0.EBX[31:0] — это биты с 0 по 31 выходного регистра EBX после исполнения CPUID, которая на вход получила лист 0 (EAX = 0); подлист (входное значение ECX) игнорируется, поэтому он не указан.

Регионы листов

Неподдерживаемые значения входных EAX и ECX не приводят к возникновению исключений, а вместо этого возвращают нули во всех четырёх регистрах, либо «мусор» (значения другого листа согласно спецификации). Допустимые же сочетания листов и подлистов образуют три непрерывных региона.


  • Обычный регион — все листы с номерами, начиная с нулевого и до максимального значения, равного CPUID.0.EAX[31:0]. Номер максимального листа постоянно растёт и уже давно перевалил за десятку.
  • Расширенный регион — все листы, начиная с 0x80000000 и до максимального значения, равного CPUID.0x80000000.EAX[31:0]. Довольно долгое время это максимальное значение остаётся равным 0x80000008. Я не нашёл документальных доказательств, но у меня есть чувство, что само появление диапазона расширенных листов связанно с введением компанией AMD 64-битного расширения архитектуры IA-32.
  • Диапазон листов 0x40000000-0x4fffffff считается зарезервированным; обещается, что возвращаемые для него CPUID значения всегда будут равны нулю. Однако это не мешает некоторым использовать его для своих нужд. Например, виртуальные машины KVM возвращают в листе 0x40000000 четвёрку чисел [0, 0x4b4d564b, 0x564b4d56, 0x4d].

  • CPUID.1.ECX[0] — SSE3 — векторные инструкции.
  • CPUID.1.ECX[9] — SSSE3 — другие векторные инструкции.
  • CPUID.1.ECX[7] — EIST — Enhanced Intel SpeedStep®, динамическое изменение частоты процессора.
  • CPUID.1.EDX[25] — SSE — ещё векторные инструкции.
  • CPUID.1.EDX[26] — SSE2 — снова векторные инструкции.
  • CPUID.6.EAX[1] — Intel Turbo Boost, оверклокинг «из коробки».
  • CPUID.7.0.EBX[4] — Hardware Lock Elision, CPUID.7.0.EBX[11] — Restricted Transactional Memory — два расширения от Intel для поддержки транзакционной памяти.
  • CPUID.0x80000001.ECX[5] — LZCNT, инструкция для подсчёта числа старших нулевых бит, похожая (даже слишком) на BSR.
Brand String

Конечно же, ни один вендор не упустит возможности увековечить своё имя в идентификационных данных своего продукта. Причём желательно сделать это не просто в виде числа, а впечатать ASCII-строку (хорошо хоть, что не Unicode).
В IA-32 CPUID текст можно найти минимум в двух группах листов. CPUID.0.EBX, ECX, EDX содержат 12 байт ASCII-строки, специфичной для каждого вендора. Для Intel это, конечно же, «GenuineIntel». А три листа CPUID.0x80000002–0x80000004 предоставляют аж 48 байт для кодирования в ASCII так называемой Brand String. Именно её видно при распечатке cat /proc/cpuinfo в Linux. И, хотя формат её более-менее стандартизован: «вендор марка серия CPU @ частота», я настоятельно не рекомендую по её содержимому принимать решения в программном коде. Слишком значительно её содержимое может варьироваться: частота может быть указана в МГц или в ГГц (а в реальности быть совсем иной из-за динамической подстройки), пробелы могут менять положение, а симулятор или виртуальная машина могут подставить туда вообще что угодно. Вся информация из brand string может быть найдена программно более надёжными способами.

Информация о кэшах, такая как их тип, количество, ёмкость, геометрия, разделяемость между ядрами полезна для тюнинга высокопроизводительного математического софта, например, библиотек BLAS (basic linear algebra system).
Изначально конфигурацию кэшей описывал лист 2. Спроектировали его не очень дальновидно. Формат кодирования информации в нём был выбран не самый гибкий, он не смог в будущем поддержать постоянные изменения в объёме и конфигурации нескольких уровней кэшей. В настоящее время использование информации из листа 2 не рекомендуется, там могут стоять 0xFF-ки.
Судя по тому, что лист 0x80000006 входит в расширенный диапазон (хотя я не уверен, документальных доказательств пока что не нашёл), он был добавлен не Intel. С помощью него была сделана попытка информацию листа 2 дополнить данными о строении кэшей, которые потребовались разработчикам софта. При этом опять же не было намерения предоставить пространство для роста.
Лист 4 — последнее и пока что наиболее гибкое представление данных о кэшах. Цена этому — добавление концепции подлистов, кодируемых в ECX. Каждый подлист описывает один кэш: данных, кода или совмещённый, определяет его уровень, ёмкость и т.д. Хватит ли четвёртого листа надолго — поживём, увидим.

Топология
  • SMT — уровень гипер-потока, сущности, содержащей индивидуальное архитектурное состояние (регистры), но потенциально разделяющей исполнительные устройства с другими потоками (в составе одного ядра).
  • Ядро (core) — сущность, содержащая индивидуальный набор вычислительных устройств (сумматоров, умножителей и т.д.). Одно ядро может иметь в себе один, два (у ЦПУ с HyperThreading) или четыре (у Xeon Phi) гипер-потока.
  • Пакет (пэкадж, package) — собственно железка целиком, покупаемая в магазине и вставляемая в разъём (сокет) на матплате. Имеет на себе как минимум одно ядро. В многопроцессорных серверных системах может быть несколько пэкаджей.
Изменяемые поля
  • Бит 18 регистра CR4 влияет на CPUID.1:ECX.OSXSAVE[27], обозначающий поддержку инструкции XSAVE.
  • Поля регистра IA32_MISC_ENABLE влияют сразу на несколько полей CPUID: бит 3 — на поля TM1 и TM2, бит 16 — на поле EIST, бит 34 — на поле XD (execution disable) и т.д.
  • Включение бита 22 регистра IA32_MISC_ENABLE вообще «отрезает» все листы таблиц CPUID старше третьего (видимо, это было сделано для совместимости с Windows NT4, не зря этот бит так и называется — NT4).
Разное

В этой секции я собрал прочие интересные моменты, связанные с историей и работой команды CPUID.

Processor Serial Number

Во времена Pentium III каждый процессор получил уникальный серийный номер, содержавшийся в CPUID.3.ECX и CPUID.3.EDX [7]. Легко представить, насколько такая фича была бы удобна для нужд защиты ПО от копирования. Однако в 1999 году Европейское сообщество запротестовало, разумно опасаясь, что подобная функциональность повредит приватности пользователей таких систем. Уже в Intel Pentium IV серийный номер был убран, сейчас лист 3 возвращает нули.

Вендоры и CPUID

Очень интересная таблица [5] повествует о том, что хранят (или в прошлом хранили) в разных листах CPUID разные вендоры. Например, описывается некий mystery level 0x8fffffff, в котором процессоры AMD K8 возвращали строку IT'S HAMMER TIME.

Agner Fog о войнах ISA

История появления расширений набора инструкций IA-32 в условиях конкурентной борьбы нескольких компаний [4]. Добавление новых инструкций всегда влияло на CPUID, и не всегда все могли договориться о том, как это сделать правильно.

Они испортили CPUID! IA32_BIOS_SIGN_ID

Инструкция CPUID всегда нравилась мне лаконичностью своего интерфейса и отсутствием неожиданностей в работе: один регистр на входе и четыре на выходе. В её работе нет генерации исключений, нет обращений к памяти, нет чтения/модификации регистра флагов, на неё не влияют префиксы, она работает во всех режимах процессора. По сравнению с зоопарком CISC-команд IA-32 это был почти идеал.
… пока не оказалось, что иногда на вход необходимо подать два регистра для кодирования листа и подлиста. Окей, не так всё хорошо. Ну хотя бы выходные регистры заранее известны и всегда изменяются…
И тут оказалось, что иногда CPUID изменяет ещё один регистр — а именно IA32_BIOS_SIGN_ID, — и сохраняет в нём сигнатуру текущей программы микрокода процессора. Происходит это, если до этого было произведено обновление прошивки процессора. По каким-то причинам информация об этой процедуре была раскидана по мануалу [1] на тысячу страниц, и потому она ускользала от меня очень долго.

Большинство индексов или цифр имеют вполне конкретное значение. Обратите на них внимание, когда будете выбирать процессор!


Разбираемся в обозначениях процессоров: что они могут сообщить о характеристиках

Если вы хотите подобрать оптимальный процессор в свою сборку, то не спешите копаться в технических характеристиках. Много полезной информации скрывается в наименовании ЦПУ. Если знать, что означают все эти буквы и цифры, то можно сэкономить много время. Разобраться в этой теме не сложно, достаточно понимать ключевые моменты. О них и поговорим.

Маркировка процессоров Intel

За всю историю компания Intel выпустила огромное количество разных моделей процессоров, и, разумеется, многие из них сегодня уже устарели. На данный момент актуальными остаются только четыре линейки. Каждая из них имеет свою направленность.

  • Intel Celeron — самые бюджетные процессоры, предоставляющие базовый уровень производительности для нетребовательных задач.
  • Intel Pentium Silver — мобильные процессоры, основанные на «малых», наиболее энергоэффективных, ядрах.
  • Intel Pentium Gold — процессоры с невысокой производительностью, подходят, в основном, для офисных решений.
  • Intel Core — самая разноплановая линейка, которая включает в себя, как офисные, так и премиальные геймерские решения.
  • Intel Xeon — модели, ориентированные на серверное применение.


Поскольку Intel Core охватывает большую часть рынка, разберем на её примере как линейка делится на классы.

  • Core i3 — начальный уровень, подходящий для несложных задач;.
  • Core i5 — включает в себя универсальные модели из среднего сегмента;
  • Core i7 — мощные процессоры, в том числе для гейминга;
  • Core i9 — премиальная продукция, которая, помимо гейминга, ориентирована на ресурсоемкие рабочие приложения;
  • Core X — исключительно узкоспециализированные профессиональные задачи.

Хотите хороший игровой компьютер до 40 000 рублей? Названы лучшие сочетания процессоров и видеокарт

После классификации процессор в названии имеет числовое обозначение. Первая цифра всегда означает поколение. На данный момент самым актуальным является 10-е. У каждого поколения имеется кодовое название. Например:

Как вы заметили, после поколения следуют ещё три цифры. Как правило, они отображают уровень производительности модели относительно других процессоров в одном поколении. Например:

  • Intel Core i5-7400 — самый слабый среди всех i5 седьмого поколения.
  • Intel Core i5-7500 — средний по производительности.
  • Intel Core i5-7600K — самый мощный.


В наименовании модели после цифр может быть расположена буква, которая указывает на отличительную характеристику процессора. Они могут комбинироваться различными способами.

  • K — процессоры, у которых разблокирован множитель. Если его увеличить, это приведет к увеличению производительности. По умолчанию большинство ЦПУ от компании Intel разгонять нельзя.
  • F — модели, у которых отсутствует встроенное видеоядро. Это значит, что даже при наличии видеовыходов на материнской плате, вы не получите изображение.
  • X — высокопроизводительные решения. Как правило, данная маркировка встречается только в премиальных продуктах.
  • E — встраиваемые процессоры.
  • T — десктопные процессоры со сниженным энергопотреблением.
  • M — мобильные процессоры.
  • Q — четырехъядерные ЦПУ.
  • H — высокопроизводительные мобильные процессоры.
  • U — решения, у которых ещё больше снижено энергопотребление.
  • Y — мобильные процессоры со сниженным энергопотреблением.
  • L — гибридные процессоры, нацеленные на максимальную энергоэффективность.

Новые мобильные процессоры Intel Core 11-го поколения, а также некоторые 10-го поколения, имеют непривычную маркировку. К примеру, Intel Core i7-1165G7, где цифра после G обозначает класс мобильной графики: G7 — ее максимальная производительность, G4 — средний уровень производительности, а G1 — базовый.

Стоит упомянуть, что многие модели встречаются в двух вариантах исполнения: BOX и OEM. Первый имеет увеличенную гарантию, а также подразумевает наличие кулера в комплекте. Второй продается дешевле, но в комплект поставки ничего не входит. Кстати, процессоры с разблокированным множителем поставляются без кулера и его нужно будет покупать отдельно.

Маркировка процессоров AMD

Говоря про обозначения ЦПУ, следует понимать, что для каждой линейки применяются уникальные правила маркировки, которые не являются универсальными. Поэтому всё, что написано ниже применимо только для ныне актуальных процессоров.

CPUID (CPU Identification) - это дополнительная инструкция процессоров архитектуры x86, которая используется для получения информации о процессоре. С ее помощью можно определить тип процессора и его характеристики. Она впервые была представлена корпорацией Intel в 1993 году примерно в то же время, когда этой же корпорацией представила торговую марку процессоров x86 Pentium и улучшенные процессоры i486. Код инструкции CPUID - 0F A2 (если задавать двумя байтами, если словом - A20Fh). Во время исполнения инструкции задействован регистр EAX, и в некоторых случаях - ECX.

Содержание

История

Поскольку архитектура Intel развивается с добавлением новых поколений и моделей процессоров (8086, 8088, Intel286, Intel386, Intel486, процессоры Pentium, процессоры Pentium OverDrive, процессоры Pentium с технологией MMX, процессоры Pentium OverDrive с технологией MMX, процессоры Pentium Pro, а также: Pentium II, Pentium II Xeon, Pentium II Overdrive, Intel Celeron, Mobile Intel Celeron, Pentium III, Mobile Intel Pentium III - M, Pentium III Xeon, Pentium 4 , Mobile Intel Pentium 4 – M, Intel Xeon and Intel Xeon MP), важно, чтобы Intel предоставлял средства, с помощью которых программное обеспечение может идентифицировать характеристики каждого процессора. Этот идентификационный механизм развился в сочетании с архитектурой Intel следующим образом:

  1. Первоначально Intel опубликовал кодовые последовательности, которые могли обнаружить незначительную реализацию или архитектурные различия для идентификации поколения, к которому относится процессор
  2. Позже, с появлением процессора Intel386 корпорация включила в состав процедуру идентификации подписи процессора, в результате которой можно было узнать семейство, модель и версию процессора, используя программные решения. Однако это можно было сделать только после перезагрузки.
  3. Поскольку архитектура Intel развилась, корпорация расширила процедуру идентификации подписи процессора, и она стала называться CPUID инструкция. С ее помощью можно выяснить не только подпись процессора, но и информацию о характеристиках, поддерживаемых и внедряемых на процессоре Intel.

Эволюция процедуры идентификации процессора была необходима, потому что, поскольку архитектура Intel распространяется, рынок IT-технологий должен был быть готов к настройке функциональности процессора на фоне множества поколений и моделей, имеющих разный набор характеристик. Ожидая, что такая тенденция распространиться и на будущие поколения процессоров, нововведение в архитектуру Intel CPUID инструкция расширяема. Учитывая сильные стороны инструкции CPUID, разработчики могут создавать приложения и инструменты, которые могут использоваться совместно несмотря на богатое разнообразие поколений процессоров Intel в прошлом, настоящем и будущем. [1]

Проверка возможности исполнения CPUID инструкции

Семейство процессоры Intel486 и последующие процессоры предоставляют прямой метод для того, чтобы определить, поддерживает ли внутренняя архитектура процессора CPUID инструкцию. Этот метод использует специальный флаг ID, находящийся в 21 бите регистра EFLAGS. Если программа сможет изменить значение этот флага, то процессор поддерживает CPUID инструкцию, иначе - не поддерживает. Этот бит проиллюстрирован ниже.


Результат работы CPUID инструкции


Инструкция CPUID поддерживает два набора функций. Первый набор функций возвращает базовую информацию о процессоре. С помощью второго набора можно получить дополнительную информацию о процессоре. На рисунке 2 проиллюстрировано то, какая базовая информация о процессоре может быть получена и где она хранится. Выходные данные инструкции CPUID полностью зависимы от содержания регистра EAX. Это означает, что, помещая различные значения в регистр EAX, а затем выполняя инструкцию CPUID, инструкция CPUID выполняет определенную функцию в зависимости от того, какое значение было помещено в регистр EAX (см. таблицу 1). Чтобы определить максимально допустимое входное значение регистра EAX и функций CPUID, которые возвращают базовую информацию о процессоре, программе следует установить значение параметра регистра EAX в нулевое, а затем выполнить инструкцию CPUID следующим образом:

После выполнения инструкции CPUID возвращаемое значение будет присутствовать в регистре EAX. Всегда используйте значение EAX, которое больше или равно нулю и меньше либо равно максимально допустимого значения EAX.

Чтобы определить максимально допустимое входное значение регистра EAX и функций CPUID, которые возвращают дополнительную информацию, программе следует установить значение параметра регистра EAX, равное 80000000h а затем исполнить инструкцию CPUID следующим образом:

После выполнения инструкции CPUID возвращаемое значение будет в регистре EAX. Всегда используйте значение параметра регистра EAX, которое больше либо равно 80000000h и меньше либо равно максимальному допустимому значению EAX. На сегодняшних и будущих IA-32 процессорах 31 бит в регистре EAX будет очищен, когда выполнится CPUID с входным параметром, большим, чем максимальное значение для любого набора функций, и когда расширенные функции не поддерживаются. Все остальные значения битов, возвращаемые процессором в ответ на инструкцию CPUID со значением в EAX больше подходящего для этого процессора, являются уникальными для данной модели и не рекомендуется их изменять.

Идентификатор производителя

В дополнение к возврату максимально допустимого значения в регистре EAX одновременно может быть также проверен идентификатор производителя Intel. Если регистр EAX содержит на входе ноль, то инструкция CPUID также возвращает идентификатор производителя в EBX, EDX и ECX регистрах (см. рисунок 2). Эти регистры содержат строку ASCII: GenuineIntel.

В то время как любой имитатор архитектуры Intel может поддержать инструкцию CPUID, ни одни из них не может претендовать на то, что он является подлинной частью Intel. Таким образом, присутствие строки GenuineIntel является гарантией того, что инструкция CPUID и идентификатор реализованы в соответствии с документом, содержащим описание процессоров Intel и инструкции CPUID. Если такая строка не появилась после исполнения инструкции, не полагайтесь на информацию в этом документе для интерпретации информации, возвращенной инструкцией CPUID.

Таблица 1. Информация, возвращаемая инструкцией CPUID
Начальное значение EAX Предоставляемая информация о процессоре
Базовая информация
0H EAX Максимальное входное значение
EBX "Genu"
ECX "ntel"
EDX "ineI"
1H EAX 32-битный идентификатор производителя (Расширенные семейство и модель, тип, семейство, модель, версия также 95-64 биты из 96-битного серийного номера, когда установлен флаг PSN)
EBX Биты 7-0: Индекс
Биты 15-8: Размер строки CLFLUSH (размер строки кэша = возвращаемое значение * 8). Допустимо только при установке флага CLFSH
Биты 23-16: Граф логических процессоров. Допустимо только при установке флага HTT
Биты 31-24: Уникальное значение контроллера APIC (работает с прерываниями). Только для Pentium 4 и последующих.
ECX Зарезервирован под дополнительные флаги
EDX Флаги характеристик
2H EAX. EBX, ECX, EDX Кэш и TLB дескрипторы
3H EAX Зарезервировано
EBX Зарезервировано
ECX Биты 31-0 96-битного серийного номера
EDX Биты 31-0 96-битного серийного номера
Расширенная информация
80000000h EAX максимальное входное значение
EBX, ECX, EDX Зарезервированы
80000001h EAX Расширенный идентификатор производителя, а также характеристики
EBX, ECX, EDX Зарезервированы
80000002h EAX Строка бренда
EBX, ECX, EDX Продолжение строки бренда
80000003h EAX, EBX, ECX, EDX Продолжение строки бренда
80000004h EAX, EBX, ECX, EDX Продолжение строки бренда

Процессорная идентификационная подпись

Начиная с семейства процессоров Intel486, регистр EDX содержит идентификационную подпись процессора, появляющуюся там после сброса (см. рисунок 3). Идентификационная подпись процессора - это 32-разрядное значение. Подпись процессора состоит из 8 различных битовых полей. Поля серого цвета представляют собой зарезервированные биты и должны кэшироваться. Остальные 6 полей формируют идентификационную подпись процессора.


Процессоры, которые поддерживают инструкцию CPUID, также возвращают 32-разрядную идентификационную подпись процессора, после сброса. Однако, инструкция CPUID дает возможность проверки подписи процессора в любое время. Рисунок 3 показывает формат 32-разрядной подписи процессора для Intel486 и последующих процессоров. Обратите внимание на то, что значение подписи процессора EDX после сброса эквивалентно выходному значению подписи процессора в регистре EAX на рисунке 2. Рассмотрим содержание EDX регистра подробнее: (здесь можно сделать таблицу)

  • Биты с 20 по 27: дополнительная информация о семействе, используется в сочетании с основным кодом семейства, определенным между битами 8 и 11, чтобы указать, принадлежит ли процессор Intel386, Intel486, Pentium, Pentium Pro или Pentium 4 семействам.
  • Биты с 16 по 19: дополнительная информация о модели, используется в сочетании с номером модели, определенным между битами 4 и 7, используются для идентификации модели процессора в семействе. ID в битах 0 до 3 указывает номер ревизии той модели.
  • Биты с 12 по 13: информация о типе процессора, указывает, является ли процессор исходным процессором OEM, OverDrive или сдвоенным (Dual). Значения типа процессора, возвращенный в битах 12 и 13 из регистра EAX, представлены в таблице 2.
  • Биты с 8 по 11: основной код семейства процессора
  • Биты с 4 по 7: модель семейства процессора
  • Биты с 0 по 3: номер ревизии модели

Флаги и характеристики

Когда регистр EAX содержит значение 1, инструкция CPUID (в дополнение к загрузке подписи процессора в регистре EAX), загружает EDX и регистр ECX со значениями флагов. Значения флагов (когда Флаг = 1) показывают, какие функции поддерживает процессор. Чтобы узнать, какие функции поддерживает процессор, следует обратиться к руководству для разработчиков, пользователей или другой подходящей документации процессора.

Размер кэша, формат и информация TLB

Когда регистр EAX содержит значение 2, инструкция CPUID загружает EAX, EBX, ECX и регистры EDX с дескрипторами, которые указывают кэш процессоров и характеристики TLB. Последние 8 бит регистра EAX (AL) содержат значение, которое показывает, сколько раз должна выполниться инструкция CPUID, чтобы получить полную картину системы кэширования процессора. Например, процессор Pentium 4 возвращает значение 1 в последних 8 битах регистра EAX, чтобы указать, что инструкция CPUID должна быть выполнена один раз (при EAX = 2) для получения полной картины конфигурации процессора.

Серийный номер процессора

Серийный номер процессора расширяет понятие идентификации процессора. Серийный номер процессора - 96-разрядное число, доступное через инструкцию CPUID. Он может использоваться приложениями, чтобы идентифицировать процессор.

Серийный номер процессора создает уникальное программное решение для конкретного процессора. Серийный номер в комбинации с другими классификаторами может быть применен к идентификации пользователя. Приложения включают проверку подлинности членства, резервное копирование данных / восстановление, съемная защита данных хранения, управление доступом к файлам, или подтвержденный обмен документом между надлежащими пользователями. Также серийный номер может использоваться для включения доверенного PC.

Наличие серийного номера процессора

Чтобы определить, поддерживается ли функция определения серийного номера процессора, программе следует установить значение параметра регистра EAX равным 1, а затем выполнить инструкцию CPUID следующим образом:

После выполнения инструкции CPUID регистры ECX и EDX содержат характеристики и флаги. Если флаг PSN (бит 18 регистра EDX) равен 1, то серийный номер процессора поддерживается и включен. При 0 он либо выключен, либо не поддерживается.

Формирование 96-битного серийного номера

96-разрядный серийный номер процессора - это комбинация трех 32-разрядный объектов. Чтобы получить доступ к старшим 32-разрядным битам, программе следует установить параметр регистра EAX в 1, а затем выполнить инструкцию как показано ниже:

После ее выполнения регистр EAX содержит идентификационную подпись процессора. Она включает старшие 32-разрядные бита серийного номера процессора. Значение в EAX должно быть сохранено до сбора оставшихся 64 битов серийного номера.

Чтобы получить к ним доступ, программе следует установить параметр регистра EAX в 3, а затем выполнить инструкцию CPUID:

После выполнения инструкции CPUID регистр EDX содержит средние 32 бита, а регистр ECX содержит младшие значащие 32 бита серийного номера. После этого программа может соединить сохраненную идентификационную подпись, EDX и ECX, а затем возвратить полный 96-битный серийный номер процессора. [2]

Номер, помогающий идентифицировать процессор

Процессоры, которые имеют такой номер, возвращают его в битах с 0 по 7 в регистре EBX, когда CPUID выполняется со стартовым значением 1 регистра EAX. Процессоры, которые не поддерживают такой номер, возвращают нулевое значение в этих же битах регистра EBX.

Строка идентификации

Эта строка - новое расширение инструкции CPUID, реализованная в некоторых процессорах. Используя ее, эти процессоры будут возвращать эту идентификационную строку в кодировке ASCII и максимальную рабочую частоту через инструкцию CPUID. Когда инструкция будет выполняться с набором значений регистра EAX, указанным с таблице 4, процессор будет возвращать эту строку в регистрах общего назначения. [3]

Последовательность идентификации процессора

Для идентификации процессора с помощью CPUID инструкции, программе следует придерживаться следующей последовательности:

Создает cpuid инструкцию, доступную на платформах x86 и x64. Эта инструкция запрашивает у процессора информацию о поддерживаемых возможностях и типе ЦП.

Синтаксис

Параметры

кпуинфо
заполняет Массив из четырех целых чисел, содержащих данные, возвращаемые в EAX, EBX, ECX и EDX о поддерживаемых возможностях ЦП.

function_id
окне Код, указывающий сведения для извлечения, переданные в EAX.

subfunction_id
окне Дополнительный код, указывающий сведения для извлечения, передаваемые в ECX.

Требования

Intrinsic Architecture
__cpuid x86, x64
__cpuidex x86, x64

Файл заголовка <intrin.h>

Remarks

Эта встроенная функция хранит поддерживаемые функции и сведения о ЦП, возвращаемые cpuid инструкцией в кпуинфо, массив 4 32-разрядных целых чисел, который заполняется ЗНАЧЕНИЯМИ регистров EAX, EBX, ECX и EDX (в этом порядке). Возвращаемые сведения имеют разные значения в зависимости от значения, переданного в качестве параметра function_id . Сведения, возвращаемые с различными значениями function_id , зависят от процессора.

Встроенная функция __cpuid очищает регистр ECX перед вызовом инструкции cpuid . __cpuidex Встроенная функция задает для регистра ecx значение subfunction_id перед созданием cpuid инструкции. Он позволяет собирать дополнительные сведения о процессоре.

Дополнительные сведения о конкретных параметрах, которые необходимо использовать, и значения, возвращаемые этими встроенными функциями процессоров Intel, см. в документации по cpuid инструкциям в руководстве по архитектуре Intel 64 и IA-32 Руководство по программированию для разработчиков программного обеспечения том 2: Справочник по набору инструкций и Справочные сведения о расширении набора инструкций по архитектуре Intel. В документации Intel используются условия "конечный" и "конечный лист" для function_id и subfunction_id параметров, передаваемых в EAX и ECX.

Дополнительные сведения о конкретных параметрах, которые необходимо использовать, и значения, возвращаемые этими встроенными функциями процессоров AMD, см. в документации по инструкциям cpuid в руководстве по архитектуре AMD64, том 3: General-Purpose и системные инструкции, а также в руководствах по редакциям для конкретных семейств процессоров. Ссылки на эти документы и другие сведения см. в руководствах для разработчиков AMD, руководства & ISA-документы . В документации по AMD используются термины "номер функции" и "номер подфункции" для параметров function_id и subfunction_id , передаваемых в EAX и ECX.

Если аргумент function_id равен 0, кпуинфо[0] возвращает наибольшее доступное значение нерасширенного function_id , поддерживаемое процессором. Производитель процессора кодируется в кпуинфо[1], кпуинфо[2] и кпуинфо[3].

Поддержка конкретных расширений набора инструкций и функций ЦП кодируется в результатах кпуинфо , возвращаемых для более высоких значений function_id . Дополнительные сведения содержатся в разделе вышеописанные руководства и в следующем примере кода.

Некоторые процессоры поддерживают информацию о расширенной функции CPUID. Если он поддерживается, для возврата информации могут использоваться function_id значения от 0x80000000. Чтобы определить максимально допустимое значение, задайте для function_id значение 0x80000000. Максимальное значение function_id , поддерживаемое для расширенных функций, записывается в кпуинфо[0].

Пример

В этом примере показаны некоторые сведения, доступные через __cpuid и __cpuidex встроенных функций. Приложение выводит список расширений набора инструкций, поддерживаемых текущим процессором. Вывод показывает возможные результаты для конкретного процессора.

Завершение блока, относящегося только к системам Майкрософт

Читайте также: