American Megatrends, Inc. (AMI)
Контрольные точки процедур POST, выполняемых в AMIBIOS, были переработа- ны и дополнены в 1995 году и до настоящего времени не претерпели существенных из- менений. Первое описание POST кодов или как их называет AMI - "check points" в их нынешнем виде появилось в связи с выходом в свет ядра V6.24, 15/07/95. Некоторые изменения внесены в AMIBIOS V7.0, что отражается в настоящем документе.
Особенности выполнения стартовых процедур AMIBIOS
Если в процессе старта в диагностическом порту появляются данные 55h, AAh, не следует сопоставлять эту информацию с POST кодами - мы имеем дело с типовой тестовой последовательностью, в задачи которой входит проверка целостности шины данных.
На этапе старта вывод в диагностический порт данных носит специфический для каждой платформы характер. В некоторых реализациях первый визуализируемый код связан с действиями, который компания AMI называет chipset specific stuff. Эта проце- дура сопровождается выводом в порт 80h значения CCh и выполнением ряда действий по настройке регистров системной логики. Как правило, код CCh возникает в тех слу- чаях, когда используется системная логика от Intel, построенная на основе контроллера PIIX - это чипсеты TX, LX, BX.
Некоторые бортовые микросхемы ввода-вывода содержат RTC и контроллер кла- виатуры, которые по старту находятся в отключенном состоянии. Цель BIOS - проини- циализировать эти ресурсы платы для дальнейшего использования. В этом случае пер- вая стартовая процедура, связанная с настройкой контроллера клавиатуры, сопровож- дается выводом значения 10h, затем выполняется инициализация RTC, о чем свиде- тельствует появление в диагностическом порту кода DDh. Следует отметить, что отказ хотя бы одного из этих ресурсов повлечет нестарт системной платы в целом на первом же этапе выполнения POST.
На ряде плат процесс инициализации начинается с перевода CPU в защищенный режим. В этом случае вслед за первым визуализируемым кодом 43h выполнение POST продолжается так, как описано в документации AMIBIOS - управление передается в точку D0h.
Коды неупакованной процедуры инициализации
Uncompressed Init Code Check Points
Код ошибки | Описание ошибки |
---|---|
EE | В современных реализациях AMIBIOS первый визуализируемый код связан с об- ращением к устройству, с которого возможна загрузка для восстановления BIOS |
CC | Инициализация регистров системной логики CD Тип Flash ROM не опознан |
CE | Несовпадение контрольных сумм в стартовом BIOS CF Ошибка в доступе к запасной микросхеме Flash ROM |
DD | Ранняя инициализация RTC, который интегрирован в SIO чип |
D0 | Запрет немаскируемого прерывания NMI. Отработка временной задержки для за- тухания переходных процессов. Проверка контрольной суммы Boot Block, оста- нов при несовпадении |
D1 | Выполнение процедуры регенерации памяти и Basic Assurance Test. Переход в 4 GB режим адресации памяти |
D3 | Определение объема и первичный тест памяти |
D4 | Возврат в реальный режим адресации памяти. Ранняя инициализация чип сета. Установка стека |
D5 | Перенос модуля POST из Flash ROM в транзитную область памяти |
D6 | При несовпадении контрольной суммы или CTRL+Home выполняется переход на процедуру восстановления Flash ROM (Код E0) |
D7 | Передача управления служебной программе, осуществляющей распаковку сис- темного BIOS |
D8 | Полная распаковка системного BIOS |
D9 | Передача управления системному BIOS в Shadow RAM |
DA | Чтение информации из SPD (Serial Presence Detect) модулей DIMM DB Настройка MTRR регистров центрального процессора |
DC | Контроллер памяти программируются согласно данным, полученным из SPD DE Ошибка конфигурации системной памяти. Фатальная ошибка |
DF | Ошибка конфигурации системной памяти. Звуковой сигнал 10 Ранняя |
11 | Возврат из состояния STR (Suspend to RAM) |
12 | Восстановление доступа к SMRAM (System Management RAM) |
13 | Восстановление регенерации памяти |
14 | Поиск и инициализация VGA BIOS |
Коды процедуры перезаписи Flash ROM
Boot Block Recovery Codes
Код ошибки | Описание ошибки |
---|---|
E0 | Выполняется подготовка к перехвату INT19 и проверяется возможность старта системы в упрощенном режиме |
E1 | Установка векторов прерываний |
E3 | Восстановление содержимого CMOS, поиск и инициализация BIOS |
E2 | Подготовка контроллеров прерываний и непосредственного доступа к памяти |
E6 | Разрешение прерываний от системного таймера и FDC |
EC | Повторная инициализация контроллеров IRQ и DMA ED Инициализация дисковода |
EE | Чтение загрузочного сектора с дискеты EF Ошибка дисковых операций |
F0 | Поиск файла AMIBOOT.ROM |
F1 | В корневом каталоге файл AMIBOOT.ROM не найден F2 Считывание FAT |
F3 | Считывание AMIBOOT.ROM |
F4 | Объем файла AMIBOOT.ROM не соответствует объему Flash ROM |
F5 | Запрет Internal Cache |
FB | Определение типа Flash ROM |
FC | Стирание основного блока Flash ROM |
FD | Программирование основного блока Flash ROM |
FF | Рестарт BIOS |
Коды распакованного системного BIOS, выполняемые в ShadowRAM
Runtime code is uncompressed in F000 shadow RAM
Код ошибки | Описание ошибки |
---|---|
03 | Запрет немаскируемого прерывания NMI. Определение типа сброса |
05 | Инициализация стека. Запрет кэширования памяти и контроллера USB |
06 | Выполнение в ОЗУ служебной программы |
07 | Распознавание процессора и инициализация APIC |
08 | Проверка контрольной суммы CMOS |
09 | Проверка отработки клавиш End/Ins |
0A | Проверка сбоя батарейного питания |
0B | Очистка буферных регистров контроллера клавиатуры |
0C | Контроллеру клавиатуры передается команда тестирования |
0E | Поиск дополнительных устройств, обслуживаемых контроллером клавиатуры |
0F | Инициализация клавиатуры |
10 | Клавиатуре передается команда сброса |
11 | Если нажата клавиша End или Ins, выполняется сброс CMOS 12 Перевод в пассивное состояние контроллеров DMA |
13 | Инициализация чип сета и кэш L2 |
14 | Проверка системного таймера |
19 | Выполняется тест формирования запросов на регенерацию DRAM |
1A | Проверка длительности цикла регенерации |
20 | Инициализация устройств вывода |
23 | Считывается порт ввода контроллера клавиатуры. Опрашивается Keylock Switch и Manufacture Test Switch |
24 | Подготовка к инициализации таблицы векторов прерываний |
25 | Инициализация векторов прерываний завершена |
26 | Через порт ввода контроллера клавиатуры опрашивается состояние перемычки Turbo Switch |
27 | Первичная инициализация контроллера USB. Обновление микрокода стартового процессора |
28 | Подготовка к установке видеорежима |
29 | Инициализация LCD панели |
2A | Поиск устройств, обслуживаемых дополнительными ROM |
2B | Инициализации VGA BIOS, проверка его контрольной суммы |
2C | Выполнение VGA BIOS |
2D | Согласование INT 10h и INT 42h |
2E | Поиск видеоадаптеров CGA |
2F | Тест видеопамяти адаптера CGA |
30 | Тест схем формирования разверток адаптера CGA |
31 | Ошибка видеопамяти или схем формирования разверток. Поиск альтернативного видеоадаптера CGA |
32 | Тест видеопамяти альтернативного видеоадаптера CGA и схем разверток |
33 | Опрос состояния перемычки Mono/Color |
34 | Установка текстового режима 80х25 |
37 | Видеорежим установлен. Экран очищен |
38 | Инициализация бортовых устройств |
39 | Вывод сообщений об ошибках на предыдущем шаге |
3A | Вывод сообщения «Hit DEL» для входа в CMOS Setup |
3B | Начало подготовки к тесту памяти в защищенном режиме |
40 | Подготовка дескрипторных таблиц GDT и IDT |
42 | Переход в защищенный режим |
43 | Процессор в защищенном режиме. Прерывания разрешены |
44 | Подготовка к проверке линии A20 |
45 | Тест линии A20 |
46 | Определение размера ОЗУ выполнено |
47 | Тестовые данные записаны в Conventional Memory |
48 | Повторная проверка Conventional Memory |
49 | Тест Extended Memory |
4B | Обнуление памяти |
4C | Индикация процесса обнуления |
4D | Запись в CMOS полученных размеров Conventional и Extended memory 4E Индикация реального объема системной памяти |
4F | Выполняется расширенный тест Conventional Memory |
50 | Коррекция размера Conventional Memory |
51 | Расширенный тест Extended Memory |
52 | Объемы Conventional Memory и Extended Memory сохранены |
53 | Обработка отложенных ошибок четности |
54 | Запрет контроля четности и обработки немаскируемых прерываний |
57 | Инициализация региона памяти для POST Memory Manager |
58 | Выводится приглашение для входа в CMOS Setup |
59 | Возврат процессора в реальный режим |
60 | Проверка страничных регистров DMA |
62 | Тест регистров адреса и длины пересылки контроллера DMA#1 |
63 | Тест регистров адреса и длины пересылки контроллера DMA#2 |
65 | Программирование контроллеров DMA |
66 | Очистка регистров Write Request и Mask Set POST |
67 | Программирование контроллеров прерываний |
7F | Разрешение запроса NMI от дополнительных источников |
80 | Устанавливается режим обслуживания прерываний от порта PS/2 |
81 | Тест интерфейса клавиатуры при ошибках сброса |
82 | Установка режима работы контроллера клавиатуры |
83 | Проверка статуса Keylock |
84 | Верификация объема памяти |
85 | Вывод на экран сообщений об ошибках |
86 | Настройка системы для работы Setup |
87 | Распаковка программы CMOS Setup в Conventional Memory. |
88 | Работа программы Setup завершена пользователем |
89 | Завершено восстановление состояния после работы Setup |
8B | Резервирование памяти дополнительному блоку переменных BIOS |
8C | Программирование конфигурационных регистров |
8D | Первичная инициализация контроллеров HDD и FDD |
8F | Повторная инициализация контроллера FDD |
91 | Конфигурирование контроллера жестких дисков |
95 | Выполняется ROM Scan для поиска дополнительных BIOS |
96 | Дополнительная настройка системных ресурсов |
97 | Проверка сигнатуры и контрольной суммы дополнительного BIOS |
98 | Настройка System Management RAM |
99 | Установка счетчика таймера и переменных параллельных портов 9A Формирование списка последовательных портов |
9B | Подготовка области в памяти для теста сопроцессора |
9C | Инициализация сопроцессора |
9D | Информация о сопроцессоре сохраняется в CMOS RAM |
9E | Идентификация типа клавиатуры |
9F | Поиск дополнительных устройств ввода |
A0 | Формирование регистров MTRR (Memory Type Range Registers) |
A2 | Сообщений об ошибках на предыдущих этапах инициализации |
A3 | Установка временных характеристик автоповтора клавиатуры |
A4 | Дефрагментирование неиспользованных регионов RAM |
A5 | Установка видео режима |
A6 | Очистка экрана |
A7 | Перенос исполняемого кода BIOS область Shadow RAM |
A8 | Инициализация дополнительного BIOS в сегменте E000h |
A9 | Возврат управления системному BIOS AA Инициализация USB шины |
AB | Подготовка модуля INT13 для обслуживания дисковых сервисов |
AC | Построение таблиц AIOPIC для поддержки мультипроцессорных систем AD Подготовка модуля INT10 для обслуживания видео сервисов |
AE | Инициализация DMI |
B0 | Таблица конфигурации системы выведена B1 Инициализация ACPI BIOS |
00 | Программное прерывание INT19h – загрузка Boot Sector |
Особенности выполнения Device Initialization Manager
Кроме выше указанных POST кодов, в диагностический порт выводятся сообще- ния о событиях в процессе выполнения Device Initialization Manager (DIM). Существует несколько контрольных точек, в которых отображается состояние инициализации сис- темных или локальных шин.
Информация отображается в формате слова, младший байт которого совпадает с системным POST кодом, а старший байт указывает на тип выполняемой инициализационной процедуры. Старшая тетрада в старшем байте указывает тип выполняемой процедуры, а младшая определяет шинную топологию для ее применения.
Старшая тетрада
Младшая тетрада
В случае если обнаружена ошибка конфигурации системной памяти, в порт 80h выводится последовательно в бесконечном цикле код DE, код DF, код ошибки конфигурации, который может принимать следующие значения:
2. Award BIOS V4.51PG Elite
AwardBIOS V4.51PG Elite
Динамично развивающаяся компания Award Software в 1995 году предложила новое на то время решение в области низкоуровневого программного обеспечения - AwardBIOS "Elite", более известное как V4.50PG. Режим обслуживания контрольных точек не изменился ни в широко распространенной версии V4.51, ни в раритетном исполнении V4.60. Суффиксы P и G обозначают соответственно поддержку механизма PnP и обслуживание функций энергосбережения (Green Function).
Выполнение POST в Shadow RAM
Код ошибки | Описание ошибки |
---|---|
03 | Запрет NMI, PIE (Periodic Interrupt Enable), AIE (Alarm Interrupt Enable), UIE (Update Interrupt Enable). Запрет генерации программируемой частоты SQWV |
04 | Проверка формирования запросов на регенерацию DRAM |
05 | |
06 | Тест области памяти, начинающейся с адреса F000h, где размещен BIOS 07 Проверка функционирования CMOS и батарейного питания |
BE | Программирование конфигурационных регистров Южного и Северного Мостов |
09 | Инициализация кэш-памяти L2 и регистров расширенного управления кэширова- нием процессора Cyrix |
0A | Генерация таблицы векторов прерываний. Настройка ресурсов Power Management и установка вектора SMI |
0B | Проверка контрольной суммы CMOS. Сканирование шины PCI устройств. Обнов- ление микрокода процессора |
0С | Инициализация контроллера клавиатуры |
0D | Поиск и инициализация видеоадаптера. Настройка IOAPIC. Измерения тактовой частоты, установка FSB |
0E | Инициализация MPC. Тест видеопамяти. Вывод на экран Award Logo |
0F | Проверка первого контроллера DMA 8237. Определение клавиатуры и ее внут- ренний тест. Проверка контрольной суммы BIOS |
10 | Проверка второго контроллера DMA 8237 |
11 | Проверка страничных регистров контроллеров DMA |
14 | Тест канала 2 системного таймера 15 Тест регистра маскирования запросов 1-го контроллера прерываний |
16 | Тест регистра маскирования запросов 2-го контроллера прерываний 19 Проверка пассивности запроса немаскируемого прерывания NMI |
30 | Определение объема Base Memory и Extended Memory. Настройка APIC. Программное управление режимом Write Allocation |
Код ошибки | Описание ошибки |
---|---|
31 | Основной отображаемый на экране тест оперативной памяти. Инициализация USB |
32 | Выводится заставка Plug and Play BIOS Extension. Настройка ресурсов Super I/O. Программируется Onboard Audio Device |
39 | Программирование тактового генератора по шине I2C |
3C | Установка программного флага разрешения входа в Setup |
3D | Инициализация PS/2 mouse |
3E | Инициализации контроллера External Cache и разрешения Cache BF Настройка конфигурационных регистров чип сета |
41 | Инициализация подсистемы гибких дисков |
42 | Отключение IRQ12 если PS/2 mouse отсутствует. Выполняется программный сброс контроллера жестких дисков. Сканирование других IDE устройств |
43 | |
45 | Инициализация сопроцессора FPU |
4E | Индикация сообщений об ошибках |
4F | Запрос пароля |
50 | Восстановление ранее сохраненного в ОЗУ состояния CMOS |
51 | Разрешение 32 битного доступа к HDD. Настройка ресурсов ISA/PnP |
52 | Инициализация дополнительных BIOS. Установка значений конфигурационных регистров PIIX. Формирование NMI и SMI |
53 | |
60 | Установка антивирусной защиты BOOT Sector |
61 | Завершающие действия по инициализации чип сет |
62 | Чтение идентификатора клавиатуры. Установка ее параметров |
63 | Коррекция блоков ESCD, DMI. Очистка ОЗУ |
FF | Передача управления загрузчику. BIOS выполняет команду INT 19h |
3. Award BIOS V6.0 Medallion
AwardBIOS V6.0 Medallion
Первое упоминание об Award Medallion BIOS, Version 6.0 датируется 12 мая 1999 года. Структура нового продукта осталась неизменной, сохранив раннюю (Early), позд- нюю (Late) и финальную (System) фазы инициализации аппаратного обеспечения. Су- щественные изменения коснулись алгоритмов выполнения POST, что отразилось на но- вой кодировке контрольных точек, значительно расширив их сферу применения. Вме- сте с тем, в новом BIOS не нашлось места устаревшим технологиям, таким как EISA, и по этой причине ряд POST кодов было упразднено.
Выполнение стартовых процедур POST из ROM
На этапе ранней инициализации программный код BIOS выполняется из загру- зочного блока (Boot Block) во Flash ROM, и сопровождается выводом в диагностический порт контрольных точек 91h…FFh
Код ошибки | Описание ошибки |
---|---|
91 | Выбор сценария старта платформы CF Определение типа процессора |
C0 | Запрет External Cache. Запрет Internal Cache. Запрет Shadow RAM. Программирование контроллера DMA, контроллера прерываний, таймера, блока RTC C1 Определение типа памяти, суммарного объем и размещение по строкам 0С Проверка контрольных сумм |
C3 | Проверка первых 256К DRAM для организации Temporary Area. Распаковка BIOS в Temporary Area |
C5 | Если контрольные суммы совпали, выполняемый код POST переносится в Shadow. В противном случае управление передается на процедуру восстановления BIOS |
B0 | Инициализация North Bridge |
A0-AF | Аппаратно-зависимая процедура инициализации системной логики E0-EF Ошибка в процессе инициализации системной логики |
Восстановление BIOS
Выполнение POST в Shadow RAM
Поздняя инициализация выполняется в оперативной памяти и продолжается до момента вызова пользовательского меню - CMOS Setup. Для этой фазы POST характерно использование сегмента памяти E000h, в котором отрабатывается прохождение кон- трольных точек от 01h до 7Fh.
Код ошибки | Описание ошибки |
---|---|
01 | Распаковка XGROUP по физическому адресу 1000:0000h |
03 | Ранняя |
05 | Установке начальных значений переменных, задающих атрибуты изображения. Проверка флага состояния CMOS |
07 | Проверка и инициализация контроллера клавиатуры |
08 | Определение типа интерфейса подключенной клавиатуры |
0A | Процедура автоопределения клавиатуры и мыши. Финальные настройки кон- троллера клавиатуры с использованием регистров пространства PCI |
0E | Тестирование сегмента памяти F000h |
10 | Определения типа установленной памяти FlashROM |
12 | Тест CMOS |
14 | Процедура инициализации регистров чипсета |
16 | Первичная инициализация бортового частотного синтезатора |
18 | Определения установленного процессора и объем его Cache L1 и L2 1B Генерация таблицы векторов прерываний |
1C | |
1D | Первичная настройка системы Power Management |
1F | Загрузка из внешнего модуля XGROUP клавиатурной матрицы |
21 | Инициализация подсистемы Hardware Power Management |
23 | Тестирование сопроцессора. Определение типа накопителя FDD. Подготовитель- ный этап для создания карты ресурсов PnP устройств |
24 | Процедура обновления микрокода процессора. Обновление карты распределения ресурсов |
25 | Первичная инициализация и сканирование шины PCI |
26 | Настройка логики, обслуживающей линии VID (Voltage Identification Device). Инициализация бортовой системы мониторинга напряжений и температур |
27 | Повторная инициализация контроллера клавиатуры |
29 | Инициализация APIC, входящего в состав центрального процессора. Измерение частоты, на которой работает процессор. Настройка регистров системной логики. Инициализация контроллера IDE |
2A | |
2B | Поиск VGA BIOS |
2D | Вывод на экран данных о процессоре |
33 | Выполнение Reset для подключенной клавиатуры |
35 | Проверка первого канала контроллера DMA 8237 |
37 | Проверка второго канала контроллера DMA 8237 |
39 | Тестирование страничных регистров DMA |
3C | Настройка контроллера Programmable Interval Timer (8254) |
3E | Инициализация Master контроллера 8259 |
40 | Инициализация Slave контроллера 8259 |
43 | Подготовка контроллера прерываний к работе. Прерывания запрещены, их раз- решение выполняется позже, после теста памяти |
45 | Проверка пассивности запроса немаскируемого прерывания (NMI) |
47 | Выполнение ISA/EISA тестов |
49 | Определение объема базовой и расширенной памяти. Программное управление режимом Writes Allocation путем настройки регистров AMD K5 |
4E | Тестирование памяти в пределах первого мегабайта и визуализация результатов на экране дисплея. Инициализация схем кэширования для одно- и многопроцессорных систем, настройка регистров процессора Cyrix M1 |
50 | Инициализация USB |
52 | Тестирование всей доступной системной памяти, включая регион для встроенно- го видео контроллера (Shared Memory). Визуализация результатов на экране дисплея |
53 | Сброс пароля на вход в систему |
55 | Визуализация количества обнаруженных процессоров |
57 | Начальная инициализация ISA PnP устройств, каждому из которых назначается CSN (Card Select Number). Визуализация логотипа EPA |
59 | Инициализация системы антивирусной поддержки |
5B | Старт процедуры обновления BIOS с накопителя на гибких дисках 5D Инициализация бортовых SIO и Audio контроллеров |
60 | Доступ к CMOS Setup открыт |
63 | Инициализация PS/2 Mouse |
65 | Инициализация USB Mouse |
67 | Использование IRQ12 устройствами PCI, если в системе PS/2 Mouse отсутствует 69 Полная инициализация контроллера кэш L2 |
6B | Инициализация чипсета согласно CMOS Setup |
6D | Настройка ресурсов для устройств ISA PnP в режиме конфигурирования SIO 6F Инициализация подсистемы гибких дисков |
73 | Предварительные действия по инициализации подсистемы жестких дисков. На некоторых платформах - опрос ALT+F2 для запуска AwardFlash |
75 | Поиск и инициализация IDE устройств |
77 | Инициализация последовательных и параллельных портов |
7A | Программный сброс сопроцессора, запись управляющего слова в регистр FPU CW 7C Установка защиты от несанкционированной записи на жесткие диски |
7F | Вывод сообщений об ошибках. Обслуживание клавиш DEL и F1 |
Подготовка таблиц, массивов и структур для старта операционной системы
Начиная с кода 82h, POST осуществляет конфигурирование системы согласно установкам CMOS. Финальная его фаза выполняется из области Shadow RAM (сегмент E800h) и завершается передачей управления операционной системе - код FFh.
Код ошибки | Описание ошибки |
---|---|
82 | Выделяется область в системной памяти для управления питанием |
83 | Восстановление данных из стека временного хранения в CMOS |
84 | Вывод на экран сообщения «Initializing Plug and Play Cards...» |
85 | Инициализация USB завершена |
86 | Зарезервировано, очистка Carry Flag |
87 | Построение таблиц SYSID в области DMI |
88 | Зарезервировано, очистка Carry Flag |
89 | Генерация таблиц обслуживания ACPI |
8A | Зарезервировано, очистка Carry Flag |
8B | Поиск и инициализация BIOS дополнительных устройств |
8C | Зарезервировано, очистка Carry Flag |
8D | Инициализация процедур обслуживания бита четности |
8E | Зарезервировано, очистка Carry Flag |
8F | Разрешение IRQ12 для «горячего» подключения манипулятора «мышь» 90 Зарезервировано, очистка Carry Flag |
91 | Инициализация Legacy-ресурсов платформы |
92 | Зарезервировано, очистка Carry Flag |
93 | Предположительно, не используется |
94 | Заключительные действия по инициализации основного набора логики перед загрузкой операционной системы. Завершается инициализация системы управления питанием. Снимается стартовая заставка BIOS, выводится на экран таблица распределения ресурсов. Для процессоров семейства AMD K6® выполняются специфические настройки. Обновление микрокода для процессоров семейства Intel Pentium® II и выше |
95 | Установка режима автоматического перехода на зимнее/летнее время. Программирование контроллера клавиатуры на частоту автоповтора |
96 | В мультипроцессорных системах выполняются финальные настройки системы и создаются служебные таблицы и поля. Для процессоров семейства Cyrix выполняется дополнительная настройка регистров. Построение таблицы ESCD "Extended System Configuration Data". Установка счетчика DOS Time в соответствии с Real Time Clock. Выполняется сохранение разделов загрузочных устройств для далнейшего использования встроенными антивирусными средствами: Trend AntiVirus или Paragon Anti-Virus Protection. На системный динамик подается сигнал окончания выполнения POST. Строится и сохраняется таблица MSIRQ |
Ряд процессов, происходящих в Award Medallion BIOS, обозначается особыми группами контрольных точек. К ним относятся:
System Event codes - контрольные точки системных событий.
Power Management Debug codes - контрольные точки, возникающие в процессе выполнения сервисов APM или ACPI.
System Error codes - сообщения о фатальных ошибках.
Debug codes for MP system - точки инициализации многопроцессорных платформ.
Особенности ускоренного прохождения POST
Для сокращения времени загрузки системы пользователь в CMOS Setup может выбрать опцию "Quick Power On Self Test". В этом случае прохождение POST будет ускорено за счет отказа от выполнения некоторых процедур (Quick Boot).
Схема работы Quick Boot замещает позднюю и финальную фазы POST и не отражается на работе загрузочного блока. Award Software предлагает кодификацию испол- няемых процедур ускоренного прохождения POST, отличную от стандартной. Quick Boot начинается с вывода в диагностический порт контрольной точки 65h и заканчивается POST кодом 80h. Затем управление передается операционной системе с отображением обычного для Award BIOS кодом FFh.
Код ошибки | Описание ошибки |
---|---|
65 | Ранняя инициализация SIO контроллера, программный сброс видео контроллера. Настройка контроллера клавиатуры, тест клавиатуры и манипулятора "мышь". Инициализация звукового контроллера. Проверка целостности структур BIOS. Распаковка процедур обслуживания Flash ROM. Инициализация бортового синтезатора частот |
66 | Инициализация кэш-памяти L1/L2 согласно результатам, полученным по команде CPUID. Генерация таблицы векторов, состоящей из указателей на процедуры обработки прерываний. Инициализация аппаратных средств Power Managment |
67 | Проверка достоверности CMOS и батарейного питания. Настройка регистров чипсета согласно установкам CMOS. Инициализация контроллера клавиатуры в составе чипсета. Формирование переменных BIOS Data Area |
68 | Инициализация видео системы |
69 | Настройка i8259 контроллера прерываний |
6A | По специальному алгоритму выполняется ускоренный однопроходный тест оперативной памяти |
6B | Визуализация количества обнаруженных процессоров, логотипа EPA и вывод приглашения для запуска утилиты AwardFlash. Настройка ресурсов встроенного контроллера ввода-вывода в режиме конфигурирования |
70 | Приглашения для входа в Setup. Инициализация PS/2 и USB Mouse |
71 | Инициализация кэш-контроллера |
72 | Настройка конфигурационных регистров системной логики. Формирование списка Plug and Play устройств. Инициализация FDD контроллера |
73 | Инициализация контроллера HDD |
74 | Инициализация сопроцессора |
75 | Если пользователем предписано в установках CMOS Setup, выполняется защитаот записи IDE HDD |
77 | Запрос пароля и вывод сообщения: «Press F1 to continue, DEL to enter Setup» |
78 | Инициализация BIOS дополнительных устройств на шинах ISA и PCI |
79 | Инициализация Legacy ресурсов платформы |
7A | Генерация корневой таблицы RSDT и таблиц устройств DSDT, FADT и т.п. |
7D | Поиск информации о разделах загрузочных устройств |
7E | Настройка служб и сервисов BIOS перед загрузкой операционной системы |
7F | Установка флага NumLock согласно CMOS SetUp |
80 | Передача управления операционной системе |
Выполнение POST в режиме энергосбережения
Одно из состояний платформы, когда содержимое оперативной памяти сохраняется на жестком диске, называется Hibernate. В спецификации ACPI ("Advanced Configuration and Power Interface Specification", Revision 2.0a от 31/03/2002) оно определяется как режим энергосбережения S4 (Non-Volatile Sleep). Возврат к полноценному функционированию предполагает особый способ прохождения POST.
Схема работы ACPI S4, как и при ускоренном старте, замещает позднюю и финальную фазы POST. Существенным моментом становится проверка в загрузочном блоке сценария старта. В зависимости от того, в каком ACPI состоянии находится система после аппаратного сигнала Reset, принимается решение о выходе из состояния S4, который начинается с вывода в диагностический порт контрольной точки 90h и заканчивается POST кодом 9Fh.
Код ошибки | Описание ошибки |
---|---|
90 | Ранняя инициализация SIO контроллера, программный сброс видео контроллера. Настройка контроллера клавиатуры, тест клавиатуры и манипулятора "мышь" |
91 | Проверка достоверности CMOS и батарейного питания |
92 | Инициализация регистров системной логики и бортового синтезатора частот |
93 | Инициализация кэш-памяти по информации CPUID |
94 | Генерация таблицы векторов, состоящей из указателей на процедуры обработки прерываний. Инициализация аппаратных средств Power Managment |
95 | Сканирование PCI шины |
96 | Инициализация встроенного контроллера клавиатуры |
97 | Инициализация видео системы |
98 | Вывод сообщений VGA адаптера |
99 | Проверка первого канала контроллера DMA8237 путем записи и контрольного считывания регистров базового адреса и длины блока пересылки 9A Настройка i8259 контроллера прерываний |
9B | Инициализация PS/2 и USB Mouse. Распаковка ACPI кода. Инициализация кэшконтроллера |
9C | Настройка конфигурационных регистров системной логики. Формирование списка Plug and Play устройств. Инициализация FDD и HDD контроллеров |
9D | Резервирование PM-региона в системной памяти не выполняется, если таковой создан в Shadow RAM или SMRAM. В некоторых случаях требуется повторная, завершающая инициализация USB шины, выполняемая при отключенной кэш- памяти L1 |
9E | Настройка Power Management, входящей в состав системной логики. Инициализация схем генерации SMI и установка вектора SMI. Программирование ресурсов, отвечающих за мониторинг системных событий PM |
9F | С помощью операции запрещения и разрешения очищается кэш-память L1/L2 и восстанавливается ее актуальный размер. Настройки управления режимом энергосбережения, заданные в CMOS Setup, сохраняются в PM RAM. Для мобильных платформ выполняется проверка возврата к полноценному функционированию после отключения всех питающих напряжений (режим Zero Volt Suspend) |
4. Phoenix BIOS 4.0 Release 6.0
Phoenix Technologies, Ltd.
Один из лидеров разработки низкоуровневого программного обеспечения Phoe- nix Technologies приурочил к выходу Windows95 новую версию PhoenixBIOS 4.0. Поддержка семейства процессоров Intel Pentium отражается в названии промежуточных ревизий. Одна из последних - Release 6.0 - легла в основу всех выпускаемых BIOS. С появлением Release 6.1 существенных изменений в выполнении процедур POST не про- изошло, и, следовательно, это не отразилось на индикации контрольных точек.
Отличительная особенность PhoenixBIOS состоит в том, что если в процессе выполнения POST возникают ошибки тестирования 512 Кбайт основной памяти (коды 2Ch, 2Eh, 30h), в порт 80h выводится дополнительная информация в формате слова, биты которого идентифицируют сбойную адресную линию или ячейку данных. Например, код "2C 0002" означает, что обнаружен сбой памяти по адресной линии 1. Код "2E 1020" в этом случае будет означать, что обнаружен сбой по линиям данных 12 и 5 в младшем байте шины данных памяти. В системах 386SX, где используется шестнадцати битная шина данных, возникновение ошибки на этапе выполнения кода 30h невозможно
Вывод в диагностический порт POST кода сопровождается выводом на системный динамик звукового сигнала. Схема формирования звукового сигнала следующая:
- Восьми битный код преобразуется в четыре двух битные группы
- Значение каждой группы увеличивается на единицу
- По полученному значению генерируется короткий звуковой сигнал (например: код 16h = 00 01 01 10 = 1-2-2-3)
Выполнение стартовых процедур POST из ROM
Код ошибки | Описание ошибки |
---|---|
01 | Инициализация контроллера Baseboard Management (BMC) |
02 | Проверка текущего режим работы процессора |
03 | Запрет выполнения немаскируемых прерываний |
04 | Определяется тип установленного процессора |
06 | Начальные установки регистров PIC и DMA |
07 | Область в памяти, предназначенная для копии BIOS, обнуляется |
08 | Ранняя инициализация регистров системной логики |
09 | Установка программного флага выполнения POST |
0A | Инициализация программных ресурсов процессора |
0B | Разрешение Internal Cache |
0E | Инициализация ресурсов Super I/O |
0C | Инициализация кэш L1/L2 согласно значениям CMOS |
0F | Инициализация IDE |
10 | Инициализация подсистемы Power Management |
11 | Установка значений альтернативных регистров |
12 | Выполняется установка значения регистра MSW (Machine Status Word) |
13 | Ранняя инициализация PCI устройств |
14 | Инициализация контроллера клавиатуры |
16 | Проверка контрольной суммы ROM BIOS |
17 | Определение объема кэш L1/L2 |
18 | Инициализация системного таймера 8254 |
1A | Инициализация контроллера DMA |
1C | Сброс значений программируемого контроллера прерываний |
20 | Проверка формирования запросов регенерации DRAM |
22 | Проверка работы контроллера клавиатуры |
24 | Установка селектора для обслуживания плоской 4Gb модели памяти |
26 | Разрешение линии А20 |
28 | Определение суммарного объема установленной памяти |
29 | Инициализация POST Memory Manager (PMM) |
2A | Обнуление 640Kb основной памяти |
2C | Тестирование адресных линий |
2E | Сбой по одной из линий данных в младшем байте шины данных памяти |
2F | Выбор протокола работы кэш памяти |
30 | Тест доступной системной памяти |
32 | Определение тактовых параметров CPU и частоты шины |
Код ошибки | Описание ошибки |
---|---|
33 | Инициализация Phoenix Dispatch Manager |
34 | Запрет на выключение питания с помощью ATX Power Button |
35 | Настройки регистров системной логики, управляющих формированием временных характеристик доступа к памяти, портам ввода/вывода, системным и локальным шинам |
36 | Выполняется рестарт при неудачном переходе к следующей процедуре POST. Последовательностью процедур управляет Watch Dog Service |
37 | Завершается процесс настройки регистров системной логики |
38 | Содержимое Runtime модуля BIOS распаковывается и переписывается в область, предназначенную для Shadow RAM |
39 | Повторная инициализация контроллера кэш-памяти |
3A | Повторное определение размера кэш L2 |
3B | Инициализация трассировки выполнения BIOS |
3C | Дополнительная настройка регистров логики для конфигурирования мостов PCI-PCI и поддержки распределенных PCI шин |
3D | Выполняется настройка регистров системной логики в соответствии с установками CMOS Setup |
3E | Read Hardware Configuration |
3E | Проверка подключения системы ROM Pilot |
40 | Определение тактовых параметров CPU |
41 | Инициализация ROM Pilot - управления удаленной загрузкой |
42 | |
44 | Set BIOS Interrupt |
45 | Инициализация устройств до включения PnP механизма |
46 | По специальному алгоритму вычисляется контрольная сумма BIOS |
47 | Инициализация I2O контроллеров ввода/вывода |
48 | Поиск видеоадаптера |
49 | Инициализация PCI |
4A | Инициализация системных видеоадаптеров |
4B | Выполняется Quiet Boot - сокращенная последовательность старта системы, используемая для ускоренного прохождения POST |
4C | Содержимое VGA BIOS переписывается в транзитную область |
4E | Визуализация текстовой строки BIOS Copyright |
4F | Резервирование памяти для меню выбора загрузочных устройств |
50 | Визуализируется тип процессора и его тактовая частота |
51 | Инициализация контроллера и устройств EISA |
52 | Программирование контроллера клавиатуры |
54 | Активизирован режим звукового сопровождения клавиш |
55 | |
58 | Поиск необслуживаемых запросов на прерывания |
59 | Инициализация процедуры POST Display Service (PDS) 5A Вывод сообщения "Press F2 to enter SETUP" |
5B | Запрет CPU Internal Cache |
5C | Проверка Conventional Memory |
5E | Detect Base Address |
60 | Проверка Extended Memory |
62 | Проверка адресных линий Extended Memory |
64 | Передача управления на выполняемый блок, генерируемый производителем системной платы (Patch1) |
66 | Настройка регистров управления кэшированием |
67 | Минимальная инициализация контроллеров APIC |
68 | Разрешение кэш L1/L2 |
69 | Подготовка System Management Mode RAM |
6A | Визуализируется объем External Cache |
6B | Установка значений CMOS Setup по умолчанию |
6C | Визуализация информации об использовании Shadow RAM |
6E | Визуализация информации об Upper Memory Blocks (UMB) |
70 | Вывод сообщений об ошибках |
72 | Проверка текущей конфигурации системы и информации в CMOS |
76 | Проверка информации об ошибках клавиатуры |
7A | Проверка состояния средств программной (System Password) или аппаратной (Key Lock Switch) блокировки клавиатуры |
7C | Установка векторов аппаратных прерываний |
7D | Инициализации системы слежения за питанием |
7E | Инициализация сопроцессора |
80 | Запрещается бортовой контроллер ввода/вывода SIO |
81 | Выполняется подготовка к загрузке операционной системы |
82 | Поиск и определение портов RS232 |
83 | Конфигурирование внешних IDE контроллеров |
84 | Поиск и определение параллельных портов |
85 | Инициализация устройств ISA PnP |
86 | Бортовые ресурсы контроллера SIO конфигурируются в соответствии с установками CMOS Setup |
87 | Конфигурирование MCD (Motherboard Configurable Devices) |
88 | Устанавливаются значения блока переменных в области BIOS Data Area |
89 | Разрешается формирование немаскируемого прерывания |
8A | Установка значений переменных, находящихся в области Extended BIOS Data Area |
8B | Проверка схем подключения PS/2 Mouse |
8C | Инициализация контроллера дисковода |
8F | Определение количества подключенных ATA устройств |
90 | Инициализация и конфигурирование контроллеров жестких дисков |
91 | Установка временных параметров работы жестких дисков в режиме PIO |
92 | Передача управления на выполняемый блок, генерируемый производителем системной платы (Patch2) |
93 | Построение таблицы конфигурации мультипроцессорной системы |
95 | Выбор процедуры обслуживания CD-ROM |
96 | Возврат в Real Mode |
97 | Построение MP Configuration Table |
98 | Выполняется процедура ROM Scan |
99 | Проверка состояния параметра SMART 9A Содержимое ROM переписывается в RAM |
9C | Настройка подсистемы Power Management |
9D | Инициализация ресурсов для защиты от несанкционированного доступа |
9E | Разрешаются аппаратные прерывания |
9F | Определяется количество накопителей IDE и SCSI |
A0 | Установка DOS Time по состоянию RTC A1 Назначение данного кода неизвестно A2 Проверка состояния Key Lock |
A4 | Установки характеристик автоповтора клавиатуры |
A8 | Сообщение "Press F2 to enter Setup" удаляется с экрана |
AA | Проверяется наличие SCAN кода клавиши F2 во входном буфере AC Запускается программа Setup |
AE | Очищается флаг перезапуска, выполняемого по CTRL+ALT+DEL B0 Генерируется сообщение "Press F1 to resume, F2 to Setup" |
B1 | Снимается флаг выполнения POST B2 Процедура POST завершена |
B4 | Выдача звукового сигнала перед загрузкой |
B5 | Фаза Quiet Boot завершена |
B6 | Проверка пароля, если данный режим включен в Setup B7 Инициализация ACPI BIOS |
B9 | Поиск загрузочных устройств на USB шине BA Инициализация параметров DMI |
BB | Повторное выполнение процедуры ROM Scan |
BC | Обнуляется триггер фиксации ошибки четности RAM |
BD | Визуализируется меню для выбора загрузочного устройства BE Очистка экрана перед загрузкой операционной системы BF Активизация антивирусной поддержки |
C0 | Запускается процедура обработки программного прерывания INT 19h - загрузчик Boot Sector. Процедура обработки прерывания последовательно пытается загрузить Boot Sector, опрашивая дисковые устройства в порядке, предписанном Setup |
C1 | Начальная инициализация процедуры обслуживания сбоев (PEM) C2 Вызов служебных процедур для ведения протокола ошибок |
C3 | Визуализация сообщений об ошибках в порядке их поступления С4 Установка флагов начальных состояний |
C5 | Инициализация расширенного блока ячеек CMOS RAM |
C6 | Первичная инициализация док-станции |
C7 | Отложенная инициализация док-станции |
С8 | Выполнение находящихся в составе Boot Block тестовых процедур определения целостности структур BIOS |
С9 | Проверка целостности внешних по отношению к системному BIOS структур и/или модулей |
CA | Запуск Console Redirect для обслуживания удаленной клавиатуры CB Эмуляция дисковых устройств в RAM/ROM |
CC | Запуск Console Redirect для обслуживания видео CD Поддержка обмена данными с PCMCIA |
CE | Настройка контроллера светового пера |
Сообщения о фатальных ошибках
D0 Ошибка, вызванная исключительной ситуацией (Exception error) D2 Вызов процедуры обработки прерывания от не идентифицированного источника D4 Ошибка, связанная с нарушением протокола выдачи и снятия запросов на пре- рывание D6 Выход из защищенного режима с программным формированием сброса D7 Для сохранения состояния видеоадаптера требуется больший объем памяти, чем доступно в SMRAM D8 Ошибка при программном формировании импульса сброса процессора DA Потеря управления при возврате в Real Mode DC Выход из защищенного режима с программным формированием сброса без по- вторной инициализации контроллера прерываний DD Ошибка при тестировании расширенной памяти DE Ошибка контроллера клавиатуры DF Ошибка управления линией A20 19
Выполнение процедур из Boot Block
Код ошибки | Описание ошибки |
---|---|
E0 | Настройка конфигурационных регистров чипсета E1 Инициализация Северного и Южного мостов |
E2 | Инициализация CPU |
E3 | Инициализация системного таймера |
E4 | Инициализация ресурсов Super I/O |
E5 | Проверка состояния Recovery Jumper, установка которого принудительно запускает режим BIOS Recovery |
E6 | Проверка контрольной суммы BIOS |
E7 | Управление передается BIOS, если его контрольная сумма вычислена правильно E8 Инициализация поддержки MPS |
E9 | Переход к плоской 4Gb модели памяти |
EA | Инициализация нестандартного оборудования |
EB | Настройка контроллера прерываний и прямого доступа к памяти |
EC | Путем записей и контрольных считываний по специальному алгоритму определя-ется тип памяти: FPM, EDO, SDRAM, в соответствии с результатом настраиваются конфигурационные регистры Host Bridge |
ED | Путем записей и контрольных считываний по специальному алгоритму определя-ется объем банков памяти и размещение по строкам. В соответствии с результа том настраиваются конфигурационные регистры Host Bridge (DRAM Row Boundary) |
EE | Содержимое Boot Block копируется в Shadow RAM EF Подготовка SMM RAM для обработчика SMI |
F0 | Тест памяти |
F1 | Инициализация векторов прерываний |
F2 | Инициализация Real Time Clock |
F3 | Инициализация видео подсистемы |
F4 | Генерация звукового сигнала перед загрузкой |
F5 | Загрузка операционной системы, хранящейся во Flash ROM |
F6 | Возврат в Real Mode |
F7 | Boot to Full DOS |
F8 | Инициализация контроллера USB |
FA…FF | Коды взаимодействия с процедурой PhDebug |
5. Insyde BIOS Mobile Pro
Insyde Software Corp.
Инсайдер рынка мобильных систем прочно обосновался там, где требуется верность традициям и консервативный подход к построению BIOS. Получив в наследство исходный код от SystemSoft, компания постоянно работает над его совершенствованием. Последняя из ревизий MobilePRO активно используется в ноутбуках Mitac и Clevo, документация к которым и легла в основу таблицы Error Codes - так в Insyde Software называют контрольные точки выполнения POST.
Контрольные точки загрузочного блока
Несмотря на то, что свой первый BIOS компания Insyde Software создала в 1992 году, устоявшая модель загрузочного блока, - или Boot Loader, как его назвали сами создатели, - окончательно сформировалась только к концу 1995 года. С этого момента стартовая процедура получила нумерацию по версии и дате создания.
Наиболее существенным моментом с точки зрения сервисного инженера, иссле- дующего процесс загрузки компьютерной системы с InsydeBIOS, становится устройство отображения диагностических кодов. Хотя, как правило, Boot Loader использует стандартный в таких случаях Manufacture"s Diagnostic Port 80h, в некоторых случаях вывод контрольных точек выполняется только на PIO Port (Parallel Input/Output port for diagnostic purpose), который представляет собой не что иное, как параллельный порт 378h. Существуют реализации, в которых диагностические коды, посылаемые в порт 80h, дублируются и в параллельный порт.
Код ошибки | Описание ошибки |
---|---|
00 | Стартовая точка выполнения загрузочного блока 01 Запрет линии А20 (не используется) |
02 | Обновление микрокода центрального процессора |
03 | Тестирование оперативной памяти |
04 | Перенос загрузочного блока в оперативную память |
05 | Выполнение загрузочного блока из оперативной памяти |
06 | Форсирование процедуры восстановления Flash ROM |
07 | Перенос системного BIOS в оперативную память |
08 | Верификация контрольной суммы системного BIOS |
09 | Запуск процедуры POST |
0A | Запуск процедуры восстановления Flash ROM с накопителя FDD |
0B | Инициализация синтезатора частот |
0C | Завершение процедуры восстановления BIOS |
0D | Альтернативная процедура восстановления Flash ROM с FDD |
0F | Останов в случае возникновения фатальной ошибки |
BB | Ранняя инициализация LPC SIO |
CC | Стартовая точка начала восстановления Flash ROM |
88 | Разрешение функций ACPI |
99 | Ошибка при выходе из режима STR |
60 | Переход в режим Big Real Mode |
61 | Инициализация SM Bus. Данные SPD сохраняются в CMOS A0 Чтение и анализ полей SPD, ранее сохраненных в CMOS A1 Инициализация контроллера памяти |
A2 | Определение логических банков модуля DIMM |
A3 | Программирование регистров DRB (DRAM Row Boundary) |
A4 | Программирование регистров DRA (DRAM Row Attributes) |
AE | В системе обнаружены модули DIMM, которые разнятся между собой функциями Error Correcting Codes (ECC) |
AF | Первичная инициализация регистров контроллера памяти, отображаемых в пространстве памяти |
E1 | Выполнение загрузочной процедуры прекращается, если модуль DIMM не оснащен микросхемой SPD |
E2 | Тип модуля DIMM не соответствует требованиям системы |
EA | Минимальное время между активацией строк DIMM модуля и переходом в состояние регенерации не соответствует системным требованиям |
EC | Регистровые модули не поддерживаются ED Проверка режимов CAS Latency |
EE | Организация модуля DIMM не поддерживается системной платой |
Выполнение процедур POST из RAM
Самые современные решения InsydeBIOS используют 16-битное отображение контрольных точек. Для этого используются порты 80h и 81h, последний из которых предназначен для расширения стандартной диагностики.
Изучение контрольных точек затрудняется их нерегулярным построением, когда различные по смыслу процессы сопровождаются одними и теми же кодами. В дуальных диагностических системах существуют разнородности другого порядка: некоторые POST коды отображаются только в один из портов без привычного в таких случаях дублирования.
Код ошибки | Описание ошибки |
---|---|
10 | Инициализация кэш-памяти, проверка CMOS |
11 | Запрет линии А20. Установка регистров контроллеров 8259. |
12 | Определение способа загрузки |
13 | Инициализация контроллера памяти |
14 | Поиск подключенного к шине ISA видео адаптера |
15 | Установка значений системного таймера |
16 | Установка регистров системной логики по CMOS |
17 | Подсчет общего объема оперативной памяти |
18 | Тестирование младшей страницы Conventional Memory |
19 | Проверка контрольной суммыы образа Flash ROM |
1A | Повторная установка регистров контроллера прерываний |
1B | Инициализация видео адаптера |
1C | Инициализация подмножества регистров видео адаптера, совместимых с программной моделью 6845 |
1D | Инициализация EGA адаптера |
1E | Инициализация CGA адапетра |
1F | Тест страничных регистров DMA контроллера |
20 | Проверка контроллера клавиатуры |
21 | Инициализация контроллера клавиатуры |
22 | Сравнение полученного объема оперативной памяти со значением в CMOS |
23 | Проверка автономного батарейного питания и Extended CMOS |
24 | Тестирование регистров контроллера DMA |
25 | Установка параметров DMA контроллера |
26 | Формирование таблицы векторов прерываний |
27 | Ускоренное определение объема установленной памяти |
28 | Защищенный режим |
29 | Тест системной памяти выполнен |
2A | Выход из защищенного режима |
2B | Перенос процедуры Setup в оперативную память |
2C | Запуск процедуры инициализации видео |
2D | Повторный поиск CGA адаптера |
2E | Повторный поиск EGA/VGA адаптера |
2F | Вывод на экран сообщений VGA BIOS |
30 | Пользовательская процедура инициализации контроллера клавиатуры |
31 | Проверка подключенной клавиатуры |
32 | Проверка прохождения запроса от клавиатуры |
33 | Проверка регистра статуса клавиатуры |
34 | Тест и обнуление системной памяти |
35 | Защищенный режим |
36 | Расширенный тест памяти завершен |
37 | Выход из защищенного режима |
38 | Запрет линии А20 |
39 | Инициализация кэш-контроллера 3A Проверка системного таймера |
3B | Установка счетчика DOS Time в соответствии с Real Time Clock |
3C | Инициализация таблицы аппаратных прерываний |
3D | Поиск и инициализация манипуляторов и указателей |
3E | Установка статуса клавиши NumLock |
3F | Инициализация последовательных и параллельных портов |
40 | Конфигурирование последовательных и параллельных портов |
41 | Инициализация FDD контроллера |
42 | Инициализация HDD контроллера |
43 | Инициализация Power Management для шины USB |
44 | Поиск и инициализация дополнительных BIOS |
45 | Повторная установка статуса клавиши NumLock |
46 | Проверка функциональности сопроцессора |
47 | Инициализация PCMCIA |
48 | Подготовка к старту операционной системы |
49 | Передача управления исполняемому Bootstrap коду |
50 | Инициализация ACPI |
51 | Инициализация Power Management |
52 | Инициализация контроллера шины USB |
POST-карта или POST-тестер это PCI плата расширения, имеющая цифровой индикатор, который выводит коды инициализации мат.платы. По данному коду можно найти, в каком из компонентов платы имеется неисправность. Коды часто зависят от производителя BIOS. Если ошибки отсутствуют и тест проходит успешно, то POST выдаёт код не меняющийся значение, к примеру на большинстве мат.плат по
завершении инициализации выводится код «FF». Также часто на тестерах установлены светодиоды отображающие напряжения +5 +3,3 +12, −12.
Вашему вниманию коды ошибок, подходящие на самые версии BIOS:
POST-код | Описание |
---|---|
D0 | Предварительная инициализация чипсета материнской платы и процессора. Проверка контрольной суммы BIOS. Запрет немаскируемого прерывания NMI. Выполняется проверка контроллера Super I/O, проверка CMOS. |
D1 | Контроллером клавиатуры выполняется процесс само-тестирования (BAT-тест). Выполняется начальная инициализация портов ввода-вывода. Инициализация контроллера DMA. |
D2 | Запрещение использования кэш-памяти. Выполняется процедура определения объема установленной оперативной памяти. |
D3 | Проверяется формирование запросов на регенерацию динамической оперативной памяти. Разрешение использования кэш-памяти. |
D4 | Тестирование 512 Кбайт памяти. Выполняется установка адреса стека, настраивается кэш-память. |
D5 | Код системной БИОС распаковывается и перезаписывается в Shadow RAM (затененную память). |
D6 | Производится вычисление контрольной суммы БИОС и проверка нажатия комбинации клавиш Ctrl+Home. Если хотя бы одно из этих условий выполняется, запускается процедура восстановления BIOS. |
D7 | В случае успешной проверки контрольных сумм BIOS управление передается модулю InterfaceModule, который выполняет распаковку исполняемого кода в Run-Time области. |
D8 | Выполняется распаковка Run-Time-кода из флеш-памяти в ОЗУ. Информация CPUID сохраняется в ОЗУ. |
D9 | Распакованный Run-Time-код переносится из области временного хранения в оперативную память. Управление передается распакованному модулю. |
DA | Выполняется восстановление регистров CPUID. Выполняется процедура POST. |
E0 | Инициализация регистров контроллера флоппи-дисковода. Выполняется инициализация контроллера прерываний и установка векторов прерываний. Включение кэш-памяти первого уровня. |
E9 | Настройка регистров флоппи-дисковода. |
EA | Выполняется проверка операции чтения с ATAPI CD-ROM и дисковой памяти. |
EB | Возврат на контрольную точку E9 в случае возникновения ошибок при операциях с ATAPI CD-ROM. |
EF | Возврат на контрольную точку EB в случае возникновения ошибок при операциях с дисками. |
F0 | Выполняется поиск файла восстановления с именем AMIBOOT.ROM. |
F1 | В точку F1 выполняется переход в том случае, если файл восстановления не найден. |
F5 | Отключение кэш-памяти первого уровня. |
FB | Определение типа FlashROM. Поиск во FlashROM раздела для хранения настроек чипсета. |
F4 | В точку F4 выполняется переход в том случае, если файла восстановления с именем AMIBOOT.ROM имеет некорректный размер. |
FC | Обнуление основного блока Flash BIOS. |
FD | Выполняется программирование основного блока Flash BIOS. |
FF | В точку FF выполняется переход в том случае, если программирование Flash BIOS успешно завершено. Запрещается запись у FlashROM. Выполняется отключение оборудования ATAPI. Восстанавливается значение CPUID. |
03 | Запрещается обработка немаскируемого прерывания (NMI), проверка ошибок четности оперативной памяти. Выполняется инициализация области данных текущего выполнения BIOS и процедуры POST. |
04 | Проверка контрольной суммы CMOS и напряжения питания аккумулятора. |
05 | Выполняется инициализация контроллера прерываний и формирование таблицы векторов прерываний. |
06 | Подготовка к работе интервального таймера. |
08 | Контроллером клавиатуры выполняется процесс само-тестирования (BAT-тест). Инициализация ЦП. |
C0 | Запрещение использования кэш-памяти. Инициализация контроллера APIC. Подготовка процессора к работе. |
С1 | Настройка параметров работы процессора. |
C2 | Идентификация процессора с помощью команды CPUID. |
C5 | Определение количества процессоров и настройка их параметров. |
C6 | Инициализация кэш-памяти процессора. |
С7 | Завершение процесса начальной инициализации центрального процессора. |
0A | Инициализация контроллера клавиатуры. |
0B | Выполняется поиск мыши, подключенной с помощью интерфейса PS/2. |
0C | Выполняется поиск клавиатуры. |
0E | Поиск и инициализация устройств ввода-вывода. Захват прерывания INT 09h. Вывод на экран логотипа БИОС. |
13 | Выполняется начальная инициализация регистров чипсета. |
24 | Выполняется распаковка и инициализация модулей BIOS. Подготовка к инициализации таблицы векторов прерываний. |
25 | Завершение инициализации таблицы векторов прерываний. |
2A | Выполняется инициализация устройств на локальных шинах (с помощью механизма DIM-Device Initialization Manager). Подготовка к инициализации видеоадаптера. |
2С | Поиск и инициализация видеокарты. |
2E | Выполняется поиск и инициализация дополнительных устройств ввода-вывода. |
30 | Выполняется инициализация компонента SMI (System Management Interrupt). |
31 | Распаковка модуля ADM. Инициализация и активизация ADM. |
33 | Инициализация модуля загрузчика. |
37 | Вывод на экран монитора логотип AMI, информация о версии БИОС, информации о типе процессора и его скорости. Отображение на мониторе названия клавиши, которую можно использовать для входа в Bios Setup. |
38 | Выполняется инициализация устройств на локальных шинах (с помощью механизма DIM-Device Initialization Manager). |
39 | Выполняется инициализация контроллера DMA. |
3A | Установка системного времени в соответствии с показаниями часов реального времени (RTC). |
3B | Выполняется тестирование оперативной памяти с последующим отображением на мониторе результатов теста. |
3C | Настройка регистров чипсета. |
40 | Выполняется инициализация математического сопроцессора, параллельных и последовательных портов. |
50 | Выполняется корректировка модулей управления памяти. |
52 | Выполняется корректировка информации в CMOS об объеме оперативной памяти (согласно результатам теста оперативной памяти). |
60 | Программирование контроллера клавиатуры на частоту авто-повтора и время ожидания до входа в режим авто-повтора согласно настройкам BIOS Setup. Установка состояния индикатора Numlock согласно настройкам BIOS Setup. |
75 | Выполняется инициализация прерывания INT 13h, которое используется для работы с дисковыми устройствами. |
78 | Создается список устройств, с которых можно выполнить загрузку ОС. |
7A | Выполняется инициализация остальных расширений БИОС. |
7C | Создание и сохранение таблицы ESCD. |
84 | Выполняется составление отчета об ошибках, которые были обнаружены во время прохождения процедуры POST. |
85 | Вывод на монитор информации об ошибках, обнаруженных во время прохождения процедуры POST. |
87 | На данном этапе имеется возможность войти в программу BIOS Setup. |
8C | Настройка регистров чипсета. |
8D | Выполняется построение таблицы ACPI. |
8E | Обслуживание NMI-прерываний. Настройка параметров периферийных устройств. |
90 | Выполняется завершающая инициализация SMI |
A0 | Запрос пароля на загрузку (если в настройках BIOS Setup это предусмотрено). |
A1 | Выполняется очистка данных, которые не требуются для загрузки ОС. |
A2 | Подготовка модулей EFI. |
A4 | Выполняется инициализация языкового модуля. |
A7 | Вывод на монитор таблицы итоговых результатов прохождения процедуры POST. |
A8 | Программирование регистров MTRR (Memory Type Range Register). |
A9 | Ожидание ввода команд с клавиатуры. |
AA | Сброс прерываний INT 1C, INT 09. Отключение модуля обслуживания процедур (ADM). |
AB | Определение устройств, с которых можно выполнить загрузку ОС. |
AC | Завершающий этап инициализации регистров чипсета в соответствии с параметрами BIOS Setup |
B1 | Выполняется настройка интерфейса ACPI. |
00 | Выполнение прерывания BIOS INT 19h. Управление процессом загрузки передается загрузчику операционной системы. Начинается загрузка ОС. |
Расшифровка кодов POST-карты для "Award BIOS 4.5 "
Award BIOS Version 4.51PG
C0
программирование регистров микросхемы Host Bridge для установки следующих режимов: External Cache запрещен. Запрещено копирование в ячейки External Cache информации, читаемой процессором (все шинные циклы Non Cacheable), а также запрещен просмотр TAGRAM на предмет кэш-попаданий (Force Cache Miss). Internal Cache запрещен. Запрещено формирование сигнала KEN# микросхемой Host Bridge, это запрещает процессору кэшировать читаемые данные. Перед запретом Internal Cache очищается программно либо аппаратно. Shadow RAM запрещено. Это приводит к направлению циклов обращения к адресам расположения System BIOS и Additional BIOS непосредственно на соответствующие ROM , а не Shadow RAM. Данная процедура пишется под конкретный Chipset. Выполняется программирование PIIX ресурсов: Контроллера DMA, контроллера прерываний, таймера, блока RTC. Контроллер DMA переводится в пассивный режим, так как конкретная инициализация каналов (установка базовых адресов, длин блоков, режимов передачи) задача не POST, а программ поддержки периферийных устройств, выполняемых уже по ходу рабочего сеанса. Контроллер прерываний настраивается следующим образом.
Master Controller (IRQ0-IRQ7)
:
режим векторных прерываний, прием запроса по фронту IRQ в соответствии IRQ0=INT8...IRQ7=INT0Fh.
Slave Controller (IRQ8-IRQ15)
:
режим векторных прерываний, прием запроса по фронту IRQ в соответствии IRQ8=INT70h...IRQ15=INT77h.
На этом этапе происходит только подготовка контроллера прерываний к работе, сами прерывания запрещены, и разрешаются существенно позже, предположительно, после теста памяти 31 Таймер настраивается следующим образом.
Counter 0
: генерация запросов IRQ0 для подсчета DOS Time, устанавливается режим деления частоты на 65536, в результате частота IRQ0 равна 18.2 Hz.
Counter 1
: генерация запросов DRAM Refresh, устанавливается режим деления частоты на 20, в результате интервал между регенерацией двух строк DRAM около 15 мкС, т.е. 128 циклов выполняется за 2 мС.
Counter 2
: Используется для звука. На данном этапе просто переводится в пассивное состояние, установка параметров этого счетчика происходит при выдаче сигнала на системный динамик.
Подсистема Real Time Clock нуждается в инициализации только в случае, если произошел сбой батарейного питания. Иначе полная инициализация CMOS не выполняется, потому что это приводило бы к сбросу часов при каждом включении. Если сбоя VCC(BAT) не было, инициализируются только регистры, отвечающие за взаимодействие RTC и процессора, но не сами часы
С1
Путем последовательных записей и контрольных считываний определяется тип памяти, суммарный объем и размещение по строкам. Результатом этого шага является настройка следующих параметров DRAM контроллера:
тип памяти (SDRAM, EDO, FPM);
картирующая информация (в зависимости от расположения по Socket);
значение параметра Memory.
Если адрес, сформированный процессором, превышает Memory , данный цикл направляется на PCI. Более точная настройка временнЫх параметров DRAM выполняется позже, в соответствии с содержимым Setup RAM либо SPD
C3
Проверка первых 256К DRAM для организации Temporary Area. Распаковка System BIOS в DRAM, копирование Option ROMs в DRAM. Этот этап выполняется для подготовки к операции Shadow. Необходимость в Temporary Area связана с тем, что Shadow блоки ОЗУ, закрепленные за соответствующими ПЗУ, включаются на те же диапазоны адресов, что и сами ПЗУ, из-за этого нельзя выполнить пересылку (распаковку) за один прием, потому что читать надо ROM, а записывать в Shadow RAM. Поэтому вначале на соответствующий диапазон картируется ROM и выполняется пересылка (распаковка) в транзитный буфер Temporary Area, затем перепрограммируется Host Bridge так, чтобы на область адресов BIOS картировать Shadow RAM и из транзитного буфера код переносится в Shadow RAM. На этапе C3 тестируются первые 256 Кбайт DRAM, которые в дальнейшем будут использованы как транзитный буфер.
Выполняется проверка контрольных сумм и наличие метки BBSS. Если метка не обнаружена или контрольные суммы не совпадают, принимается решение о частичном повреждении микропрограмм BIOS. Управление передается на подпрограмму восстановления FlashROM, расположенную в BootBlock. (BootBlock POST Codes)
C5
Выполняемый код POST переносится в Shadow RAM и далее выполняется из Shadow RAM для ускорения прохождения POST.
Shadow RAM быстрее ROM по двум причинам: разрядность ROM 8 бит, разрядность RAM равна разрядности локальной шины данных процессора. Время выборки используемых DRAM существенно меньше аналогичного параметра используемых ROM / Flash ROM
C6
Определение присутствия, объема и типа External Cache. Наличие и параметры External Cache определяются путем записей и контрольных считываний по специальному алгоритму
C8
Проверка целостности компонентов BIOS, расположенных в ROM. В случае несовпадения контрольной суммы компонентов делается вывод о повреждении области 128 Кб, содержащей внешний по отношению к системному BIOS файл awardext.rom. В виду того, что системный BIOS хранится в следующем 128 Кб блоке, некоторые 2 Мбит BIOS могут корректно обрабатывать эту ошибку и передавать управление на программу восстановления.
CF
Определение типа процессора. Результат помещается в CMOS. В виду того, что не все RTC инициализируются к этому моменту, сначала выполняется тест чтения/записи.
Если по каким либо причинам определение типа CPU закончилось неудачей, такая ошибка становится фатальной и POST дальше не выполняется и система останавливается.
01
В ранних версиях BIOS выполнялась проверка флагов признаков результата арифметической операции по такому алгоритму: флаги переноса (CF), нуля (ZF), знака (SF), переполнения (OF) принудительно устанавливаются в 1 командой SAHF, после этого проверяется что команды условного перехода JC, JZ, JS, JO выполняются. Затем подобным образом проверяется правильность отработки условных переходов при нулевых значениях этих флагов. Позднее от этого отказались по причине того, что неправильная работа флагов является очень грубой ошибкой процессора, при наличии которой POST все равно не дойдет до этого теста. Кроме того, начиная с 80386, процессоры имеют автономный тест, и при наличии такой грубой ошибки маловероятно, что процессор начнет выполнение POST вообще.
02
Зарезервировано для ProcessorTest 2. Проверка регистров процессора путем записи и контрольного считывания. От этого теста отказались приблизительно на этапе 80386 по той же причине, что и для теста 01
.
03
Предполагается, что верен вариант Soyo, согласно которому выполняется только настройка EISA ресурсов, а PIIX ресурсы (DMA, INT, Timer, RTC) настраиваются на шаге C0
, как это было описано выше, однако в зависимости от конкретной версии BIOS могут быть вариации.
NMI (Non Maskable interrupt) немаскируемое прерывание, имеет фиксированный номер вектора (2), используется для сообщения процессору об аварийных ситуациях (ошибка четности DRAM, активность сигнала IOCHCK# на ISA и т.п.).
PIE
, AIE
, UIE
(в исходном документе Award опечатка, по ошибке указано UEI) - это три разрешающих бита для формирования запроса прерывания схемой RealTimeClock (IRQ8 = INT 70h), по трем условиям, которые можно взаимонезависимо разрешать и запрещать.
PIE
(Periodic Interrupt Enable
) - разрешение периодических прерываний с программно устанавливаемой частотой.
AIE
(Alarm Interrupt Enable
) - разрешение прерываний от будильника, формируемых при совпадении значений часов, минут, секунд в регистрах подсчета времени и регистрах будильника.
UIE
(Update Interrupt Enable
) - разрешение прерываний при завершении цикла обновления состояния счетчиков часов:минут:секунд (1 раз в секунду).
SQWV
- режим генерации программируемой частоты на специальном выходе микросхемы RTC. PIE, AIE, UIE, SQWV запрещаются при выполнении POST, для этого записывается соответственно управляющий байт в регистр 0Bh микросхемы RTC.
04
Проверка формирования запросов на регенерацию DRAM.
В классической реализации PC AT запросы на регенерацию DRAM генерирует канал 1 системного таймера 8254. К его выходу также подключен триггер, работающий в счетном режиме и меняющий свое состояние на противоположное при каждом запросе. Состояние этого триггера можно программно считывать через бит 4 порта 61h. Проверка Refresh Toggle заключается в проверке того факта, что этот триггер переключается с заданной частотой. Однако появились chipset, использующие другие алгоритмы регенерации DRAM, с целью свести к минимуму простои CPU из-за регенерации. В этом случае, несмотря на то, что Refresh Trigger сохраняется для совместимости, по нему уже нельзя проверить формирование запросов на регенерацию.
Начиная с этого момента становится возможным использование стека
05
Если установлены адаптеры EGA или VGA, поддерживаемые собственным BIOS, операция Blank Video на этом этапе невозможна, так как Video BIOS еще не инициализирован. Если установлены CGA или MDA, обслуживаемые процедурами видео сервиса System BIOS, теоретически есть возможность очистить экран на этом шаге.
Проверка и инициализация контроллера клавиатуры. Контроллеру клавиатуры передается команда самотестирования и контролируется статус после ее завершения. Затем передается команда разрешения интерфейса клавиатуры.
Примечание 1
:
На данный момент прием кодов нажатых клавиш еще невозможен, так как запрещены прерывания, не подготовлены области данных BIOS, не инициализирована сама клавиатура.
06
Тест Shadow области памяти, начинающейся с адреса F000h, где размещен BIOS. Предположительно выполняются некоторые действия направленные на дополнительную проверку памяти или содержимого памяти, так как если на шаге C5
в Shadow RAM размещен BIOS, тестировать его уже поздно. Возможно, данный шаг обусловлен спецификацией конкретного ChipSet либо присутствует в BIOS, не поддерживающих Early Shadow.
07
Проверка функционирования CMOS и батарейного питания.
Батарейное питание проверяется путем чтения регистра 0Dh микросхемы RTC. Бит 7 этого регистра индицирует ошибку батарейного питания, причем он сообщает об ошибке, даже если в данный момент питание CMOS в норме, но с момента последнего считывания регистра 0Dh имело место пропадание питания CMOS. Если зафиксирована ошибка питания, BIOS запоминает этот факт, но POST не останавливается. Затем выполняется Verify Basic R/W functionality - проверка ячеек CMOS как проверка памяти. Записываются значения, выполняется контрольное считывание и проверяется равенство читаемого кода записанному. В отличие от ошибки батарейного питания, ошибка, выявленная этой проверкой считается фатальной и приводит к остановке на коде 07
.
BE
Настройка конфигурационных регистров CHIPSET. Программирование конфигурационных регистров микросхем Host Bridge и PIIX. Значения загружаются из таблицы BIOS defaults, доступной пользователю с помощью утилиты MODBIN .
08
В сложившемся разногласии видимо верное значение Absent, в виду того, что 64К, о которых здесь идет речь, уже протестированы, так как входят в 256К, задействованных на шагах C3
, C5
. OEM Specific действия по первичной настройке DRAM Controller соответственно уже проделаны.
09
Процессоры IBM/Cyrix имеют внутренние регистры для более гибкого управления кэшированием. На этом шаге выполняется машинная команда CPUID для распознавания типа процессора (видимо, основная процедура распознавания CPU происходит существенно позже, на данном этапе следует выяснить IBM/Cyrix это или нет), если распознан IBM/Cyrix, инициализируются его регистры расширенного управления кэшированием.
Выполняется инициализация L2 Cache Controller (запись управляющих слов в соответствующие регистры конфигурационного блока Host Bridge, очистка TAGRAM).
0A1
Генерация таблицы векторов прерываний. Таблица имеет объем 1024 байта и содержит 256 указателей на процедуры обработки прерываний, на каждую процедуру - два 16-битовых слова: смещение и сегмент, на данном этапе устанавливаются 32 вектора (INT 00h - INT 1Fh), на процедуры обработки соответствующих прерываний (Interrupt Handlers), входящие в состав BIOS. Векторы 33-120 устанавливаются на процедуру заглушку. Настройка ресурсов Power Management. На этом шаге также происходит первичная настройка подсистемы управления питанием, входящей в состав PIIX, схемы генерации SMI (System Management interrupt) и установка вектора SMI .
0B
Если нажата клавиша INS, выполняется установка CMOS по умолчанию.
Существенно важный момент для BIOS, поддерживающих SoftMenu. (См. FAQ №9
) .
Проверяется контрольная сумма блока ячеек CMOS, отвечающего за хранение конфигурационной информации, если фиксируется ошибка, устанавливается программный флаг CMOS недостоверен. Этот флаг также устанавливается, если ранее, на шаге 07
было выявлено пропадание батарейного питания CMOS.
Если BIOS поддерживает PnP, выполняется сканирование ISA PnP устройств и инициализация их параметров (Адрес, Номера IRQ и DRQ). Для PCI устройств устанавливаются основные параметры в блоке конфигурационных регистров (PCI Bus Cycle parameters, I/O and MEMORY Address). Блок конфигурационных регистров PCI устройства содержит поля, имеющие одинаковое назначение у всех PCI устройств (стандартные) и поля, специфичные для конкретного устройства. Установка параметров PCI устройств, о которой здесь идет речь сводится к установке значений стандартных полей.
В процессорах класса P6 существует доступ к памяти микропрограмм, в которой хранится микрокод для выполнения каждой машинной команды. Внесение изменений в микрокод, дает возможность изменять алгоритмы выполнения имеющихся машинных команд и добавлять новые.
0C
Инициализация блока переменных BIOS. На этом этапе присваиваются стартовые значения переменным BIOS, находящимся в 256-байтовом блоке 0040:0000h - 0040:00FFh.
Разногласия с Initialize Keyboard, видимо решаются в пользу варианта Soyo, так как второе после включения питания мигание светодиодов клавиатуры происходит уже после инициализации видеоадаптера
0D
Классический подход к обнаружению видеоадаптера следующий: проверяется наличие EGABIOS или VGABIOS путем проверки наличия сигнатуры 55 AA по адресу начала Video BIOS (Seg:Offs
= C000:0000h
). Если сигнатура обнаружена, проверяется контрольная сумма Video BIOS, если она правильная, происходит передача управления командой CALL FAR по адресу Seg:Offs = C000:0003h на инициализационную процедуру Video BIOS. Эта процедура настраивает видеоадаптер, переустанавливает вектор прерывания INT 10h (Video Service) на сервисную процедуру Video BIOS, выдает заставку видеоадаптера и возвращает управление вызвавшей процедуре System BIOS командой RET FAR. Если Video BIOS не обнаружен, делается попытка обнаружить CGA или MDA, путем сканирования пространства портов и поиска регистров управления CGA/MDA. Если CGA или MDA обнаружены, BIOS инициализирует видеоадаптер. В отличие от EGA/VGA, у CGA/MDA адаптеров Video BIOS нет и обработка INT 10h для CGA/MDA входит в обязанности System BIOS. Если не обнаружен никакой видеоадаптер - генерируется звуковой сигнал.
На этом же этапе происходит распознавание типа процессора (процессоров) настройка I/O APIC, Local APIC, программирование Host Bridge для установки параметров Host Bus (Front Side Bus). Для распознавания типа процессора обычно используется команда CPUID.
Для измерения тактовой частоты используется измерение частоты инкрементирования регистра TSC (Time Stamp Counter), который инкрементируется по каждому такту Internal CPU CLK. В качестве генератора образцовой частоты может использоваться либо системный таймер, либо RTC. Некоторые BIOS не используют Time Stamp Counter, а измеряют время выполнения цикла из последовательности команд, для которых известно количество тактов на команду. Так делалось, когда процессоры не имели TSC
0E
Если установлен видеоадаптер CGA или MDA, выполняется тест Video RAM. Для EGA/VGA такой тест был проделан Video BIOS на шаге 0D
, при выполнении инициализационной процедуры C000:0003h
.
Относительно настройки APIC: скорее всего она разбита на два этапа, выполняемых на шагах 0D
и 0E
.
Предположительно на этом шаге, а не 0F
, настраивается клавиатура и разрешаются аппаратные прерывания от таймера 8254 (IRQ0) и клавиатуры (IRQ1).
Инициализация RPB (Remote Pre Boot) подсистемы удаленной загрузки,
0F
Проверка первого контроллера DMA 8237, ошибочно указанного в документации SOYO канал 0 - перепутаны понятия "канал DMA" и "контроллер DMA". Проверка выполняется путем записи и контрольного считывания регистров базового адреса и длины пересылки. Собственно тестовых пересылок данных с помощью DMA каналов на этом шаге и вообще в POST не выполняется. Таким образом проверяется только чтение/запись регистров контроллера DMA процессором с помощью команд IN / OUT.
BIOS Checksum должен был проверяться при распаковке, видимо расположение BIOS Checksum Test на этом этапе было до того, как BIOS разделили на Boot Block и основной (упакованный) блок.
Известно, что на этом этапе выполняется определения клавиатуры и ее внутренний тест. Запрещены Reset контроллера клавиатуры и обслуживаемый им интерфейс манипулятора "мышь" PS/2. Эти действия выполняются позже на шаге 3D.
10
Проверка второго контроллера DMA 8237.
11
Проверка страничных регистров контроллеров DMA. Страничные регистры необходимы для расширения 16-битового адреса формируемого контроллером 8237 до 24-битового (ISA) или 32-битового (EISA).
Обособление страничных регистров от контроллера DMA обусловлено тем, что в старых системах использовался контроллер DMA Intel 8237 в виде отдельной микросхемы, он способен формировать только 16-битовые адреса, поэтому устанавливался дополнительный блок расширения адреса (DMA Page Registers).
Тест страничных регистров выполняется путем записей и контрольных считываний, без собственно DMA операций (пересылок)
14
Тест канала (счетчика) 2 системного таймера. Канал 2 системного таймера используется для генерации звука. По нашим сведениям какого-либо классического подхода к этому тесту не сформировано, некоторые BIOS ограничиваются записью и контрольным считыванием регистров таймера, доступных для записи и чтения (R/W test).
Некоторые BIOS программируют таймер на формирование заданного интервала и контролируют длительность сформированного интервала по часам RTC. Однако в случае расхождения не понятно кто ошибся - Timer или RTC. Предположительно, Award 4.51 ограничился R/W тестом,
15
Проверка регистра маскирования запросов первого контроллера прерываний. Следует сказать, что использование термина "Channel" для контроллера прерываний нетрадиционно и приведет к путанице. Приняты следующие обозначения: Первый контроллер прерываний (Master), 8259#1. Регистры доступны по адресам 20h, 21h. Обрабатывает IRQ0-IRQ7, которым присвоены вектора INT 08h - INT 0Fh. Второй контроллер прерываний (Slave), 8259#2. Регистры доступны по адресам A0h, A1h. Обрабатывает IRQ8-IRQ15, которым присвоены вектора INT 70h - INT 77h. Выход Slave8259 подключен ко входу IRQ2 Master 8259.
На этом шаге проверяется регистр маскирования первого контроллера прерываний путем записи тестовых кодов в порт 21h и контрольного считывания. Однако проверки собственно операции маскирования, как индивидуального разрешения/запрещения линий IRQ POST не выполняет.
16
Проверка регистра маскирования запросов второго контроллера прерываний. Операция аналогична шагу 15
, адрес регистра маскирования для второго контроллера прерываний - A1h.
17
Зарезервировано. Видимо у более ранних версий BIOS на этом шаге выполнялась следующая операция: устройства источники IRQ (Timer, Keyboard...) программировались таким образом, чтобы запрос IRQ зафиксировался в пассивном состоянии, затем выполнялось чтение регистров запросов контроллеров прерываний 8259#1 и 8259#2 и проверялся тот факт, что соответствующие запросы пассивны.
Практика ремонта плат, показывает, что фиксация IRQ в состоянии 0 или 1 дает о себе знать только в момент, когда нужно взаимодействовать с устройством, IRQ которого неисправно (так происходит в большинстве случаев). На этапе теста контроллера прерываний такой дефект НЕ выявляется, поэтому предполагается, что BIOS не делает указанного действия.
18
По описанию этот шаг подобен шагу 17
, однако, если на шаге 17
проверялось отсутствие запросов, то здесь наоборот, устройства источники IRQ программируются на активизацию запросов и проверяется запуск процедур обработки прерывания для активизированных запросов.
На основании тех же экспериментальных данных, о которых шла речь в описании шага 17
, можно считать, что шаг 18
действительно отсутствует в том смысле, который имеет в виду Award. Имеется подтверждение о его существовании и выполнении совершенно иных тестовых процедур, связанных с определением типа процессора.
19
Проверка пассивности запроса немаскируемого прерывания (NMI). Запрос NMI используется для сообщения процессору об аварийных ситуациях (ошибка четности памяти, активность сигнала #IOCHCK на шине ISA). Он приводит к генерации прерывания с фиксированным номером вектора - 2 и обрабатывается без участия 8259. Указанные аварийные события приводят к установке триггера NMI, сброс этого триггера выполняется программно, его состояние также можно опросить (используется порт 61h). Обычно этот тест подразумевает выполнение программного сброса триггера NMI и проверку, что он не установился повторно
1A
Предположительно, что этот шаг Reserved, а вывод на экран значения тактовой частоты CPU происходит на шаге 0D.
1E
, 1F
Установка параметров шины EISA в соответствии с содержимым NV memory (EISA BIOS). Проверяется контрольная сумма блока параметров EISA (NVM Checksum), если она верная, контроллер EISA инициализируется в соответствии с указанными параметрами.
20
...2F
Инициализация EISA устройств. В отличие от ISA, шина EISA имеет средства для индивидуальной адресации слотов (раздельные сигналы SELECT). Таким образом, имеется возможность программно распознать, в каком слоте какое устройство установлено. Возможно также выполнить раздельный доступ к конфигурационным регистрам подобно PCI, что и делается на этом шаге
.
30
1
.Get Base Memory and Extended Memory Size
2.P6 Multi-P BIOS Only - Init I/O and Local APIC
3.Program K5/K6 CPU"s Write Allocation
Определение объема Base Memory и Extended Memory. Это завершающая стадия определения объема памяти, к этому моменту все операции по картированию выполнены, и на этой стадии уже начинается тестирование памяти, BIOS выполняет запись/контрольное считывание, определяет, начиная с какого адреса прекращается совпадение читаемых значений записанным и этот адрес принимается как граница памяти.
Настройка APIC применительно к P6 освещена достаточно мало.
K5/K6 Write Allocation
- это нововведение AMD, которое сводится к следующему. У процессоров Intel поводом для кэширования ячейки является только ее чтение, после того, как ячейка с определенным адресом кэширована, это приносит пользу также и при записи (Write Back), однако само кэширование выполняется только при чтении, поэтому если в выполняемом коде попадается серия из последовательных записей по одинаковым (или близким) адресам, кэш не приносит пользы, если до этого эти адреса не считывались программой. AMD Write Allocation - режим, при котором поводом для кэширования является не только чтение данных, но и запись. Это чревато коллизиями, как любое отступление от стандарта Intel, поэтому AMD предусмотрела возможность программного управления этим режимом, вплоть до отключения его. Настройка регистров процессоров AMD K5/K6, управляющих этим режимом, и есть часть шага 30.
31
1. Test base memory from 256K to 640K and extended memory above 1MB .
2. Test Extended Memory from 1M to the of memoryusing various patterns.
NOTE: This will be skipped in EISA mode and can be "skipped" with ESC key in ISA mode.
3. USB Init .
Основной отображаемый на экране тест оперативной памяти. Для объема памяти, определенного на шаге 30
выполняется тест, путем записи нескольких видов Pattern и их контрольного считывания. Предположительной причиной разногласий по EISA является тот факт, что по старым стандартам, иметь более 16 Мбайт памяти могла только EISA система. Сейчас это не так, и вся физически присутствующая память тестируется на этом этапе, во всяком случае для не EISA системы.
Инициализация USB. По USB есть сомнения: это действие не имеющее отношение к тесту памяти и для него должны были зарезервировать отдельный код.
32
IfEISA Mode flag is set then test EISA memory found in slots initialization.
NOTE: This will be skipped in ISA mode and can be "skipped" with ESC key in EISA mode.
Display the Award Plug and Play BIOS Extension message (PnP BIOS ONLY).
Program all onboard super I/O chips(if any) including COM ports, LPT ports, FDD port... according to setup value Program onboard audio devices
Если исходить из предположения, что вся память проверяется на шаге 31
, то для шага 32
верным кажется вариант Soyo, где нет упоминаний про память.
Выводится заставка Plug and Play BIOS Extension
.
Настройка ресурсов Super I/O. Микросхема SIO вводится в режим конфигурирования. В соответствии с установками Setup, если CMOS достоверен, программируются параметры: базовые адреса программно-доступных ресурсов COM, LPT, FDC, GamePort номера используемых линий IRQ и DRQ. После этого отключается режим конфигурирования SIO.
Аналогично программируется Onboard Audio Device. Если Audio Device подключено к PCI, его настройка происходит не на этом шаге, а на шаге 0B .
39
Programming clock synthesizer by I2C bus
.
Предположительно, на этом шаге выполняется программирование тактового генератора по шине I2C
3C
Set flag to allow users to enter CMOS Setup Utility.
Установка программного флага разрешения входа в Setup.
3D
1. Initialize Keyboard.
2. Install PS2 mouse .
3. Build the INT 15h function E820H table .
4. Build the PnP Device Node for total memory size .
Инициализация PS/2 mouse. Один из альтернативных моментов для инициализации клавиатуры.
Относительно функции E820h и PnP Device Node информации мало.
3E
Try to turn on Level 2 cache.
NOTE: Some chipset may need to turn on the L2 cache in this stage. But usually, the cache is turn on later in POST 61h.
Один из альтернативных моментов для инициализации контроллера External Cache и разрешения Cache
BF
1. Program the rest of the Chipset"s value according to Setup (Later Setup Value Program).
2. If auto-configuration is enabled, programmed the chipset with pre-defined values in the MODBINable Auto-Table
.
Настройка конфигурационных регистров CHIPSET в соответствии с установками CHIPSET Setup.
Доступно для утилиты MODBIN.
40
Display virus protect disable or enable - Absent
.
Отображение состояния опции Virus Protect, исключено в новых версиях BIOS
41
Initialize floppy disk drive controller and any drives.
Инициализация подсистемы гибких дисков.
Для BIOS поддерживающих процессоры P6 сначала выполняется отключение local APIC, потому что в противном случае запрос IRQ не может быть правильно сгенерирован. Затем, для всех типов BIOS, выполняется программный сброс контроллера дисковода (через порт 3F2h). Снимается маскирование запроса прерывания от дисковода (IRQ6), для этого обнуляется бит 6 в порте 21h, проверяется прохождение запроса прерывания от контроллера дисковода. Устанавливаются параметры работы контроллера дисковода (командой SPECIFY). Если в Setup разрешен Floppy Drive Seek Test, выполняется тест позиционирования для установленных дисководов
42
1. Cut IRQ 12 connection if PS2 mouse is not installed.
2. Install IDE Hard Drives. Auto-detect HDDs. Build the AT compatible HDD table for Type 47. Set PIO timing
.
3. Detect CD ROM on IDE Bus
.
4. Detect LS120 drive
.
Отключение IRQ12 если PS/2 mouse отсутствует.
Выполняется программный сброс контроллера жестких дисков. Если для устройства в Setup указан режим AUTO, выполняется команда IDENTIFY DRIVE, иначе параметры устройства берутся из CMOS. Выполняется программирование конфигурационных регистров PIIX для установки PIO Mode.
Выполняется сканирование на предмет наличия других IDE устройств (CDROM, LS120 ...). Если на Primary IDE присутствуют устройства, размаскируется IRQ14, обнуляется бит 6 в порте A1h. Если на Secondary IDE присутствуют устройства, размаскируется IRQ15, обнуляется бит 7 в порте A1h. Проверяется прохождение соответствующих IRQ (только для HDD)
43
1. Detect and Initialize Serial/Parallel Ports (also game port).
2. If it is a PNP BIOS, initialize serial and parallel ports
.
Предположительно само конфигурирование Si/o Chip происходит на шаге 32
, а на шаге 43
ресурсы SIO вносятся в формируемый BIOS список PnP устройств.
45
Detect and Initialize math coprocessor.
Инициализация сопроцессора FPU.
Проверка наличия (Detect) в обычном понимании не выполняется, так как наличие/отсутствие FPU однозначно следует из информации, прочитанной по команде CPUID при определении CPU Type. Но в силу того, что убедиться в функциональной пригодности этого устройства невозможно на ранних этапах POST, выполняется ряд тестов с участием памяти, подтверждающих корректность определения FPU.
Под инициализацией обычно понимается программный сброс FPU и запись управляющего слова в регистр FPU CW .
4E
1. Reboot if Manufacturing pin POST Loop is set. Otherwise display any messages (i.e., any non-fatal errors that were detected during POST) and enter Setup.
2. If there is any error detected (such as video, keyboard etc.), show all the error messages on the screen and wait for user to press key .
3. Enable "Far Hit" for IBM/Cyrix 6x86 CPU.
Инициализация клавиатуры USB.
Некоторые материнские платы (в основном в конструктиве Socket 7) имеют перемычку для заводского тестирования. Если указанная перемычка установлена, выполняется перезагрузка. В противном случае на экран выводятся сообщения о нефатальных ошибках, таких как несоответствие HDD объявленному в CMOS типу, отказе клавиатуры и тому подобное.
На данном этапе становится возможен вход в CMOS Setup, если отработано нажатие клавиши DEL.
В случае, если перемычка заводского тестирования не установлена либо не предусмотрена вообще и обнаружены ошибки, не препятствующие дальнейшему выполнению POST и старту операционной системы, выводится сообщение и ожидание продолжить POST по нажатию любой клавиши. Для клавиатуры в стандарте DIN или PS/2 инициализация уже выполнена на шаге 3D
, поэтому выполняется только проверка состояния KeyLock. Прочие параметры клавиатуры устанавливаются на шаге 62
.
В связи с тем, что на шаге 45
завершены все инициализационные процедуры для CPU, становится возможным выбрать протокол работы с cache L2, если установлен процессор IBM/Cyrix. Разрешается Write Allocation .
4F
1. If password is needed, ask for password.
2. Clear the Energy Star Logo (Green BIOS ONLY) .
Запрос на ввод пароля, если это предусмотрено установками CMOS Setup.
Логотип Energy Star Pollution или его заменяющий исчезает.
50
Write all CMOS values back to RAM and clear screen.
Write all the CMOS values currently in the BIOS stack area back into the CMOS .
Восстановление ранее сохраненного в ОЗУ состояния CMOS. При выполнении некоторых фрагментов POST содержимое CMOS может модифицироваться, поэтому исходное содержимое CMOS копируется в ОЗУ, обычно стек BIOS, а после прохождения искажающих CMOS фрагментов, записывается обратно в CMOS .
51
Enable parity checker, Enable NMI, Enable cache, reset flags before boot.
Относительно разрешения контроля четности, немаскируемых прерываний, cache L1/L2 и переустановки флагов информации нет. Предположительно, выполнение указанных операций возможно только для чип сетов типа Intel HX, осуществляющих поддержку контроля четности.
Разрешено автоопределение HDD по схеме с 32-битным доступом.
Инициализация и установка параметров устройств ISA/PnP до инициализации устройств PCI
52
1. Initialize any option ROMs present from C8000h to EFFFFh
.
NOTE: When FSCAN option is enabled, will initialize from C8000h to F7FFFh
.
2. Later PCI initializations (PCI BIOS ONLY) - assign IRQ to PCI devices - initialize all PCI ROMs.
3. Program shadows RAM according to Setup settings.
4. Program parity according to Setup setting.
5. Power Management Initialization. Enable/Disable global PM - APM interface initializtion.
Инициализация ПЗУ дополнительных BIOS (ROMSCAN процедура). В диапазоне адресов C8000H-EFFFFH
выполняется поиск сигнатур дополнительных BIOS (55 AA), если сигнатура обнаружена, считывается байт длины блока (идущий после сигнатуры) для блока проверяется контрольная сумма, и в случае верной контрольной суммы управление передается командой FAR CALL по смещению 0003 относительно начала блока. Предполагается, что дополнительный BIOS выполнит инициализацию устройства, которое он обслуживает, перехватит необходимые вектора прерываний и вернет управление в System BIOS командой RET FAR. Типичный пример - SCSI BIOS, который обычно перехватывает INT 13h и берет на себя обслуживание SCSI HDD. Video BIOS использует ту же идеологию, но находится на особом положении - его инициализация происходит раньше, для обеспечения возможности отображения выполнения POST на экране.
Assign IRQ to PCI devices - имеется в виду установка значений четырех конфигурационных регистров PIIX (по числу линий PCI INT), в которые записывается, на какое IRQ картируется каждая из линий запросов прерывания PCI (INTA#, INTB#, INTC#, INTD#). Для дополнительных BIOS в соответствии с установками Setup, опционально включается режим Shadow. Для System BIOS он включен всегда.
На этом этапе также программируется:
формирование NMI (Nonmaskable Interrupt) для Parity Check
формирование SMI (System Management Interrupt) для Green функций
53
Initialize time value in 40h: BIOS area.
1. If it is NOT a PNP BIOS, initialize serial and parallel ports .
2. Initialize time value in BIOS data area by translate the RTC time value into a timer tick value
.
Установка счетчика DOS Time в соответствии с Real Time Clock. Значение времени в формате часы:минуты:секунды пересчитывается в тики таймера 18.2 Hz и записывается в ячейки DOS Time в области переменных BIOS. Установка переменных BIOS, хранящих базовые адреса портов.
60
SetupVirus Protection (Boot Sector Protection) functionality according to Setupsetting
.
Установка антивирусной защиты BOOT Sector. В большинстве плат такая защита реализуется программно. Перед входом в процедуру обработки дискового сервиса (INT 13h) устанавливается транзитный программный модуль, который анализирует входные параметры функции и детектирует две ситуации:
Попытка записи в BOOT Sector (AH=3
, CL=1
, CH=0
, DL=8xh
, DH=0
)
Попытка форматирования Track 0 (AH=5
, CH=0
, DL=8xh
, DH=0
)
Если система условий - значения регистров - выполняется, вместо дисковой операции выдается предупреждающее сообщение и звуковой сигнал. На шаге 60
выполняется перестановка вектора INT 13h на транзитный контролирующий модуль, если в Setup включен данный режим.
61
1. Try to turn on Level 2 cache.
Note: if L2 cache is already turned on in POST 3D, this part will be skipped .
2. Set the boot up speed according to Setup setting .
3. Last chance for Chipset initialization .
4. Last chance for Power Management initialization (Green BIOS only) .
5. Show the system configuration table
.
Один из альтернативных моментов для включения External Cache.
Завершающие действия по инициализации Chipset и Power Management
62
1. Setup daylight saving according to Setup value .
2. Program the NUM Lock, typmatic rate and typmatic speed according to Setup setting Чтение KBD ID.
Установка режима Daylight Saving - разрешение автоматического перехода на зимнее/летнее время для RealTimeClock, состояния NUM Lock, частота автоповтора и время ожидания до входа в режим автоповтора.
63
1. If there is any changes in the hardware configuration, update the ESCD information (PNP BIOS ONLY) .
2. If there is any changes in the hardware configuration, update the DMI data pool (DMI BIOS ONLY) .
3. Clear memory that have been used .
4. Boot system via INT 19h
.
Коррекция блоков ESCD, DMI, если изменилась конфигурация. Очистка, обнуление ОЗУ.
75
Thermal Warning
.
Если в качестве контроллера системного мониторинга используется LM78, выполняется сигнализация о превышении допустимых значений температурного режима.
В настоящее время нет достоверной информации о генерации этого кода контроллерами других производителей, например Winbond Electronics или Genesys Logic.
80
...83
, 90
...93
Primary Master IDE Power Off(80)/On(90); Primary Slave IDE Power Off(81)/On(91); Secondary Master IDE Power Off(82)/On(92);
Secondary Slave IDE Power Off(83)/On(93)
.
84
and 94
Sound Chip Power Off(84)/On(94)
.
86
...88
, 96
...98
COMA Power Off(86)/On(96) ; COMB Power Off(87)/On(97) ;
LPT Power Off(88)/On(98).
8B
and 9B
Turn CRT Off(8B)/On(9B)
.
85
, 89
, 8A
, 8C
, 8D
and 95
, 99
, 9A
, 9C
, 9D
Turn Unknown Devices Off/On
.
Это не один из этапов POST, а вывод в диагностический порт контрольных точек включения / выключения неизвестных устройств.
Следует отметить, что все коды группы 80 и 90 связаны с событиями, возникающими в процессе Green Functions. На сегодня нет достоверной информации, однозначно определяющей устройства, кроме выше упомянутых, участвующих в функциях энергосбережения
B0
Spurious. If interrupt occurs in protected mode.
Обработчик-заглушка прерываний (исключений) для защищенного режима. Это не один из этапов POST, а процедура, на которую устанавливаются вектора (для защищенного режима не вектора, а дескрипторы IDT) внутренних прерываний (исключений) процессора на время работы в Protected Mode, например, при тесте Extended Memory. Если при работе в Protected Mode не будет сбоев, эта процедура и не получит управления. Если будут иметь место ошибки, например некорректные данные в дескрипторных таблицах, страничные нарушения и другие исключительные ситуации Protected Mode, управление будет передано на эту процедуру, она выведет код B0 в Port 80 и остановится
B1
If unmasked NMI occurs, display Press F1
to disable NMI, F2 reboot
.
Unclaimed NMI occurs.
Обработчик-заглушка немаскируемого прерывания. Это не один из этапов POST, а процедура, на которую указывает вектор немаскируемого прерывания. Если возник запрос NMI, и не удалось идентифицировать причину NMI, в Port80 выводится этот код, на экран выводится сообщение:
Press F1
to disable NMI, F2 to reboot
.
И ожидаются действия пользователя.
B2
Unknown action
.
55
and BB
Begin to Shutdown the system 5 Volt;
Begin to Shutdown the system 0 Volt
.
D3
SMI Handle .
D7
Software Doze
.
D8
Software Standby
.
D9
Software Suspend
.
E1
...EF
Setup Pages E1
- Page 1
, E2
- Page 2
, etc.
По этой операции проверенной информации нет, предположительно, что это актуально для старых систем, у которых доступ к BIOS ROM организуется постранично через картируемое окно, при установке каждой новой страницы выводится код Ex, где x - номер страницы. Этот факт подтверждается существованием в указанном диапазоне кодов, связанных с выполнением других процессов
EC
ECC Post Code associate with System Management Interrupt (SMI)
.
В настоящее время нет достоверной информации о причинах генерации этого кода. Предположительно, его возникновение связано с обработкой ECC в процессе выполнения Green Functions .
ED
HDD hang up on 0V resume.
Данный код сигнализирует об ошибке выхода HDD из режима энергосбережения.
FF
System Booting
.
This means that the BIOS already pass the control right to the operating system.
Передача управления загрузчику BOOT сектора. BIOS выполняет команду INT 19h. Процедура обработки прерывания INT 19h последовательно пытается заг.
Сокращенная процедура выполняется при установке в BIOS параметра Quick Power On Self Test.
- 65 Сбрасывается видеоадаптер. Инициализируются звуковой контроллер, устройства ввода/вывода,тестируется клавиатура и мышь. Проверяется целостность BIOS
- 66 Инициализируется кэш-память. Создается таблица векторов прерываний. Инициализируется система управления питанием
- 67 Проверяется контрольная сумма CMOS и тестируется батарейка питания. Настраивается чипсет на основе параметров CMOS
- 68 Инициализируется видеоадаптер
- 69 Настраивается контроллер прерываний
- 6A Тестируется оперативная память (ускоренно)
- 6B Отображается логотип EPA, результаты тестов процессора и памяти
- 70 Отображается подсказка для входа в BIOS Setup. Инициализируется мышь, подключенная к PS/2 или USB
- 71 Инициализируется контроллер кэш-памяти
- 72 Настраиваются регистры чипсета. Создается список устройств Plug and Play.& Инициализируется контроллер дисковода
- 73 Инициализируется контроллер жестких дисков
- 74 Инициализируется сопроцессор
- 75 Если нужно, жесткий диск защищается от записи
- 77 Если нужно, запрашивается пароль и выводятся сообщения Press F1 to continue, DEL to enter Setup
- 78 Инициализируются платы расширения с собственной BIOS
- 79 Инициализируются ресурсы платформы
- 7A Генерируются корневая таблица RSDT, таблицы устройств DSDT, FADT и т. п.
- 7D Собирается информациия о разделах загрузочных устройств
- 7E BIOS готовится к загрузке операционной системы
- 7F Состояние индикатора NumLock устанавливается в соответствии с настройками
- BIOS Setup
- 80 Вызывается INT 19 и запускается операционная система
AMIBIOS 8.0
- D0 Инициализация процессора и чипсета. Проверка контрольных сумм загрузочного блока BIOS
- D1 Начальная инициализация портов ввода/вывода. Контроллеру клавиатуры передается команда для самотестирования BAT
- D2 Запрет кэш-памяти L1/L2. Определяется объем установленной ОЗУ
- D3 Настраиваются схемы регенерации памяти. Разрешается использовать кэш-память
- D4 Тест 512 Кбайт памяти. Устанавливается стек и назначается протокол обмена с кэш-памятью
- D5 Код BIOS распаковывается и копируется в теневую память
- D6 Проверяются контрольные суммы BIOS и нажатие клавиш Ctrl+Home (восстановление BIOS)
- D7 Управление передается интерфейсному модулю, распаковывающему код в область Run-Time
- D8 Выполняемый код распаковывается из flash-памяти в оперативную. Сохраняется информация CPUID
- D9 Распакованный код переносится из области временного хранения в сегменты 0E000h и 0F000h ОЗУ
- DA Восстанавливаются регистры CPUID. Выполнение POST переносится в оперативную память
- E1-E8, EC-EE Ошибки, связанные с конфигурацией системной памяти
- 03 Запрещается обработка NMI, ошибок четности, выдача сигналов на монитор. Резервируется область для журнала событий GPNV, устанавливаются начальные значения переменных из BIOS
- 04 Проверяется работоспособность батареи и подсчитывается контрольная сумма CMOS
- 05 Инициализируется контроллер прерываний и строится таблица векторов
- 06 Тестируется и готовится к работе таймер
- 08 Тестируется клавиатура (мигают индикаторы клавиатуры)
- C0 Начальная инициализация процессора. Запрещается использовать кэш-память. Определяется APIC
- C1 Для многопроцессорных систем определяется процессор, отвечающий за запуск системы
- C2 Завершается назначение процессора для запуска системы. Идентификация с помощью CPUID
- C5 Определяется количество процессоров, настраиваются их параметры
- C6 Инициализируется кэш-память для более быстрого прохождения POST
- C7 Завершается начальная инициализация процессора
- 0A Определяется контроллер клавиатуры
- 0B Поиск мыши, подключенной к порту PS/2
- 0C Проверяется наличие клавиатуры
- 0E Детектируются и инициализируются различные устройства ввода
- 13 Начальная инициализация регистров чипсета
- 24 Распаковываются и инициализируются модули BIOS, специфические для платформы.
- Создается таблица векторов прерываний и инициализируется обработка прерываний
- 2A С помощью механизма DIM определяются устройства на локальных шинах. Готовится к инициализации видеоадаптер, строится таблица распределения ресурсов
- 2C Обнаружение и инициализация видеоадаптера, видеоадаптер вызывается BIOS
- 2E Поиск и инициализация дополнительных устройств ввода/вывода
- 30 Готовится к обработке SMI
- 31 Инициализируется и активизируется модуль ADM
- 33 Инициализируется модуль упрощенной загрузки
- 37 Отображается логотип AMI, версия BIOS, процессора, подсказка клавиши для входа в BIOS
- 38 С помощью DIM инициализируются различные устройства на локальных шинах
- 39 Инициализируется контроллер DMA
- 3A Устанавливается системное время в соответствии с показаниями часов RTC
- 3B Тестируется оперативная память и отображаются результаты
- 3C Настраиваются регистры чипсета
- 40 Инициализируются последовательные и параллельные порты, математический сопроцессор и др.
- 52 По результатам теста памяти обновляются данные об ОЗУ в CMOS
- 60 По BIOS Setup устанавливается состояние NumLock и настраиваются параметры автоповтора
- 75 Запускается процедура для работы с дисковыми устройствами (прерывание INT 13h)
- 7C Создаются и записываются в NVRAM таблицы расширенной системной конфигурации ESCD
- 84 Регистрация ошибок, обнаруженных при выполнении POST
- 85 Выводятся сообщения об обнаруженных некритических ошибках.
- 87 Если нужно, запускается BIOS Setup, которая предварительно распаковывается в ОЗУ
- 8C В соответствии с BIOS Setup настраиваются регистры чипсета
- 8D Строятся таблицы ACPI
- 8E Настраивается обслуживание немаскируемых прерываний (NMI)
- 90 Окончательно инициализируется SMI
- A1 Очистка данных, которые не нужны при загрузке операционной системы
- A2 Для взаимодействия с операционной системой готовятся модули EFI
- A4 В соответствии с BIOS Setup инициализируется языковой модуль
- A7 Выводится итоговая таблица процедуры POST
- A8 Устанавливается состояние регистров MTRR
- A9 Если нужно, выполняется ожидание ввода команд с клавиатуры
- AA Удаляются векторы прерываний POST (INT 1Ch и INT 09h)
- AB Определяются устройства для загрузки операционной системы
- AC Завершающие этапы настройки чипсета в соответствии с BIOS Setup
- B1 Настраивается интерфейс ACPI
PhoenixBIOS 4.0
- 02 Verify Real Mode
- 03 Disable Non-Maskable Interrupt (NMI)
- 04 Get CPU type
- 06 Initialize system hardware
- 08 Initialize chipset with initial POST values
- 09 Set IN POST flag
- 0A Initialize CPU registers
- 0B Enable CPU cache
- 0C Initialize caches to initial POST values
- 0E Initialize I/O component
- 0F Initialize the local bus IDE
- 10 Initialize Power Management
- 11 Load alternate registers with initial POST values
- 12 Restore CPU control word during warm boot
- 13 Initialize PCI Bus Mastering devices
- 14 Initialize keyboard controller
- 16 (1-2-2-3) BIOS ROM checksum
- 17 Initialize cache before memory autosize
- 18 8254 timer initialization
- 1A 8237 DMA controller initialization
- 1C Reset Programmable Interrupt Controller
- 20 (1-3-1-1) Test DRAM refresh
- 22 (1-3-1-3) Test 8742 Keyboard Controller
- 24 Set ES segment register to 4 GB
- 26 Enable A20 line
- 28 Autosize DRAM
- 29 Initialize POST Memory Manager
- 2A Clear 512 KB base RAM
- 2C (1-3-4-1) RAM failure on address line xxxx
- 2E (1-3-4-3) RAM failure on data bits xxxx of low byte of memory bus
- 2F Enable cache before system BIOS shadow
- 30 (1-4-1-1) RAM failure on data bits xxxx of high byte of memory bus
- 32 Test CPU bus-clock frequency
- 33 Initialize Phoenix Dispatch Manager
- 34 Disable Power Button during POST
- 35 Re-initialize registers
- 36 Warm start shut down
- 37 Re-initialize chipset
- 38 Shadow system BIOS ROM
- 39 Re-initialize cache
- 3A Autosize cache
- 3C Advanced configuration of chipset registers
- 3D Load alternate registers with CMOS values
- 40 CPU speed detection
- 42 Initialize interrupt vectors
- 45 POST device initialization
- 46 (2-1-2-3) Check ROM copyright notice
- 48 Check video configuration against CMOS
- 49 Initialize PCI bus and devices
- 4A Initialize all video adapters in system
- 4B QuietBoot start (optional)
- 4C Shadow video BIOS ROM
- 4E Display BIOS copyright notice
- 50 Display CPU type and speed
- 51 Initialize EISA board
- 52 Test keyboard Тестируется клавиатура
- 54 Set key click if enabled
- 55 Initialize USB bus
- 58 (2-2-3-1) Test for unexpected interrupts
- 59 Initialize POST display service
- 5A Display prompt “Press F2 to enter SETUP”
- 5B Disable CPU cache
- 5C Test RAM between 512 and 640 KB
- 60 Test extended memory
- 62 Test extended memory address lines
- 64 Jump to UserPatch1
- 66 Configure advanced cache registers
- 67 Initialize Multi Processor APIC
- 68 Enable external and CPU caches
- 69 Setup System Management Mode (SMM) area
- 6A Display external L2 cache size
- 6B Load custom defaults (optional)
- 6C Display shadow-area message
- 6E Display possible high address for UMB recovery
- 70 Display error messages Выводятся сообщения об ошибках
- 72 Check for configuration errors
- 76 Check for keyboard errors
- 7C Set up hardware interrupt vectors
- 7D Initialize hardware monitoring
- 7E Initialize coprocessor if present
- 80 Disable onboard Super I/O ports and IRQs
- 81 Late POST device initialization
- 82 Detect and install external RS232 ports
- 83 Configure non-MCD IDE controllers
- 84 Detect and install external parallel ports
- 85 Initialize PC-compatible PnP ISA devices
- 86 Re-initialize onboard I/O ports
- 87 Configure Motheboard Configurable Devices (optional)
- 88 Initialize BIOS Data Area
- 89 Enable Non-Maskable Interrupts (NMIs)
- 8A Initialize Extended BIOS Data Area
- 8B Test and initialize PS/2 mouse
- 8C Initialize floppy controller
- 8F Determine number of ATA drives (optional)
- 90 Initialize hard-disk controllers
- 91 Initialize local-bus harddisk controllers
- 92 Jump to UserPatch2
- 93 Build MPTABLE for multi-processor boards
- 95 Install CD ROM for boot
- 96 Clear huge ES segment register
- 97 Fixup Multi Processor table
- 98 (1-2) Search for option ROMs. One long, two short beeps on checksum failure
- 99 Check for SMART Drive (optional)
- 9A Shadow option ROMs
- 9C Set up Power Management
- 9D Initialize security engine (optional)
- 9E Enable hardware interrupts
- 9F Determine number of ATA and SCSI drives
- A0 Set time of day
- A2 Check key lock
- A4 Initialize Typematic rate
- A8 Erase F2 prompt
- AA Scan for F2 key stroke
- AC Enter SETUP
- AE Clear Boot flag
- B0 Check for errors
- B2 POST done - prepare to boot operating system
- B4 (1) One short beep before boot
- B5 Terminate QuietBoot (optional)
- B6 Check password (optional)
- B9 Prepare Boot
- BA Initialize DMI parameters
- BB Initialize PnP Option ROMs
- BC Clear parity checkers
- BD Display MultiBoot menu
- BE Clear screen (optional)
- BF Check virus and backup reminders
- C0 Try to boot with INT 19
- C1 Initialize POST Error Manager (PEM)
- C2 Initialize error logging
- C3 Initialize error display function
- C4 Initialize system error handler
- C5 PnPnd dual CMOS (optional)
- C6 Initialize notebook docking (optional)
- C7 Initialize notebook docking late
- D2 Unknown interrupt
- E0 Initialize the chipset
- E1 Initialize the bridge
- E2 Initialize the CPU
- E3 Initialize system timer
- E4 Initialize system I/O
- E5 Check force recovery boot
- E6 Checksum BIOS ROM
- E7 Go to BIOS
- E8 Set Huge Segment
- E9 Initialize Multi Processor
- EA Initialize OEM special code
- EB Initialize PIC and DMA
- EC Initialize Memory type
- ED Initialize Memory size
- EE Shadow Boot Block
- EF System memory test
- F0 Initialize interrupt vectors
- F1 Initialize Real Time Clock
- F2 Initialize video
- F3 Initialize System Management Mode
- F4 (1) Output one beep before boot
- F5 Boot to Mini DOS
- F6 Clear Huge Segment
- F7 Boot to Full DOS
Error Message | Description |
|
System is booting properly |
||
BIOS ROM checksum error | The contents of the BIOS ROM to not match the expected contents. If possible, reload the BIOS from the PAQ |
|
Check the video adapter and ensure it"s seated properly. If possible, replace the video adapter |
||
7 beeps (1 long, 1s, 1l, 1 short, pause, 1 long, 1 short, 1 short) | The AGP video card is faulty. Reseat the card or replace it outright. This beep pertains to Compaq Deskpro systems |
|
1 long neverending beep | Memory error. Bad RAM. Replace and test | |
Reseat RAM then retest; replace RAM if failure continues |
Error Message | Description |
|
System is booting properly |
||
Initialization error | Error code is displayed |
|
System board error | ||
Video adapter error | ||
EGA/VGA adapter error | ||
3270 keyboard adapter error | ||
Power supply error | Replace the power supply |
|
Power supply error | Replace the power supply |
|
Replace the power supply |
Beeps/Error | Description |
Continuous beeping | System board failure |
One beep; Unreadable, blank or flashing LCD | LCD connector problem; LCD backlight inverter failure; video adapter faulty; LCD assembly faulty; System board failure; power supply failure |
One beep; Message "Unable to access boot source" | Boot device failure; system board failure |
One long, two short beeps | System board failure; Video adapter problem; LCD assembly failure |
One long, four short beeps | Low battery voltage |
One beep every second | Low battery voltage |
Two short beeps with error codes | POST error message |
System board failure |
IBM Intellistation BIOS:
Beep error code: | Action / Run diagnosics on the following components: |
1-1-3 CMOS read/write error | 1. Run Setup 2. System Board |
1-1-4 ROM BIOS check error | 1. System Board |
1-2-X DMA error | 1. System Board |
1-3-X | 1. Memory Module 2. System Board |
1-4-4 | 1. Keyboard 2. System Board |
1-4-X Error detected in first 64 KB of RAM. | 1. Memory Module 2. System Board |
2-1-1, 2-1-2 | 1. Run Setup 2. System Board |
2-1-X First 64 KB of RAM failed. | 1. Memory Module 2. System Board |
2-2-2 | 2. System Board |
2-2-X First 64 KB of RAM failed. | 1. Memory Module 2. System Board |
2-3-X | 1. Memory Module 2. System Board |
2-4-X | 1. Run Setup 2. Memory Module 3. System Board |
3-1-X DMA register failed. | 1. System Board |
3-2-4 Keyboard controller failed. | 1. System Board 2. Keyboard |
3-3-4 Screen initialization failed. | 1. Video Adapter (if installed) 2. System Board 3. Display |
3-4-1 Screen retrace lest detected an error. | 1. Video Adapter (if installed) 2. System Board 3. Display |
3-4-2 POST is searching for video ROM. | 1. Video Adapter (if installed) 2. System Board |
4 | 1. Video Adapter (if installed) 2. System Board |
All other beep code sequences. | 1. System Board |
One long and one short beep during POST. Base 640 KB memory error or shadow RAM error. | 1. Memory Module 2. System Board |
One long beep and two or three short beeps during POST.(Video error) | 1. Video Adapter (if installed) 2. System Board |
Three short beeps during POST. | 1. See "System board memory" on page 62. 2. System Board |
Continuous beep. | 1. System Board |
Repeating short beeps. | 1. Keyboard stuck key? 2. Keyboard Cable 3. System Board |
Error Message | Description |
|
System is booting normally |
||
Video adapter error | The video adapter is either faulty or not seated properly. Check the adapter |
|
Keyboard controller error | The keyboard controller IC is faulty. Replace the IC if possible |
|
The keyboard controller IC is faulty or the keyboard is faulty. Replace the keyboard, if problem still persists, replace the keyboard controller IC |
||
The programmable interrupt controller is faulty. Replace the IC if possible |
||
The programmable interrupt controller is faulty. replace the IC if possible |
||
DMA page register error | The DMA controller IC is faulty. Replace the IC if possible |
|
RAM refresh error | ||
RAM parity error | ||
DMA controller 0 error | The DMA controller IC for channel 0 has failed |
|
The CMOS RAM has failed |
||
DMA controller 1 error | The DMA controller IC for channel 1 has failed |
|
CMOS RAM battery error | The CMOS RAM battery has failed. If possible, replace the CMOS or battery |
|
CMOS RAM checksum error | The CMOS RAM has failed. If possible, replace the CMOS |
|
BIOS ROM checksum error | The BIOS ROM has failed. If possible replace the BIOS or upgrade it |
Error Message | Description |
|
System is booting normally |
||
Video adapter failure | Either the video adapter is faulty, not seated properly or is missing |
|
1 long, 1 short, 1 long | Keyboard controller error | Either the keyboard controller IC is faulty or the system board circuitry is faulty |
1 long, 2 short, 1 long | Either the keyboard controller is faulty or the system board circuitry is faulty |
|
1 long, 3 short, 1 long | ||
1 long 4 short, 1 long | The programmable interrupt controller IC is faulty |
|
1 long, 5 short, 1 long | DMA page register error | The DMA controller IC 1 or 2 is faulty or the system board circuitry is faulty |
1 long, 6 short, 1 long | RAM refresh error | |
1 long, 7 short, 1 long | ||
1 long, 8 short, 1 long | RAM parity error |
|
1 long, 9 short, 1 long | DMA controller 1 error | The DMA controller for channel 0 is faulty or the system board circuitry is faulty |
1 long, 10 short, 1 long | Either the CMOS RAM is faulty. Replace the CMOS |
|
1 long, 11 short, 1 long | DMA controller 2 error | The DMA controller for channel 1 is faulty or the system board circuitry is faulty |
1 long, 12 short, 1 long | CMOS RAM battery error | The CMOS RAM battery is faulty or the CMOS RAM is bad. Replace the battery if possible |
1 long, 13 short, 1 long | CMOS checksum error | The CMOS RAM is faulty |
1 long 14 short, 1 long | BIOS ROM checksum failure | The BIOS ROM checksum is faulty. Replace the BIOS or upgrade |
Phoenix ISA/MCA/EISA BIOS:
The beep codes are represented in the number of beeps. E.g. 1-1-2 would mean 1 beep, a pause, 1 beep, a pause, and 2 beeps.
- With a Dell computer, a 1-2 beep code can also indicate that a bootable add-in card is installed but no boot device is attached. For example, in you insert a Promise Ultra-66 card but do not connect a hard drive to it, you will get the beep code. I verified this with a SIIG (crap -- avoid like the plague) Ultra-66 card, and then confirmed the results with Dell.
Error Message | Description |
|
CPU test failure | The CPU is faulty. Replace the CPU |
|
System board select failure | The motherboard is having an undetermined fault. Replace the motherboard |
|
CMOS read/write error | The real time clock/CMOS is faulty. Replace the CMOS if possible |
|
Extended CMOS RAM failure | The extended portion of the CMOS RAM has failed. Replace the CMOS if possible |
|
BIOS ROM checksum error | The BIOS ROM has failed. Replace the BIOS or upgrade if possible |
|
The programmable interrupt timer has failed. Replace if possible |
||
DMA read/write failure | The DMA controller has failed. Replace the IC if possible |
|
RAM refresh failure | The RAM refresh controller has failed |
|
64KB RAM failure | The test of the first 64KB RAM has failed to start |
|
First 64KB RAM failure | The first RAM IC has failed. Replace the IC if possible |
|
First 64KB logic failure | The first RAM control logic has failed |
|
Address line failure | The address line to the first 64KB RAM has failed |
|
Parity RAM failure | The first RAM IC has failed. Replace if possible |
|
EISA fail-safe timer test | Replace the motherboard |
|
EISA NMI port 462 test | Replace the motherboard |
|
64KB RAM failure | Bit 0; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 1; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 2; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 3; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 4; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 5; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 6; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 7; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 8; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 9; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 10; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 11; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 12; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 13; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 14; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
64KB RAM failure | Bit 15; This data bit on the first RAM IC has failed. Replace the IC if possible |
|
Slave DMA register failure | The DMA controller has failed. Replace the controller if possible |
|
Master DMA register failure | The DMA controller had failed. Replace the controller if possible |
|
Master interrupt mask register failure | ||
Slave interrupt mask register failure | The interrupt controller IC has failed |
|
Interrupt vector error | The BIOS was unable to load the interrupt vectors into memory. Replace the motherboard |
|
Keyboard controller failure | ||
CMOS RAM power bad | Replace the CMOS battery or CMOS RAM if possible |
|
CMOS configuration error | The CMOS configuration has failed. Restore the configuration or replace the battery if possible |
|
Video memory failure | There is a problem with the video memory. Replace the video adapter if possible |
|
Video initialization failure | There is a problem with the video adapter. Reseat the adapter or replace the adapter if possible |
|
The system"s timer IC has failed. Replace the IC if possible |
||
Shutdown failure | The CMOS has failed. Replace the CMOS IC if possible |
|
Gate A20 failure | The keyboard controller has failed. Replace the IC if possible |
|
Unexpected interrupt in protected mode | This is a CPU problem. Replace the CPU and retest |
|
RAM test failure | System RAM addressing circuitry is faulty. Replace the motherboard |
|
Interval timer channel 2 failure | The system timer IC has failed. Replace the IC if possible |
|
Time of day clock failure | The real time clock/CMOS has failed. Replace the CMOS if possible |
|
Serial port failure | A error has occurred in the serial port circuitry |
|
Parallel port failure | A error has occurred in the parallel port circuitry |
|
Math coprocessor failure | The math coprocessor has failed. If possible, replace the MPU |
Description |
|
Verify real mode |
|
Initialize system hardware |
|
Initialize chipset registers with initial values |
|
Set in POST flag |
|
Initialize CPU registers |
|
Initialize cache to initial values |
|
Initialize power management |
|
Load alternative registers with initial POST values |
|
Jump to UserPatch0 |
|
Initialize timer initialization |
|
8254 timer initialization |
|
8237 DMA controller initialization |
|
Reset Programmable Interrupt Controller |
|
Test DRAM refresh |
|
Test 8742 Keyboard Controller |
|
Set ES segment register to 4GB |
|
Clear 512K base memory |
|
Test 512K base address lines |
|
Test 51K base memory |
|
Test CPU bus-clock frequency |
|
CMOS RAM read/write failure (this commonly indicates a problem on the ISA bus such as a card not seated) |
|
Reinitialize the chipset |
|
Shadow system BIOS ROM |
|
Reinitialize the cache |
|
Autosize the cache |
|
Configure advanced chipset registers |
|
Load alternate registers with CMOS values |
|
Set initial CPU speed |
|
Initialize interrupt vectors |
|
Initialize BIOS interrupts |
|
Check ROM copyright notice |
|
Initialize manager for PCI Options ROMs |
|
Check video configuration against CMOS |
|
Initialize PCI bus and devices |
|
initialize all video adapters in system |
|
Shadow video BIOS ROM |
|
Display copyright notice |
|
Display CPU type and speed |
|
Set key click if enabled |
|
Test for unexpected interrupts |
|
Display prompt "Press F2 to enter setup" |
|
Test RAM between 512K and 640K |
|
Test expanded memory |
|
Test extended memory address lines |
|
Jump to UserPatch1 |
|
Configure advanced cache registers |
|
Enable external and CPU caches |
|
Initialize SMI handler |
|
Display external cache size |
|
Display shadow message |
|
Display non-disposable segments |
|
Display error messages |
|
Check for configuration errors |
|
Test real-time clock |
|
Check for keyboard errors |
|
Setup hardware interrupt vectors |
|
Test coprocessor if present |
|
Disable onboard I/O ports |
|
Detect and install external RS232 ports |
|
Detect and install external parallel ports |
|
Reinitialize onboard I/O ports |
|
Initialize BIOS Data Area |
|
Initialize Extended BIOS Data Area |
|
Initialize floppy controller |
|
Initialize hard disk controller |
|
Initialize local bus hard disk controller |
|
Jump to UserPatch2 |
|
Disable A20 address line |
|
Clear huge ES segment register |
|
Search for option ROMs |
|
Shadow option ROMs |
|
Setup power management |
|
Enable hardware interrupts |
|
Scan for F2 keystroke |
|
Clear in-POST flag |
|
Check for errors |
|
POST done - prepare to boot operating system |
|
Check password (optional) |
|
Clear global descriptor table |
|
Clear parity checkers |
|
Check virus and backup reminders |
|
Try to boot with INT 19 |
|
Interrupt handler error |
|
Unknown interrupt error |
|
Pending interrupt error |
|
Initialize option ROM error |
|
Extended Block Move |
|
Shutdown 10 error |
|
Keyboard Controller failure (most likely problem is with RAM or cache unless no video is present) |
|
Initialize the chipset |
|
Initialize refresh counter |
|
Check for Forced Flash |
|
Do a complete RAM test |
|
Do OEM initialization |
|
Initialize interrupt controller |
|
Read in bootstrap code |
|
Initialize all vectors |
|
Initialize the boot device |
|
Boot code was read OK |
Quadtel BIOS:
Error Messages | Description |
|
System is booting normally |
||
The CMOS RAM is faulty. Replace the IC if possible |
||
The video adapter is faulty. Reseat the video adapter or replace the adapter if possible |
||
Peripheral controller error | One or more of the system peripheral controllers is bad. Replace the controllers and retest |