IBM PC выполняет процедуру самопроверки после каждого сброса
системы, включая момент, когда появляется питание. Такая проверка
преследует две цели: она выполняет быструю проверку основных
элементов системы и инициализирует основные аппаратные компоненты.
Как системный тест, процедура POST образует первую часть
трехуровнего диагностического пакета фирмы IBM для ее персональной
ЭВМ. Процедура POST выполняется всякий раз при включении системы.
Эта быстрая проверка тестирует работу системы и обнаруживает ошибку
до того, как она повлияет на выполнение программы. Программы,
обеспечивающие второй уровень диагностики приходит вместе с каждой
машиной в составе руководства по работе на IBM PC; эта дискета (или
кассета) содержит программу диагностики, она проверяет оьдельно
каждый компонент машины. Эта диагностическая программа определяет,
какую часть машины покуптель должен вернуть для обслуживания, если
найдена ошибка. Наконец, фирма IBM поставляет усовершенствованное
диагностическое средство. Это средство, доступное за дополнительную
плату, определяет, какой из сменных узлов не работает. Это
диагностическое средство создано для обслуживающего персонала,
работающего на таких машинах. Правда вы можете купить для себя и
усовершенствованные диагностические тесты.
Начало процедуры POST, возможно, будет трудно найти из-за того,
что оно находится в самом конце листинга. Когда микропроцессор 8088
сбрасывается (или когда включается питание), он начинает работу с
адреса 0FFFF:0000H. Эта ячейка находится всего в 16 байтах от
самого конца адресного пространства микропроцессора 8088. Этого
места хватает для команды перехода на настоящую программу POST. Как
вы видите, команда FAR JMP передает управление на метку START,
которая и есть начало процедуры POST. Фирма IBM использует
оставшиеся байты в конце памяти под дату; эта дата - момент выпуска
ПЗУ в серию.
Способ запуска процедуры POST также объясняет, почему фирма IBM
расположила ПЗУ в верхних адресах памяти. Именно здесь
микропроцессор начинает выполнение программы после сброса.
Системное ПЗУ, содержащее программу инициализации машины, должно
иметь некоторую информацию по адресу 0FFFFH:0000H. Так что есть
смысл помещать все ПЗУ в конце памяти. Также, есть смысл поместить
ОЗУ в нижних адресах, оставив в нем векторы прерываний. Возможность
модификации кодов в этих векторах в большой степени увеличивает
универсальность программы BIOS.
Вообще процедура POST состоит из неинтересных кодов. Многие
последовательности команд не имеют никакого смысла. Если вы
посмотрите на начальную последовательность команд, то увидите, что
они не делают ничего - если с микропроцессором ничего не случилось.
Если вас не интересует написание диагностических программ нет
смысла изучать технику процедуры POST. Отметим некоторые действия
процедуры POST, чтобы показать область проверки ошибок. Процедура
POST проверяет все ПЗУ системной платы, считая контрольную сумму.
Этот тест складывает все байты модулей ПЗУ. При сложении перенос из
8-битового результата игнорируется. Если окончательный результат
нулевой, ПЗУ прошло проверку. Конечно, перед тем, как запустить ПЗУ
в серию, фирма IBM обеспечила, чтобы сумма каждого ПЗУ была равна
нулю. Если ПЗУ плохое, этот тест находит ошибку.
Процедура POST также проверяет всю оперативную память в
системе. Переключатели не системной плате сообщают процедуре POST,
сколько у системы есть памяти в наличии. Каждый бит памяти
проверяется, может ли он быть установлен в единицу и сброшен в
нуль. По окончании теста процедура POST записывает нули по всем
адресам памяти. Это означает, что если вы написали программу,
которая будет работать сразу же после процедуры POST, содержимое
всей памяти окажется нулевым. Но надеяться, что некоторая другая
программа инициализирует поля данных вашей программы - плохой стиль
программирования. чтобы быть в этом уверенным, лучше делать это
самому.
Последнее, что можно сказать про процедуру POST - то, что она
Аппаратные прерывания
---------------------------------------------------------
Номер
прерывания Использование в ROM BIOS
---------------------------------------------------------
2 02H Ошибка четности в памяти
5 05H Печать экрана
8 08H Текущее время
9 09H Клавиатура
14 OEH Дискета
Драйверы BIOS
---------------------------------------------------------
Номер
прерывания Использование в ROM BIOS
---------------------------------------------------------
16 10H Видео
17 11H Проверка оборудования
18 12H Размер памяти
19 13H Дискета
20 14H Асинхронные
21 15H Кассета стриммера
22 16H Клавиатура
23 17H Принтер
24 18H Точка входа Бэйсика для кассеты
25 19H Точка входа в процедуру первичной
загрузки
26 1AH Текущее время
---------------------------------------------------------
Процедуры управляемые пользователем
---------------------------------------------------------
Номер
прерывания Использование в ROM BIOS
---------------------------------------------------------
27 1BH Прерывание клавиатуры
28 1CH Квантование времени
Блоки параметров BIOS
---------------------------------------------------------
Номер
прерывания Использование в ROM BIOS
---------------------------------------------------------
29 1DH Параметры видеомонитора
30 1EH Параметры дисковода
31 1FH Графические символы видеомонитора
---------------------------------------------------------
Фиг. 9.1 Векторы прерываний, используемые
ROM BIOS
инициализирует векторы прерываний для BIOS. Программы получают
доступ к BIOS с помощью векторов прерывания. Сами по себе эти
подпрограммы находятся в модуле ПЗУ, в том же, что и процедура
POST. Перед тем, как процедура POST передаст управление
операционной системе, она делает так, чтобы каждая входная точка
BIOS была записана в соответствующий вектор прерывания. BIOS
использует векторы прерываний для прерываний от 2 до 01FH.
Техническое описание содержит листинг векторов прерывания, в
котором показаны номера прерываний и первоначальное содержимое
векторов. На Фиг.9.1 изображена часть этой таблицы, которая будет
использоваться в описании BIOS.