структура PEP_ACPI_EXTENDED_ADDRESS (pep_x.h)

Структура PEP_ACPI_EXTENDED_ADDRESS используется для создания отчетов об использовании ресурсов в адресном пространстве, например памяти и операций ввода-вывода.

Синтаксис

typedef struct _PEP_ACPI_EXTENDED_ADDRESS {
  PEP_ACPI_RESOURCE_TYPE  Type;
  PEP_ACPI_RESOURCE_FLAGS Flags;
  UCHAR                   ResourceFlags;
  UCHAR                   GeneralFlags;
  UCHAR                   TypeSpecificFlags;
  UCHAR                   RevisionId;
  UCHAR                   Reserved;
  ULONGLONG               Granularity;
  ULONGLONG               MinimumAddress;
  ULONGLONG               MaximumAddress;
  ULONGLONG               TranslationAddress;
  ULONGLONG               AddressLength;
  ULONGLONG               TypeAttribute;
  PUNICODE_STRING         DescriptorName;
} PEP_ACPI_EXTENDED_ADDRESS, *PPEP_ACPI_EXTENDED_ADDRESS;

Члены

Type

Значение перечисления PEP_ACPI_RESOURCE_TYPE , описывающее этот ресурс.

Flags

Структура PEP_ACPI_RESOURCE_FLAGS , описывающая этот ресурс.

ResourceFlags

Указывает тип ресурса, описываемого этой структурой.

Значение Значение
0
Указывает, что этот ресурс является диапазоном памяти.
1
Указывает, что этот ресурс является диапазоном операций ввода-вывода.
2
Указывает, что этот ресурс является диапазоном номеров шины.
3-191
Эти значения зарезервированы для использования в будущем.
192-255
Эти значения зарезервированы для использования поставщиком оборудования.

GeneralFlags

Значение , содержащее битовые флаги, общие для всех типов ресурсов.

Биты Значение
0 — флаг потребителя или производителя
Если этот параметр задан, это означает, что устройство использует этот ресурс.
1 . Тип декодирования
Если задано значение , указывает, что этот мост субтрактивно декодирует адрес. Это относится только к мостам верхнего уровня.

Если значение не задано, указывает, что этот мост декодирует этот адрес.

2 — фиксированный минимальный адрес
Если задано значение , указывает, что минимальный адрес является фиксированным.
3 — исправлено максимальное число адресов
Если задано значение , указывает, что максимальный адрес является фиксированным.
От 4 до 7 — зарезервировано
Эти биты зарезервированы и должны иметь нулевое значение.

TypeSpecificFlags

Значение этого элемента зависит от значения в элементе ResourceFlags . Флаги для каждого типа ресурса описаны в таблицах ниже.

Ресурс памяти (ResourceFlags = 0)

Биты Значение
0 — состояние записи
Если этот параметр задан, указывает, что этот диапазон памяти доступен для чтения и записи. В противном случае это означает, что этот диапазон памяти доступен только для чтения.
От 1 до 2 — атрибуты памяти (MEM)
0 — указывает, что память не кэшируется.

1 — указывает, что память кэшируется.

2 — указывает, что память кэшируется и поддерживает объединение операций записи.

3 — память кэшируется и доступна для предварительной выборки.

От 3 до 4 — атрибуты памяти (MTP)
Эти биты определяются только в том случае, если этот ресурс памяти описывает системный ОЗУ.

0 — память диапазона адресов. Этот диапазон ОЗУ доступен для использования операционной системой.

1 — зарезервированный диапазон адресов. Этот диапазон адресов используется или зарезервирован системой и не должен включаться в пул памяти диспетчера памяти операционной системы.

2 . ACPI диапазона адресов: ACPI reclaim Memory. Этот диапазон ОЗУ может использовать ос после считывания таблиц ACPI.

3 . Диапазон адресов NVS: ACPI NVS Memory. Этот диапазон адресов используется или зарезервирован системой и не должен использоваться операционной системой. Этот диапазон необходимо сохранить и восстановить в спящем режиме NVS.

5. Преобразование операций ввода-вывода в память
0 — тип статического типа. Этот ресурс является памятью на основной и вторичной сторонах моста.

1 . Преобразование типов. Этот ресурс представляет собой память на вторичной стороне моста и операции ввода-вывода на основной стороне моста.

От 6 до 7 — зарезервировано
Эти биты зарезервированы и должны иметь нулевое значение.
 

Ресурс ввода-вывода (ResourceFlags = 1)

Биты Значение
От 0 до 1 — диапазон
0 — зарезервировано.

1 — только диапазоны, отличные от ISA. Этот флаг предназначен для мостов в системах с несколькими мостами. Установка этого бита означает, что окно памяти, указанное в этом дескрипторе, ограничено адресами ввода-вывода, не относящиеся к ISA, которые попадают в указанное окно. Диапазоны операций ввода-вывода, отличные от ISA: n100-n3FF, n500-n7FF, n900-nBFF, nD00-nFFF. Этот бит можно задать только для мостов, полностью настроенных через пространство имен ACPI.

2 — только диапазоны ISA. Этот флаг предназначен для мостов в системах с несколькими мостами. Установка этого бита означает, что окно памяти, указанное в этом дескрипторе, ограничено адресами ввода-вывода ISA, которые входят в указанное окно. Диапазоны операций ввода-вывода ISA: n000-n0FF, n400-n4FF, n800-n8FF, nC00-nCFF. Этот бит можно задать только для мостов, полностью настроенных через пространство имен ACPI.

3 . Окно памяти охватывает весь диапазон

От 2 до 3 — зарезервировано
Эти биты зарезервированы и должны иметь нулевое значение.
4. Преобразование операций ввода-вывода в память
0 — тип статического типа. Этот ресурс является операцией ввода-вывода на основной и вторичной сторонах моста.

1 . Преобразование типов. Этот ресурс является операцией ввода-вывода на вторичной стороне моста и памятью на основной стороне моста.

5 . Разреженный перевод
Этот бит имеет смысл только в том случае, если задан бит 4 (преобразование ввода-вывода в память).

0 — плотное преобразование. Основной адрес памяти для любого конкретного порта ввода-вывода в дополнительном диапазоне можно найти с помощью следующей функции.

address = port + TranslationAddress

1 . Разреженный перевод. Основной адрес памяти для любого конкретного порта ввода-вывода в дополнительном диапазоне можно найти с помощью следующей функции.

address = (((port & 0xFFFc) << 10) || (порт & 0xFFF)) + TranslationAddress

В адресе, используемом для доступа к порту ввода-вывода, биты от 2 до 11 должны быть идентичны битам от 12 до 21. Это дает четыре байта портов ввода-вывода на каждой странице размером 4 КБ.

От 6 до 7 — зарезервировано
Эти биты зарезервированы и должны иметь нулевое значение.
 

Ресурс диапазона номеров шины (ResourceFlags = 2)

Биты Значение
От 0 до 7 — зарезервировано
Эти биты зарезервированы и должны иметь нулевое значение.

RevisionId

Указывает редакцию дескриптора расширенного адресного пространства, подробно описанного этой структурой. Для ACPI 3.0 это значение равно 1.

Reserved

Granularity

Битовая маска, указывающая, какие биты были декодированы.

MinimumAddress

Минимальный начальный адрес. Для мостов, которые переводят адреса, это адресное пространство на вторичной стороне моста.

MaximumAddress

Максимальный начальный адрес. Для мостов, которые переводят адреса, это адресное пространство на вторичной стороне моста.

TranslationAddress

Для мостов, которые переводят адреса через мост, это адрес на основной стороне.

AddressLength

Длина адреса.

TypeAttribute

Указывает атрибуты, относящиеся к типу ресурса, указанному в элементе ResourceFlags . Если ResourceFlags равно нулю, это значение равно нулю, в противном случае значение значения можно найти в спецификации UEFI в разделе GetMemoryMap().

DescriptorName

Имя дескриптора ресурса.

Требования

Требование Значение
Минимальная версия клиента Поддерживается начиная с Windows 10.
Верхняя часть pep_x.h (включая Pep_x.h)