Для более эффективной работы DDIM желательно использовать не только стандартную, но и расширенную память (за пределами первого мегабайта), в то время как POST работает в реальном режиме процессора. Решить эту проблему помогает режим «Big Real Mode», который поддерживают все 32-разрядные процессоры (см. п. 12.3.1). Специально для предоставления доступа ко всей памяти процедурами инициализации фирмы Phoenics и Intel разработали спецификацию PMM (POST Memory Manager Specification), версия 1.01 была опубликована в конце 1997 г. Эта спецификация определяет несколько дополнительных сервисов BIOS, позволяющих выделять, находить и освобождать блоки в любой, в том числе и расширенной памяти. Клиенты этого сервиса запрашивают блок памяти требуемого размера, a BIOS возвращает физический 32-разрядный адрес начала выделяемого блока (если она способна его выделить). Клиент помечает свой блок 32-битным индексом (handle), по которому его в дальнейшем можно найти функцией поиска. Анонимный блок (индекс FFFFFFFFh) поиску не поддается. Этими сервисами можно пользоваться только до начала процедуры начальной загрузки ( Int 19h
), работу с вентилем Gate A20 они берут на себя. Перед начальной загрузкой BIOS освобождает и обнуляет все блоки расширенной памяти, занятые с помощью этих сервисов. Сервисами PMM могут пользоваться процедуры инициализации карт расширения, а также процедуры BCV
, описанные в заголовке ПЗУ карт PnP (см. ниже). Процедуры, на которые указывает BEV
, ими пользоваться не могут, поскольку вызываются после входа в Int 19h
. Наличие сервисов PMM определяется по контрольной структуре, начинающейся со строки-сигнатуры $PMM
и расположенной на границе параграфа в области E0000-FFFF0h. Программный интерфейс можно найти в вышеуказанном документе, который доступен на сайте http://www.phoenix.com/techs.
12.9.1. ROM BIOS карт ISA PnP
Для поддержки технологии PnP и расширения возможностей управления начальной загрузкой в спецификации PnP BIOS ввели дополнительный указатель на структуру расширенного заголовка (Expansion Header Structure). Расширенный заголовок имеет формат, приведенный в табл. 12.9. В одном ПЗУ может находиться несколько расширенных заголовков (это требуется для многофункциональных карт расширения), связанных в цепочку. В каждом расширенном заголовке может указываться смещение следующего заголовка относительно начала стандартного заголовка. Наличие и действительность расширенного заголовка проверяется по его сигнатуре и контрольной сумме. Сумма всех байтов расширенного заголовка, включая байт контрольной суммы, должна быть нулевой.
Таблица 12.9. Расширенный заголовок ROM BIOS карт ISA PnP
Смещение |
Длина |
Назначение |
0h |
4 байта |
Сигнатура, строка $PnP (символы ASCII) |
04h |
байт |
Версия структуры (01h) |
05h |
байт |
Длина (в параграфах по 16 байт) |
06h |
слово |
Смещение следующего заголовка (0000h, если нет больше) |
08h |
байт |
Резерв(0) |
09h |
байт |
Контрольная сумма |
0Ah |
двойное слово |
Идентификатор устройства PnP |
0Eh |
слово |
Указатель на строку идентификатора производителя (0, если нет) |
10h |
слово |
Указатель на строку названия продукта (0, если нет) |
12h |
3 байт |
Код типа устройства |
15h |
байт |
Индикаторы устройства |
16h |
слово |
Вектор подключения BCV (Boot Connection Vector) — 0, если нет |
18h |
слово |
Вектор отключения (Disconnect Vector) — 0, если нет |
1Ah |
слово |
Точка входа для загрузки BEV (Bootstrap Entry Point) — 0, если нет |
1Ch |
слово |
Резерв (0) |
1Eh |
слово |
Вектор получения информации о статических ресурсах (Static Resource Information Vector) — Real/Protected mode (0 если нет) |
Расширенный заголовок позволяет определить идентификатор устройства PnP , его название и код производителя. Код типа состоит из байта общего типа, байта подтипа и байта идентификатора программного интерфейса, по которым система может узнать знакомые устройства.
Байт индикаторов устройства имеет следующее назначение битов:
♦ бит 7 — ПЗУ поддерживает модель инициализации устройства (Device Driver Initialization Model);
♦ бит 6 — ПЗУ может затеняться оперативной памятью;
♦ бит 5 — ПЗУ может кэшироваться по чтению;
♦ бит 4 — ПЗУ требуется лишь для загрузки с данного устройства;
♦ бит 3 — резерв (0);
♦ бит 2 — является устройством загрузки (IPL-устройство);
♦ бит 1 — устройство ввода (может заменять клавиатуру);
Читать дальше