Автор | Сообщение | |||
---|---|---|---|---|
|
||||
Последняя доступная версия для Windows: http://www.overclockers.ru/softnews/24022.shtml Последняя доступная версия для DOS: http://www.overclockers.ru/softnews/22601.shtml Последний раз редактировалось coxswain 26.06.2005 14:55, всего редактировалось 1 раз. |
Реклама | |
Партнер |
revenant |
|
Member Статус: Не в сети |
gHosTer писал(а): KoDAkchek через API, понятное дело. |
PNC |
|
Member Статус: Не в сети |
Что то под вистой программа зависает, в трее иконка и все больше ничего не происходит… ? |
N’drew |
|
Member Статус: Не в сети |
Скажите в чем проблема, при попытке определить RPM винтов любого из 3х саташных, пишет Disable cache… Error, process terminated |
N’drew |
|
Member Статус: Не в сети |
Что, ни у кого нет такого? |
Dr.LEX |
|
Member Статус: Не в сети |
Доброго времени суток. |
Zelgadies |
|
Junior Статус: Не в сети |
Здравствуйте! |
cthutq99 |
|
Junior Статус: Не в сети |
можно толко меньшив время здержки и заремапив их. |
QNX |
|
Advanced member Статус: Не в сети |
Zelgadies это уже труп с такими то задержками, только на свалку, либо изолировать область диска поврежденную, но это все равно ненадолго и только если проблемы ближе к началу или концу диска |
Ганеев |
|
вопрос: а можно ли программой Victoria — проверить одноверемнно несколько САТА винтов? |
Бам-Бам |
|
Заблокирован Статус: Не в сети |
Тестировал свой хард с помощью Victoria 3.5: Defectoscop v1.1 Обнаружилось очень много бэдов, именно бедов. Раза 3 прогнал — все на одном и том же месте. Как это можно обьяснить? Проблема еще и в том, что в СЦ не хотят вернуть мне деньги за хард потому что они так же тестируют пустой жесткий диск и у них соответственно виктория ничего не находит. |
Ханыга |
|
Member Статус: В сети |
Какая-то древняя программа, рейд не видит. |
Старший |
|
Junior Статус: Не в сети |
добрый день! Так случилось, что уронил внешний диск Seagate FreeAgent Go (500Гб) в метро на эскалатор с высоты немного выше уровня живота, в момент удара раздался аццкий грохот :]] принес его домой, подключил- все работает как и раньше (хоть в этом повезло) просканил его Викторией, результаты прилагаю, диску ~ года 2. http://s58…radikal.ru/i161/1004/44/6e00acb79f09.png [/img] http://s53…radikal.ru/i140/1004/d6/184141e625c4.png [/img] http://s001…radikal.ru/i196/1004/a5/e7b8baf926ae.png [/img] |
moty |
|
Member Статус: Не в сети |
Старший Ну что, некоторые сектора вообще убились, их оно переназначило, некоторые просто повредились… Короче, ожидайте смерти винта. |
_tonis |
|
Member Статус: Не в сети |
Бам-Бам Некропост, но всё же. Покажите S.M.A.R.T. винчестера. Либо там куча переназначенных секторов (reallocated sectors), либо я ничего не понимаю. |
XIce |
|
Member Статус: Не в сети |
Подскажите плиз. Есть Victoria 4.3 под винду и IDE винт Seagate 120gb(чистый, без инфы). Как проверить его перед продажей(какие настройки, значения и прч.)??? |
Svirik |
|
Народ как включить режим дефектоскопа в пункте меню работы с BAD блоками. |
k@mikadze |
|
Member Статус: Не в сети |
Блин по вин7 х64 не работает, есть какая нибудь альтернатива ? |
uot |
|
Member Статус: Не в сети |
Добрый вечер. В одной из тем мне посоветовали программу Victoria для проверки 16 Гб флешки. Вопрос — правильно ли тестировать флешку этой программой и корректно ли она работает с флешкой размером 16 Гб. Получил вот такой результат http://s013..radikal.ru/i323/1012/c3/06ef1cae9191.png, |
Bullettime |
|
Заблокирован Статус: Не в сети |
На жестком диске Hitachi, при проверке дефектоскопом, 350-400 красных блоков с задержкой > 1.5 сек |
—
Кто сейчас на конференции |
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 9 |
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения |
Лаборатория
Новости
На чтение 6 мин. Просмотров 473 Опубликовано 03.09.2019
Содержание
- Как избавиться от ошибки STATUS SYSTEM PROCESS TERMINATED на Windows 10 ноутбуках/ПК?
- Как исправить ошибку STATUS_SYSTEM_PROCESS_TERMINATED
- Решение 1. Загрузите последние обновления для Windows 10
- Решение 2. Обновите драйверы
- Решение 3. Удалите антивирус
- Решение 4. Войдите в безопасный режим и удалите проблемные приложения.
- Решение 5 – Сброс Windows 10
- Решение 6 – Найти и заменить неисправное оборудование
- Решение 7. Проверьте жесткий диск на наличие ошибок
Как избавиться от ошибки STATUS SYSTEM PROCESS TERMINATED на Windows 10 ноутбуках/ПК?
- Загрузите последние обновления для Windows 10
- Обновите драйверы
- Удалите антивирусное программное обеспечение
- Войдите в безопасный режим и удалите проблемные приложения
- Сброс Windows 10
- Найдите и замените неисправное оборудование
- Проверьте жесткий диск на наличие ошибок
Ошибки Blue Screen of Death иногда могут быть довольно проблематичными, поэтому важно знать, как их исправить. Ошибки, такие как STATUS_SYSTEM_PROCESS_TERMINATED, могут быть серьезными, поэтому сегодня мы собираемся показать вам, как исправить эту ошибку в Windows 10.
Как исправить ошибку STATUS_SYSTEM_PROCESS_TERMINATED
Решение 1. Загрузите последние обновления для Windows 10
Как и многие другие операционные системы, Windows 10 имеет некоторые проблемы с определенным аппаратным и программным обеспечением. Обычно программное или аппаратное обеспечение не полностью совместимо с Windows 10, что иногда может привести к ошибке STATUS_SYSTEM_PROCESS_TERMINATED.
Чтобы исправить эту и многие другие ошибки Blue Screen of Death, рекомендуется использовать Центр обновления Windows для загрузки последних исправлений Windows 10. Microsoft часто выпускает новые исправления, и многие из этих исправлений обеспечивают повышенную безопасность наряду с различными исправлениями ошибок, связанных как с аппаратным, так и программным обеспечением. Если вы хотите, чтобы ваш компьютер был стабильным и не содержал ошибок, мы настоятельно рекомендуем вам часто загружать последние обновления Windows.
Решение 2. Обновите драйверы
Чтобы ваше оборудование работало с вашей операционной системой, вам необходимо установить соответствующие драйверы. Если ваши драйверы устарели или содержат определенные ошибки, вы не сможете их использовать, и вы можете получить STATUS_SYSTEM_PROCESS_TERMINATED или любую другую ошибку Blue Screen of Death. Чтобы решить эту проблему, рекомендуется найти и обновить проблемный драйвер. Если вы не можете найти проблемный драйвер, мы советуем обновить драйверы для всех основных компонентов, таких как материнская плата, чипсет, сетевой адаптер и т. Д. Обязательно обновите столько драйверов, сколько сможете, чтобы решить эту проблему.
Обновление драйверов довольно просто, и вы можете сделать это, посетив веб-сайт производителя оборудования и загрузив последние версии драйверов для вашего устройства. Как мы уже упоминали, вам может потребоваться обновить все драйверы на вашем компьютере, чтобы исправить эту ошибку.
Обновление всех ваших драйверов иногда может занять некоторое время, особенно потому, что вам нужно найти и загрузить их один за другим. Если вы хотите быстро обновить все ваши драйверы, вы можете использовать это программное обеспечение для обновления драйверов, которое загружает все необходимые драйверы одним щелчком мыши.
- ЧИТАЙТЕ ТАКЖЕ: исправлено: ошибка BUGCODE_ID_DRIVER в Windows 10
Решение 3. Удалите антивирус
Наличие антивирусного программного обеспечения важно для вашей безопасности, но иногда ваш антивирус может вызывать STATUS_SYSTEM_PROCESS_TERMINATED и другие ошибки Blue Screen of Death. Чтобы исправить эту ошибку, вам может потребоваться временно удалить все антивирусные программы с вашего компьютера. Помните, что Windows 10 поставляется с Защитником Windows, который работает в качестве антивирусной программы по умолчанию, поэтому даже если вы удалите все сторонние антивирусные программы, ваш компьютер не будет полностью незащищенным.
Мы должны отметить, что удаление антивирусной программы может не исправить эту ошибку, поскольку антивирусные программы, как правило, оставляют определенные файлы и записи реестра после их удаления, и иногда эти файлы также могут вызывать ошибку BSoD. Чтобы полностью удалить все файлы, связанные с вашим антивирусным программным обеспечением, мы настоятельно рекомендуем вам загрузить специальный инструмент для удаления. Многие антивирусные компании имеют эти инструменты, доступные для скачивания, поэтому обязательно скачайте одну для вас антивирусную программу.
Решение 4. Войдите в безопасный режим и удалите проблемные приложения.
Иногда ошибки BSoD вызваны сторонними приложениями, и единственное решение – найти и удалить проблемное приложение. Чтобы определить, вызывает ли программное обеспечение ошибку STATUS_SYSTEM_PROCESS_TERMINATED, рекомендуется перейти в безопасный режим. Чтобы войти в безопасный режим, вам необходимо сделать следующее:
-
Перезагрузите компьютер несколько раз во время загрузки, чтобы запустить автоматическое восстановление. Кроме того, вы можете просто удерживать клавишу Shift на клавиатуре и нажимать кнопку Перезагрузить .
- Выберите Устранение неполадок> Дополнительные параметры> Параметры запуска и нажмите кнопку Перезагрузить .
- Когда ваш компьютер перезагрузится, вы увидите список параметров.Нажмите 5 или F5 , чтобы выбрать Безопасный режим с поддержкой сети .
- ЧИТАЙТЕ ТАКЖЕ: исправьте ошибку «Исключение системной службы» в Windows 10
Безопасный режим запускается только с приложениями и драйверами по умолчанию, поэтому, если проблема вызвана сторонним программным обеспечением или драйверами, у вас не должно возникнуть проблем в безопасном режиме. Если ваш компьютер стабилен в безопасном режиме, теперь вы можете использовать его для поиска и удаления проблемного программного обеспечения.
Решение 5 – Сброс Windows 10
Иногда вы просто не можете найти приложение, которое вызывает эту ошибку, поэтому рекомендуется выполнить сброс Windows 10. Для завершения этого процесса вам может понадобиться загрузочная флешка с Windows 10, но также рекомендуется создать резервную копию, так как этот процесс удалит все файлы с вашего диска C. Чтобы выполнить сброс Windows 10, выполните следующие действия:
- Перезагрузите компьютер несколько раз во время загрузки, чтобы запустить автоматическое восстановление.
- Выберите Устранение неполадок> Перезагрузить этот компьютер> Удалить все . Для выполнения этого шага вам может понадобиться вставить установочный носитель Windows 10, поэтому будьте готовы к этому.
- Выберите Только диск, на котором установлена Windows> Просто удалите мои файлы и нажмите кнопку Сбросить .
- Следуйте инструкциям для завершения сброса.
После завершения сброса Windows 10 не устанавливайте какое-либо программное обеспечение или драйверы, вместо этого протестируйте компьютер некоторое время. Если ошибка BSoD появляется снова, это означает, что она вызвана вашим оборудованием.
Решение 6 – Найти и заменить неисправное оборудование
Иногда ошибка STATUS_SYSTEM_PROCESS_TERMINATED может быть вызвана недавно установленным оборудованием, особенно если это оборудование не полностью совместимо с вашим ПК. Если вы установили какое-либо новое оборудование, обязательно удалите его или замените и проверьте, устраняет ли это проблему. Если ошибка не устранена, мы предлагаем вам выполнить детальную проверку оборудования и заменить неисправное оборудование.
Решение 7. Проверьте жесткий диск на наличие ошибок
Вы также можете использовать другую простую манипуляцию со своего ПК, которая проверит ваш жесткий диск на наличие ошибок. Вот что вам нужно сделать:
- На клавиатуре нажмите «Windows»
- В окне поиска нажмите «cmd»
- В результатах вы увидите «Командная строка». Щелкните правой кнопкой мыши на нем и выберите «Запуск от имени администратора».
- В окне командной строки нажмите, введите следующую команду: ‘ chkdsk/f/r C: ‘ (C – буква драйвера для сканирования. Измените его на нужный водитель) п>
Вот. Попробуйте и дайте нам знать, как вам удалось решить эту проблему.
Ошибка STATUS_SYSTEM_PROCESS_TERMINATED может быть проблематичной, но пользователи сообщили, что исправили ее, обновив Windows 10 или выполнив сброс Windows 10. Если эти решения не работают для вас, не стесняйтесь попробовать любое другое решение из этой статьи.
ЧИТАЙТЕ ТАКЖЕ
- Исправлено: код ошибки 0x80070032 в Windows 10 Mail
- Исправлено: Microsoft Edge не открывается
- ИСПРАВЛЕНИЕ: «Доступ запрещен» при редактировании файла hosts в Windows 10
- Исправлено: ошибка Winload.efi не дает пользователям сбросить или обновить мой компьютер
- Исправьте ошибки PAGE_FAULT_IN_NONPAGED_AREA в Windows 10
Hello
I have set up on Oracle Linux 7.9. This issue seems to persist continuosly in microsoft_defender_enterprise_err.log file
[4131][2022-08-08 12:00:01.865959 UTC][error]: ProcessCache: Collision on attempt to retire process to terminated cache, errorCode:2, newly terminated:[1, 0, 0] "systemd", 1st collision:[1, 0, 0] "systemd"
[4131][2022-08-08 12:00:01.950638 UTC][error]: {"code":{"category":"generic","value":38,"message":"Function not implemented"},"call_stack":{"frames":[{"file":"machineutils.cpp","line":291}]},"context":[]}
[4131][2022-08-08 12:00:02.011652 UTC][error]: ProcessCache: Collision on attempt to retire process to terminated cache, errorCode:2, newly terminated:[2, 0, 0] "kthreadd", 1st collision:[2, 0, 0] "kthreadd"
$ mdatp health
healthy : true
health_issues : []
licensed : true
engine_version : "1.1.19400.3"
app_version : "101.75.43"
org_id : "e4b1bd4a-b6c9-4043-b658-3f34164d269e"
log_level : "info"
machine_guid : "f8cbd045-993e-7c42-afe6-89d0a3fcb522"
release_ring : "Production"
product_expiration : Apr 15, 2023 at 05:45:15 AM
cloud_enabled : true
cloud_automatic_sample_submission_consent : "safe"
cloud_diagnostic_enabled : true
passive_mode_enabled : false
real_time_protection_enabled : true
real_time_protection_available : true
real_time_protection_subsystem : "fanotify"
supplementary_events_subsystem : "auditd"
tamper_protection : "disabled"
automatic_definition_update_enabled : true
definitions_updated : Aug 11, 2022 at 08:15:14 AM
definitions_updated_minutes_ago : 249
definitions_version : "1.373.131.0"
definitions_status : "up_to_date"
edr_early_preview_enabled : "enabled"
edr_device_tags : [{"key":"AzureResourceId","value":"/subscriptions/3861848d-c216-47d0-986c-4ff438b8ef25/resourceGroups/Linux_Endpoints/providers/Microsoft.Compute/virtualMachines/OracleLinux2"},{"key":"SecurityWorkspaceId","value":"3861848d-c216-47d0-986c-4ff438b8ef25"}]
edr_group_ids : ""
edr_configuration_version : "30.199999.7676430.5582739.6176165-d66675e5729d743986bacf9507a9f225a932b60e"
edr_machine_id : "8c977933a29fc8664535af79aec88daae73a44b3"
conflicting_applications : []
network_protection_status : "stopped"
network_protection_enforcement_level : "audit"
Managing the behavior of Caché when an error occurs is called error processing or error handling. Error processing performs one or more of the following functions:
-
Correcting the condition that caused the error
-
Performing some action that allows execution to resume despite the error
-
Diverting the flow of execution
-
Logging information about the error
Caché supports three types of error processing, which can be used simultaneously. These are:
-
The TRY-CATCH mechanism
-
%Status error code processing
-
Traditional error processing ($ZTRAP and $ETRAP)
Important:
The preferred mechanism for ObjectScript error handling is the TRY-CATCH mechanism. If traditional error processing is to be used, the $ZTRAP mechanism is preferred. Use of $ETRAP is discouraged.
The TRY-CATCH Mechanism
Caché supports a TRY—CATCH mechanism for handling errors. With this mechanism, you can establish delimited blocks of code, each called a TRY block; if an error occurs during a TRY block, control passes to the TRY block’s associated CATCH block, which contains code for handling the exception. A TRY block can also include THROW commands; each of these commands explicitly issues an exception from within a TRY block and transfers execution to a CATCH block.
To use this mechanism in its most basic form, include a TRY block within ObjectScript code. If an exception occurs within this block, the code within the associated CATCH block is then executed. The form of a TRY—CATCH block is:
TRY {
protected statements
} CATCH [ErrorHandle] {
error statements
}
further statements
where:
-
The TRY command identifies a block of ObjectScript code statements enclosed in curly braces. TRY takes no arguments. This block of code is protected code for structured exception handling. If an exception occurs within a TRY block, Caché sets the exception properties (oref.Name, oref.Code, oref.Data, and oref.Location), $ZERROR, and $ECODE, then transfers execution to an exception handler, identified by the CATCH command. This is known as throwing an exception.
-
The protected statements are ObjectScript statements that are part of normal execution. (These can include calls to the THROW command. This scenario is described in the following section.)
-
The CATCH command defines an exception handler, which is a block of code to execute when an exception occurs in a TRY block.
-
The ErrorHandle variable is a handle to an exception object. This can be either an exception object that Caché has generated in response to a runtime error or an exception object explicitly issued by invoking the THROW command (described in the next section).
-
The error statements are ObjectScript statements that are invoked if there is an exception.
-
The further statements are ObjectScript statements that either follow execution of the protected statements if there is no exception or follow execution of the error statements if there is an exception and control passes out of the CATCH block.
Depending on events during execution of the protected statements, one of the following events occurs:
-
If an error does not occur, execution continues with the further statements that appear outside the CATCH block.
-
If an error does occur, control passes into the CATCH block and error statements are executed. Execution then depends on contents of the CATCH block:
-
If the CATCH block contains a THROW or GOTO command, control goes directly to the specified location.
-
If the CATCH block does not contain a THROW or GOTO command, control passes out of the CATCH block and execution continues with the further statements.
-
Using THROW with TRY-CATCH
Caché issues an implicit exception when a runtime error occurs. To issue an explicit exception, the THROW command is available. The THROW command transfers execution from the TRY block to the CATCH exception handler. The THROW command has a syntax of:
where expression is an instance of a class that inherits from the %Exception.AbstractExceptionOpens in a new tab class, which Caché provides for exception handling. For more information on %Exception.AbstractExceptionOpens in a new tab, see the following section.
The form of the TRY/CATCH block with a THROW is:
TRY {
protected statements
THROW expression
protected statements
}
CATCH exception {
error statements
}
further statements
where the THROW command explicitly issues an exception. The other elements of the TRY—CATCH block are as described in the previous section.
The effects of THROW depends on where the throw occurs and the argument of THROW:
-
A THROW within a TRY block passes control to the CATCH block.
-
A THROW within a CATCH block passes control up the execution stack to the next error handler. If the exception is a %Exception.SystemException object, the next error handler can be any type (CATCH or traditional); otherwise there must be a CATCH to handle the exception or a <NOCATCH> error will be thrown.
If control passes into a CATCH block because of a THROW with an argument, the ErrorHandle contains the value from the argument. If control passes into a CATCH block because of a system error, the ErrorHandle is a %Exception.SystemExceptionOpens in a new tab object. If no ErrorHandle is specified, there is no indication of why control has passed into the CATCH block.
For example, suppose there is code to divide two numbers:
div(num,div) public {
TRY {
SET ans=num/div
} CATCH errobj {
IF errobj.Name="<DIVIDE>" { SET ans=0 }
ELSE { THROW errobj }
}
QUIT ans
}
If a divide-by-zero error happens, the code is specifically designed to return zero as the result. For any other error, the THROW sends the error on up the stack to the next error handler.
Using $$$ThrowOnError and $$$ThrowStatus Macros
Caché provides macros for use with exception handling. When invoked, these macros throw an exception object to the CATCH block.
The following example invokes the $$$ThrowOnError() macro when an error status is returned by the %Prepare() method:
#include %occStatus
ZNSPACE "SAMPLES"
TRY {
SET myquery = "SELECT TOP 5 Name,Hipness,DOB FROM Sample.Person"
SET tStatement = ##class(%SQL.Statement).%New()
SET status = tStatement.%Prepare(myquery)
$$$ThrowOnError(status)
WRITE "%Prepare succeeded",!
RETURN
}
CATCH sc {
WRITE "In Catch block",!
WRITE "error code: ",sc.Code,!
WRITE "error location: ",sc.Location,!
WRITE "error data:",$LISTGET(sc.Data,2),!
RETURN
}
The following example invokes $$$ThrowStatus after testing the value of the error status returned by the %Prepare() method:
#include %occStatus
ZNSPACE "SAMPLES"
TRY {
SET myquery = "SELECT TOP 5 Name,Hipness,DOB FROM Sample.Person"
SET tStatement = ##class(%SQL.Statement).%New()
SET status = tStatement.%Prepare(myquery)
IF ($System.Status.IsError(status)) {
WRITE "%Prepare failed",!
$$$ThrowStatus(status) }
ELSE {WRITE "%Prepare succeeded",!
RETURN }
}
CATCH sc {
WRITE "In Catch block",!
WRITE "error code: ",sc.Code,!
WRITE "error location: ",sc.Location,!
WRITE "error data:",$LISTGET(sc.Data,2),!
RETURN
}
These system-supplied macros are further described in the “ObjectScript Macros and the Macro Preprocessor” chapter of this book.
Using the %Exception.SystemException and %Exception.AbstractException Classes
Caché provides the %Exception.SystemExceptionOpens in a new tab and %Exception.AbstractExceptionOpens in a new tab classes for use with exception handling. %Exception.SystemExceptionOpens in a new tab inherits from the %Exception.AbstractExceptionOpens in a new tab class and is used for system errors. For custom errors, create a class that inherits from %Exception.AbstractExceptionOpens in a new tab. %Exception.AbstractExceptionOpens in a new tab contains properties such as the name of the error and the location at which it occurred.
When a system error is caught within a TRY block, the system creates a new instance of the %Exception.SystemExceptionOpens in a new tab class and places error information in that instance. When throwing a custom exception, the application programmer is responsible for populating the object with error information.
An exception object has the following properties:
-
Name — The error name, such as <UNDEFINED>
-
Code — The error number
-
Location — The label+offset^routine location of the error
-
Data — Any extra data reported by the error, such as the name of the item causing the error
Other Considerations with TRY-CATCH
The following describe conditions that may arise when using a TRY—CATCH block.
QUIT within a TRY-CATCH Block
A QUIT command within a TRY or CATCH block passes control out of the block to the next statement after the TRY—CATCH as a whole.
TRY-CATCH and the Execution Stack
The TRY block does not introduce a new level in the execution stack. This means that it is not a scope boundary for NEW commands. The error statements execute at the same level as that of the error. This can result in unexpected results if there are DO commands within the protected statements and the DO target is also within the protected statements. In such cases, the $ESTACK special variable can provide information about the relative execution levels.
Using TRY-CATCH with Traditional Error Processing
TRY—CATCH error processing is compatible with $ZTRAP and $ETRAP error traps used at different levels in the execution stack. The exception is that $ZTRAP and $ETRAP may not be used within the protected statements of a TRY clause. User-defined errors with a THROW are limited to TRY—CATCH only. User-defined errors with the ZTRAP command may be used with any type of error processing.
%Status Error Processing
Many of the methods in the Caché class library return success or failure information via the %StatusOpens in a new tab data type. For example, the %Save() method, used to save an instance of a %PersistentOpens in a new tab object, returns a %StatusOpens in a new tab value indicating whether or not the object was saved.
-
Successful method execution returns a %StatusOpens in a new tab of 1.
-
Failed method execution returns %StatusOpens in a new tab as an encoded string containing the error status and one or more error codes and text messages. Status text messages are localized for the language of your locale.
You can use %SYSTEM.StatusOpens in a new tab class methods to inspect and manipulate %StatusOpens in a new tab values.
Caché provides several options for displaying (writing) the %StatusOpens in a new tab encoded string in different formats. For further details, refer to “Display (Write) Commands” in the “Commands” chapter of this manual.
In the following example, the %Prepare fails because of an error in the myquery text: “ZOP” should be “TOP”. This error is detected by the IsError()Opens in a new tab method, and other %SYSTEM.StatusOpens in a new tab methods display the error code and text:
ZNSPACE "SAMPLES"
SET myquery = "SELECT ZOP 5 Name,DOB FROM Sample.Person"
SET tStatement = ##class(%SQL.Statement).%New()
SET status = tStatement.%Prepare(myquery)
IF ($System.Status.IsError(status)) {
WRITE "%Prepare failed",!
DO StatusError() }
ELSE {WRITE "%Prepare succeeded",!
RETURN }
StatusError()
WRITE "Error #",$System.Status.GetErrorCodes(status),!
WRITE $System.Status.GetOneStatusText(status,1),!
WRITE "end of error display"
QUIT
The following example is the same as the previous, except that the status error is detected by the $$$ISERR() macro of the %occStatus include file. $$$ISERR() (and its inverse, $$$ISOK()) checks whether or not %StatusOpens in a new tab=1. The error code is returned by the $$$GETERRORCODE() macro:
#include %occStatus
ZNSPACE "SAMPLES"
SET myquery = "SELECT ZOP 5 Name,DOB FROM Sample.Person"
SET tStatement = ##class(%SQL.Statement).%New()
SET status = tStatement.%Prepare(myquery)
IF $$$ISERR(status) {
WRITE "%Prepare failed",!
DO StatusError() }
ELSE {WRITE "%Prepare succeeded",!
RETURN}
StatusError()
WRITE "Error #",$$$GETERRORCODE(status),!
WRITE $System.Status.GetOneStatusText(status,1),!
WRITE "end of error display"
QUIT
These system-supplied macros are further described in the “ObjectScript Macros and the Macro Preprocessor” chapter of this book.
Some methods, such as %New(), generate, but do not return a %StatusOpens in a new tab. %New() either returns an oref to an instance of the class upon success, or the null string upon failure. You can retrieve the status value for methods of this type by accessing the %objlasterror system variable, as shown in the following example.
SET session = ##class(%CSP.Session).%New()
IF session="" {
WRITE "session oref not created",!
WRITE "%New error is ",!,$System.Status.GetErrorText(%objlasterror),! }
ELSE {WRITE "session oref is ",session,! }
For more information, refer to the %SYSTEM.StatusOpens in a new tab class.
Creating %Status Errors
You can invoke system-defined %Status errors from your own methods by using the Error()Opens in a new tab method. You specify the error number that corresponds to the error message you wish to return.
WRITE "Here my method generates an error",!
SET status = $System.Status.Error(20)
WRITE $System.Status.GetErrorText(status),!
You can include %1, %2, and %3 parameters in the returned error message, as shown in the following example:
WRITE "Here my method generates an error",!
SET status = $System.Status.Error(214,"3","^fred","BedrockCode")
WRITE $System.Status.GetErrorText(status),!
You can localize the error message to display in your preferred language.
SET status = $System.Status.Error(30)
WRITE "In English:",!
WRITE $System.Status.GetOneStatusText(status,1,"en"),!
WRITE "In French:",!
WRITE $System.Status.GetOneStatusText(status,1,"fr"),!
For a list of error codes and messages (in English), refer to the “General Error Messages” chapter of the Caché Error Reference.
You can use the generic error codes 83 and 5001 to specify a custom message that does not correspond to any of the general error messages.
You can use the AppendStatus()Opens in a new tab method to create a list of multiple error messages. Then you can use GetOneErrorText()Opens in a new tab or GetOneStatusText()Opens in a new tab to retrieve individual error messages by their position in this list:
CreateCustomErrors
SET st1 = $System.Status.Error(83,"my unique error")
SET st2 = $System.Status.Error(5001,"my unique error")
SET allstatus = $System.Status.AppendStatus(st1,st2)
DisplayErrors
WRITE "All together:",!
WRITE $System.Status.GetErrorText(allstatus),!!
WRITE "One by one",!
WRITE "First error format:",!
WRITE $System.Status.GetOneStatusText(allstatus,1),!
WRITE "Second error format:",!
WRITE $System.Status.GetOneStatusText(allstatus,2),!
%SYSTEM.Error
The %SYSTEM.ErrorOpens in a new tab class is a generic error object. It can be created from a %Status error, from an exception object, a $ZERROR error, or an SQLCODE error. You can use %SYSTEM.ErrorOpens in a new tab class methods to convert a %Status to an exception, or to convert an exception to a %Status.
Traditional Error Processing
This section describes various aspects of traditional error processing with Caché. These include:
-
How Traditional Error Processing Works
-
Handing Errors with $ZTRAP
-
Handling Errors with $ETRAP
-
Handling Errors in an Error Handler
-
Forcing an Error
-
Processing Errors from the Terminal Prompt
How Traditional Error Processing Works
For traditional error processing, Caché provides the functionality so that your application can have an error handler. An error handler processes any error that may occur while the application is running. A special variable specifies the ObjectScript commands to be executed when an error occurs. These commands may handle the error directly or may call a routine to handle it.
To set up an error handler, the basic process is:
-
Create one or more routines to perform error processing. Write code to perform error processing. This can be general code for the entire application or specific processing for specific error conditions. This allows you to perform customized error handling for each particular part of an application.
-
Establish one or more error handlers within your application, each using specific appropriate error processing.
If an error occurs and no error handler has been established, the behavior depends on how the Caché session was started:
-
If you signed onto Caché at the Terminal prompt and have not set an error trap, Caché displays an error message on the principal device and returns the Terminal prompt with the program stack intact. The programmer can later resume execution of the program.
-
If you invoked Caché in Application Mode and have not set an error trap, Caché displays an error message on the principal device and executes a HALT command.
Internal Error-Trapping Behavior
To get the full benefit of Caché error processing and the scoping issues surrounding the $ZTRAP special variable (as well as $ETRAP), it is helpful to understand how Caché transfers control from one routine to another.
Caché builds a data structure called a “context frame” each time any of the following occurs:
-
A routine calls another routine with a DO command. (This kind of frame is also known as a “DO frame.”)
-
An XECUTE command argument causes ObjectScript code to execute. (This kind of frame is also known as a “XECUTE frame.”)
-
A user-defined function is executed.
The frame is built on the call stack, one of the private data structures in the address space of your process. Caché stores the following elements in the frame for a routine:
-
The value of the $ZTRAP special variable (if any)
-
The value of the $ETRAP special variable (if any)
-
The position to return from the subroutine
When routine A calls routine B with DO ^B, Caché builds a DO frame on the call stack to preserve the context of A. When routine B calls routine C, Caché adds a DO frame to the call stack to preserve the context of B, and so forth.
Frames on a Call Stack
If routine A in the figure above is invoked at the Terminal prompt using the DO command, then an extra DO frame, not described in the figure, exists at the base of the call stack.
Current Context Level
You can use the following to return information about the current context level:
-
The $STACK special variable contains the current relative stack level.
-
The $ESTACK special variable contains the current stack level. It can be initialized to 0 (level zero) at any user-specified point.
-
The $STACK function returns information about the current context and contexts that have been saved on the call stack
The $STACK Special Variable
The $STACK special variable contains the number of frames currently saved on the call stack for your process. The $STACK value is essentially the context level number (zero based) of the currently executing context. Therefore, when a Caché image is started, but before any commands are processed, the value of $STACK is 0.
See the $STACK special variable in the Caché ObjectScript Reference for details.
The $ESTACK Special Variable
The $ESTACK special variable is similar to the $STACK special variable, but is more useful in error handling because you can reset it to 0 (and save its previous value) with the NEW command. Thus, a process can reset $ESTACK in a particular context to mark it as a $ESTACK level 0 context. Later, if an error occurs, error handlers can test the value of $ESTACK to unwind the call stack back to that context.
See the $ESTACK special variable in the Caché ObjectScript Reference for details.
The $STACK Function
The $STACK function returns information about the current context and contexts that have been saved on the call stack. For each context, the $STACK function provides the following information:
-
The type of context (DO, XECUTE, or user-defined function)
-
The entry reference and command number of the last command processed in the context
-
The source routine line or XECUTE string that contains the last command processed in the context
-
The $ECODE value of any error that occurred in the context (available only during error processing when $ECODE is non-null)
When an error occurs, all context information is immediately saved on your process error stack. The context information is then accessible by the $STACK function until the value of $ECODE is cleared by an error handler. In other words, while the value of $ECODE is non-null, the $STACK function returns information about a context saved on the error stack rather than an active context at the same specified context level.
See the $STACK function in the Caché ObjectScript Reference for details.
When an error occurs and an error stack already exists, Caché records information about the new error at the context level where the error occurred, unless information about another error already exists at that context level on the error stack. In this case, the information is placed at the next level on the error stack (regardless of the information that may already be recorded there).
Therefore, depending on the context level of the new error, the error stack may extend (one or more context levels added) or information at an existing error stack context level may be overwritten to accommodate information about the new error.
Keep in mind that you clear your process error stack by clearing the $ECODE special variable.
Error Codes
When an error occurs, Caché sets the $ZERROR and $ECODE special variables to a value describing the error.
$ZERROR Value
Caché sets $ZERROR to a string containing:
-
The Caché error code, enclosed in angle brackets.
-
The label, offset, and routine name where the error occurred.
-
(For some errors): Additional information, such as the name of the item that caused the error.
The AsSystemError()Opens in a new tab method of the %Exception.SystemExceptionOpens in a new tab class returns the same values in the same format as $ZERROR.
The following examples show the type of messages to which $ZERROR is set when Caché encounters an error. In the following example, the undefined local variable abc is invoked at line offset 2 from label PrintResult of routine MyTest. $ZERROR contains:
<UNDEFINED>PrintResult+2^MyTest *abc
The following error occurred when a non-existent class is invoked at line offset 3:
<CLASS DOES NOT EXIST>PrintResult+3^MyTest *%SYSTEM.XXQL
The following error occurred when a non-existent method of an existing class is invoked at line offset 4:
<METHOD DOES NOT EXIST>PrintResult+4^MyTest *BadMethod,%SYSTEM.SQL
You can also explicitly set the special variable $ZERROR as any string up to 128 characters; for example:
The $ZERROR value is intended for use immediately following an error. Because a $ZERROR value may not be preserved across routine calls, users that wish to preserve a $ZERROR value for later use should copy it to a variable. It is strongly recommended that users set $ZERROR to the null string («») immediately after use. See the $ZERROR special variable in the Caché ObjectScript Reference for details. For further information on handling $ZERROR errors, refer to the %SYSTEM.ErrorOpens in a new tab class methods in the InterSystems Class Reference.
$ECODE Value
When an error occurs, Caché sets $ECODE to the value of a comma-surrounded string containing the ANSI Standard error code that corresponds to the error. For example, when you make a reference to an undefined global variable, Caché sets $ECODE set to the following string:
If the error has no corresponding ANSI Standard error code, Caché sets $ECODE to the value of a comma-surrounded string containing the Caché error code preceded by the letter Z. For example, if a process has exhausted its symbol table space, Caché places the error code <STORE> in the $ZERROR special variable and sets $ECODE to this string:
After an error occurs, your error handlers can test for specific error codes by examining the value of the $ZERROR special variable or the $ECODE special variable.
Note:
Error handlers should examine $ZERROR rather than $ECODE special variable for specific errors.
See the $ECODE special variable in the Caché ObjectScript Reference for details.
Handling Errors with $ZTRAP
To handle errors with $ZTRAP, you set the $ZTRAP special variable to a location, specified as a quoted string. You set the $ZTRAP special variable to an entry reference that specifies the location to which control is to be transferred when an error occurs. You then write $ZTRAP code at that location.
When you set $ZTRAP to a non-empty value, it takes precedence over any existing $ETRAP error handler. Caché implicitly performs a NEW $ETRAP command and sets $ETRAP equal to «».
Setting $ZTRAP in a Procedure
Within a procedure, you can only set the $ZTRAP special variable to a line label (private label) within that procedure. You cannot set $ZTRAP to any external routine from within a procedure block.
When displaying the $ZTRAP value, Caché does not return the name of the private label. Instead, it returns the offset from the top of the procedure where that private label is located.
For further details see the $ZTRAP special variable in the ObjectScript Reference.
Setting $ZTRAP in a Routine
Within a routine, you can set the $ZTRAP special variable to a label in the current routine, to an external routine, or to a label within an external routine. You can only reference an external routine if the routine is not procedure block code. The following example establishes LogErr^ErrRou as the error handler. When an error occurs, Caché executes the code found at the LogErr label within the ^ErrRou routine:
SET $ZTRAP="LogErr^ErrRou"
When displaying the $ZTRAP value, Caché displays the label name and (when appropriate) the routine name.
A label name must be unique within its first 31 characters. Label names and routine names are case-sensitive.
Within a routine, $ZTRAP has three forms:
-
SET $ZTRAP=»location«
-
SET $ZTRAP=»*location» which executes in the context in which the error occurred that invoked it.
-
SET $ZTRAP=»^%ETN» which executes the system-supplied error routine %ETN in the context in which the error occurred that invoked it. You cannot execute ^%ETN (or any external routine) from a procedure block. Either specify the code is [Not ProcedureBlock], or use a routine such as the following, which invokes the %ETN entrypoint BACK^%ETN:
ClassMethod MyTest() as %Status { SET $ZTRAP="Error" SET ans = 5/0 /* divide-by-zero error */ WRITE "Exiting ##class(User.A).MyTest()",! QUIT ans Error SET err=$ZERROR SET $ZTRAP="" DO BACK^%ETN QUIT $$$ERROR($$$CacheError,err) }
For more information on %ETN and its entrypoints, see Logging Application Errors. For details on its use with $ZTRAP, see SET $ZTRAP=^%ETN.
For further details see the $ZTRAP special variable in the ObjectScript Reference.
Writing $ZTRAP Code
The location that $ZTRAP points to can perform a variety of operations to display, log, and/or correct an error. Regardless of what error handling operations you wish to perform, the $ZTRAP code should begin by performing two tasks:
-
Set $ZTRAP to another value, either the location of an error handler, or the empty string («»). (You must use SET, because you cannot KILL $ZTRAP.) This is done because if another error occurs during error handling, that error would invoke the current $ZTRAP error handler. If the current error handler is the error handler you are in, this would result in an infinite loop.
-
Set a variable to $ZERROR. If you wish to reference a $ZERROR value later in your code, refer to this variable, not $ZERROR itself. This is done because $ZERROR contains the most-recent error, and a $ZERROR value may not be preserved across routine calls, including internal routine calls. If another error occurs during error handling, the $ZERROR value would be overwritten by that new error.
It is strongly recommended that users set $ZERROR to the null string («») immediately after use.
The following example shows these essential $ZTRAP code statements:
MyErrHandler
SET $ZTRAP=""
SET err=$ZERROR
/* error handling code
using err as the error
to be handled */
Using $ZTRAP
Each routine in an application can establish its own $ZTRAP error handler by setting $ZTRAP. When an error trap occurs, Caché takes the following steps:
-
Sets the special variable $ZERROR to an error message.
-
Resets the program stack to the state it was in when the error trap was set (when the SET $ZTRAP= was executed). In other words, the system removes all entries on the stack until it reaches the point at which the error trap was set. (The program stack is not reset if $ZTRAP was set to a string beginning with an asterisk (*).)
-
Resumes the program at the location specified by the value of $ZTRAP. The value of $ZTRAP remains the same.
Note:
You can explicitly set the variable $ZERROR as any string up to 128 characters. Usually you would set $ZERROR to a null string, but you can set $ZERROR to a value.
Unstacking NEW Commands With Error Traps
When an error trap occurs and the program stack entries are removed, Caché also removes all stacked NEW commands back to the subroutine level containing the SET $ZTRAP=. However, all NEW commands executed at that subroutine level remain, regardless of whether they were added to the stack before or after $ZTRAP was set.
For example:
Main
SET A=1,B=2,C=3,D=4,E=5,F=6
NEW A,B
SET $ZTRAP="ErrSub"
NEW C,D
DO Sub1
RETURN
Sub1()
NEW E,F
WRITE 6/0 // Error: division by zero
RETURN
ErrSub()
WRITE !,"Error is: ",$ZERROR
WRITE
RETURN
When the error in Sub1 activates the error trap, the former values of E and F stacked in Sub1 are removed, but A, B, C, and D remain stacked.
$ZTRAP Flow of Control Options
After a $ZTRAP error handler has been invoked to handle an error and has performed any cleanup or error logging operations, the error handler has three flow control options:
-
Handle the error and continue the application.
-
Pass control to another error handler
-
Terminate the application
Continuing the Application
After a $ZTRAP error handler has handled an error, you can continue the application by issuing a GOTO. You do not have to clear the values of the $ZERROR or $ECODE special variables to continue normal application processing. However, you should clear $ZTRAP (by setting it to the empty string) to avoid a possible infinite error handling loop if another error occurs. See “Handling Errors in an Error Handler” for more information.
After completing error processing, your $ZTRAP error handler can use the GOTO command to transfer control to a predetermined restart or continuation point in your application to resume normal application processing.
When an error handler has handled an error, the $ZERROR special variable is set to a value. This value is not necessarily cleared when the error handler completes. The $ZERROR value is overwritten when the next error occurs that invokes an error handler. For this reason, the $ZERROR value should only be accessed within the context of an error handler. Accessing $ZERROR in any other context does not produce reliable results.
Passing Control to Another Error Handler
If the error condition cannot be corrected by a $ZTRAP error handler, you can use a special form of the ZTRAP command to transfer control to another error handler. The command ZTRAP $ZERROR re-signals the error condition and causes Caché to unwind the call stack to the next call stack level with an error handler. After Caché has unwound the call stack to the level of the next error handler, processing continues in that error handler. The next error handler may have been set by either a $ZTRAP or a $ETRAP.
The following figure shows the flow of control in $ZTRAP error handling routines.
$ZTRAP Error Handlers
Handling Errors with $ETRAP
When an error trap occurs and you have set $ETRAP, Caché takes the following steps:
-
Sets the values of $ECODE and $ZERROR.
-
Processes the commands that are the value of $ETRAP.
By default, each DO, XECUTE, or user-defined function context inherits the $ETRAP error handler of the frame that invoked it. This means that the designated $ETRAP error handler at any context level is the last defined $ETRAP, even if that definition was made several stack levels down from the current level.
$ETRAP Error Handlers
The $ETRAP special variable can contain one or more ObjectScript commands that are executed when an error occurs. Use the SET command to set $ETRAP to a string that contains one or more Caché commands that transfer control to an error-handling routine. This example transfers control to the LogError code label (which is part of the routine ErrRoutine):
SET $ETRAP="DO LogError^ErrRoutine"
The commands in the $ETRAP special variable are always followed by an implicit QUIT command. The implicit QUIT command quits with a null string argument when the $ETRAP error handler is invoked in a user-defined function context where a QUIT with arguments is required.
$ETRAP has a global scope. This means that setting $ETRAP should usually be preceded by NEW $ETRAP. Otherwise, if the value of $ETRAP is set in the current context, then, after passing beyond the scope of that context, the value stored in $ETRAP is still present while control is in a higher-level context. Thus, if you do not specify the NEW $ETRAP, then $ETRAP could be executed at an unexpected time when the context that set that it no longer exists.
See the $ETRAP special variable in the Caché ObjectScript Reference for details.
Context-specific $ETRAP Error Handlers
Any context can establish its own $ETRAP error handler by taking the following steps:
-
Use the NEW command to create a new copy of $ETRAP.
-
Set $ETRAP to a new value.
If a routine sets $ETRAP without first creating a new copy of $ETRAP, a new $ETRAP error handler is established for the current context, the context that invoked it, and possibly other contexts that have been saved on the call stack. Therefore InterSystems recommends that you create a new copy of $ETRAP before you set it.
Keep in mind that creating a new copy of $ETRAP does not clear $ETRAP. The value of $ETRAP remains unchanged by the NEW command.
The figure below shows the sequence of $ETRAP assignments that create the stack of $ETRAP error handlers. As the figure shows:
-
Routine A creates a new copy of $ETRAP, sets it to “GOTO ^ERR”, and contains the DO command to call routine B.
-
Routine B does nothing with $ETRAP (thereby inheriting the $ETRAP error handler of Routine A) and contains the DO command to call routine C.
-
Routine C creates a new copy of $ETRAP, sets it to “GOTO ^CERR”, and contains the DO command to call routine D.
-
Routine D creates a new copy of $ETRAP and then clears it, leaving no $ETRAP error handler for its context.
If an error occurs in routine D (a context in which no $ETRAP error handler is defined), Caché removes the DO frame for routine D from the call stack and transfers control to the $ETRAP error handler of Routine C. The $ETRAP error handler of Routine C, in turn, dispatches to ^CERR to process the error. If an error occurs in Routine C, Caché transfers control to the $ETRAP error handler of Routine C, but does not unwind the stack because the error occurs in a context where a $ETRAP error handler is defined.
$ETRAP Error Handlers
$ETRAP Flow of Control Options
When the $ETRAP error handler has been invoked to handle an error and perform any cleanup or error-logging operations, it has the following flow-of-control options:
-
Handle the error and continue the application.
-
Pass control to another error handler.
-
Terminate the application.
Handling the Error and Continuing the Application
When a $ETRAP error handler is called to handle an error, Caché considers the error condition active until the error condition is dismissed. You dismiss the error condition by setting the $ECODE special variable to the null string:
Clearing $ECODE also clears the error stack for your process.
Typically, you use the GOTO command to transfer control to a predetermined restart or continuation point in your application after the error condition is dismissed. In some cases, you may find it more convenient to quit back to the previous context level after dismissing the error condition.
Passing Control to Another Error Handler
If the error condition is not dismissed, Caché passes control to another error handler on the call stack when a QUIT command terminates the context at which the $ETRAP error handler was invoked. Therefore, you pass control to a previous level error handler by performing a QUIT from a $ETRAP context without clearing $ECODE.
If routine D, called from routine C, contains an error that transfers control to ^CERR, the QUIT command in ^CERR that is not preceded by setting $ECODE to «» (the empty string) transfers control to the $ETRAP error handler at the previous context level. In contrast, if the error condition is dismissed by clearing $ECODE, a QUIT from ^CERR transfers control to the statement in routine B that follows the DO ^C command.
Terminating the Application
If no previous level error handlers exist on the call stack and a $ETRAP error handler performs a QUIT without dismissing the error condition, the application is terminated. In Application Mode, Caché is then run down and control is passed to the operating system. The Terminal prompt then appears.
Keep in mind that you use the QUIT command to terminate a $ETRAP error handler context whether or not the error condition is dismissed. Because the same $ETRAP error handler can be invoked at context levels that require an argumentless QUIT and at context levels (user-defined function contexts) that require a QUIT with arguments, the $QUIT special variable is provided to indicate the QUIT command form required at a particular context level.
The $QUIT special variable returns 1 (one) for contexts that require a QUIT with arguments and returns 0 (zero) for contexts that require an argumentless QUIT.
A $ETRAP error handler can use $QUIT to provide for either circumstance as follows:
When appropriate, a $ETRAP error handler can terminate the application using the HALT command.
Handling Errors in an Error Handler
When an error occurs in an error handler, the flow of execution depends on the type of error handler that is currently executing.
Errors in a $ETRAP Error Handler
If the new error occurs in a $ETRAP error handler, Caché unwinds the call stack until the context level at which the $ETRAP error handler was invoked has been removed. Caché then passes control to the next error handler (if any) on the call stack.
Errors in a $ZTRAP Error Handler
If the new error occurs in a $ZTRAP error handler, Caché passes control to the first error handler it encounters, unwinding the call stack only if necessary. Therefore, if the $ZTRAP error does not clear $ZTRAP at the current stack level and another error subsequently occurs in the error handler, the $ZTRAP handler is invoked again at the same context level, causing an infinite loop. To avoid this, Set $ZTRAP to another value at the beginning of the error handler.
Error Information in the $ZERROR and $ECODE Special Variables
If another error occurs during the handling of the original error, information about the second error replaces the information about the original error in the $ZERROR special variable. However, Caché appends the new information to the $ECODE special variable. Depending on the context level of the second error, Caché may append the new information to the process error stack as well.
If the existing value of the $ECODE special variable is non-null, Caché appends the code for the new error to the current $ECODE value as a new comma piece. Error codes accrue in the $ECODE special variable until either of the following occurs:
-
You explicitly clear $ECODE, for example:
-
The length of $ECODE exceeds the maximum string length.
Then, the next new error code replaces the current list of error codes in $ECODE.
When an error occurs and an error stack already exists, Caché records information about the new error at the context level where the error occurred, unless information about another error already exists at that context level on the error stack. In this case, the information is placed at the next level on the error stack (regardless of the information that may already be recorded there).
Therefore, depending on the context level of the new error, the error stack may extend (one or more context levels added) or information at an existing error stack context level may be overwritten to accommodate information about the new error.
Keep in mind that you clear your process error stack by clearing the $ECODE special variable.
See the $ECODE and $ZERROR special variables in the Caché ObjectScript Reference for details. For further information on handling $ZERROR errors, refer to the %SYSTEM.ErrorOpens in a new tab class methods in the InterSystems Class Reference.
Forcing an Error
You set the $ECODE special variable or use the ZTRAP command to cause an error to occur under controlled circumstances.
Setting $ECODE
You can set the $ECODE special variable to any non-null string to cause an error to occur. When your routine sets $ECODE to a non-null string, Caché sets $ECODE to the specified string and then generates an error condition. The $ZERROR special variable in this circumstance is set with the following error text:
Control then passes to error handlers as it does for normal application-level errors.
You can add logic to your error handlers to check for errors caused by setting $ECODE. Your error handler can check $ZERROR for an <ECODETRAP> error (for example, “$ZE[«ECODETRAP»”) or your error handler can check $ECODE for a particular string value that you choose.
Creating Application-Specific Errors
Keep in mind that the ANSI Standard format for $ECODE is a comma-surrounded list of one or more error codes:
-
Errors prefixed with “Z” are implementation-specific errors
-
Errors prefixed with “U” are application-specific errors
You can create your own error codes following the ANSI Standard by having the error handler set $ECODE to the appropriate error message prefixed with a “U”.
SET $ECODE=",Upassword expired,"
Processing Errors from the Terminal Propmt
When you generate an error after you sign onto Caché at the Terminal prompt with no error handler set, Caché takes the following steps when an error occurs in a line of code you enter:
-
Caché displays an error message on the process’s principal device.
-
Caché breaks at the call stack level where the error occurred.
-
The process returns the Terminal prompt.
Understanding Error Message Formats
As an error message, Caché displays three lines:
-
The entire line of source code in which the error occurred.
-
Below the source code line, a caret (^) points to the command that caused the error.
-
A line containing the contents of $ZERROR.
In the following Terminal prompt example, the second SET command has an undefined local variable error:
USER>WRITE "hello",! SET x="world" SET y=zzz WRITE x,!
hello
WRITE "hello",! SET x="world" SET y=zzz WRITE x,!
^
<UNDEFINED> *zzz
USER>
In the following example, the same line of code is in a program named mytest executed from the Terminal prompt:
USER>DO ^mytest
hello
WRITE "hello",! SET x="world" SET y=zzz WRITE x,!
^
<UNDEFINED>WriteOut+2^mytest *zzz
USER 2d0>
In this case, $ZERROR indicates that the error occurred in mytest at an offset of 2 lines from the a label named WriteOut. Note that the prompt has changed, indicating that a new program stack level has been initiated.
Understanding the Terminal Prompt
By default, the Terminal prompt specifies the current namespace. If one or more transactions are open, it also includes the $TLEVEL transaction level count. This default prompt can be configured with different contents, as described in the ZNSPACE command documentation. The following examples show the defaults:
If an error occurs during the execution of a routine, the system saves the current program stack and initiates a new stack frame. An extended prompt appears, such as:
This extended prompt indicates that there are two entries on the program stack, the last of which is an invoking of DO (as indicated by the “d”). Note that this error placed two entries on the program stack. The next DO execution error would result in the Terminal prompt:
For a more detailed explanation, refer to Terminal Prompt Shows Program Stack Information in the “Command-line Routine Debugging” chapter.
Recovering from the Error
You can then take any of the following steps:
-
Issue commands from the Terminal prompt
-
View and modify your variables and global data
-
Edit the routine containing the error or any other routine
-
Execute other routines
Any of these steps can even cause additional errors.
After you have taken these steps, your most likely course is to either resume execution or to delete all or part of the program stack.
Resuming Execution at the Next Sequential Command
You can resume execution at the next command after the command that caused the error by entering an argumentless GOTO at the Terminal prompt:
USER>DO ^mytest
hello
WRITE "hello",! SET x="world" SET y=zzz WRITE x,!
^
<UNDEFINED>WriteOut+2^mytest *zzz
USER 2d0>GOTO
world
USER>
Resuming Execution at Another Line
You can resume execution at another line by issuing a GOTO with a label argument at the Terminal prompt:
Deleting the Program Stack
You can delete the entire program stack by issuing an argumentless QUIT command at the Terminal prompt:
Deleting Part of the Program Stack
You can issue QUIT n with an integer argument at the Terminal prompt to delete the last (or last several) program stack entry:
USER 8d0>QUIT 1
USER 7E0>QUIT 3
USER 4d0>QUIT 1
USER 3E0>QUIT 1
USER 2d0>QUIT 1
USER 1S0>QUIT 1
USER>
Note that in this example because the program error created two program stack entries, you must be on a “d” stack entry to resume execution by issuing a GOTO. Depending on what else has occurred, a “d” stack entry may be even-numbered (USER 2d0>) or odd-numbered (USER 3d0>).
By using NEW $ESTACK, you can quit to a specified program stack level:
USER 4d0>NEW $ESTACK
USER 5E1>
/* more errors create more stack frames */
USER 11d7>QUIT $ESTACK
USER 4d0>
Note that the NEW $ESTACK command adds one entry to the program stack.
Logging Application Errors
Caché provides several ways to log an exception to an application error log.
-
The %ETN utility logs errors. It can be invoked as ^%ETN or using one of its entrypoints: FORE^%ETN, BACK^%ETN, or LOG^%ETN.
-
The %Exception.AbstractException.Log()Opens in a new tab method.
Using %ETN to Log Application Errors
The %ETN utility logs an exception to the application error log and then exits. You can invoke %ETN (or one of its entrypoints) as a utility:
Or you can set the $ZTRAP special variable to %ETN (or one of its entrypoints):
You can specify %ETN or one of its entry points:
-
FORE^%ETN (foreground) logs an exception to the standard application error log, and then exits with a HALT. This invokes a rollback operation. This is the same operation as %ETN.
-
BACK^%ETN (background) logs an exception to the standard application error log, and then exits with a QUIT. This does not invoke a rollback operation.
-
LOG^%ETN logs an exception to the standard application error log, and then exits with a QUIT. This does not invoke a rollback operation. The exception can be a standard %Exception.SystemExceptionOpens in a new tab, or a user-defined exception.
To define an exception, set $ZERROR to a meaningful value prior to calling LOG^%ETN; this value will be used as the Error Message field in the log entry. You can also specify a user-defined exception directly into LOG^%ETN: DO LOG^%ETN(«This is my custom exception»); this value will be used as the Error Message field in the log entry. If you set $ZERROR to the null string (SET $ZERROR=»») LOG^%ETN logs a <LOG ENTRY> error. If you set $ZERROR to <INTERRUPT> (SET $ZERROR=»<INTERRUPT>») LOG^%ETN logs an <INTERRUPT LOG> error.
LOG^%ETN returns a %List structure with two elements: the $HOROLOG date and the Error Number.
The following example uses the recommended coding practice of immediately copying $ZERROR into a variable. LOG^%ETN returns a %List value:
SET err=$ZERROR
/* error handling code */
SET rtn = $$LOG^%ETN(err)
WRITE "logged error date: ",$LIST(rtn,1),!
WRITE "logged error number: ",$LIST(rtn,2)
Calling LOG^%ETN or BACK^%ETN automatically increases the available process memory, does the work, and then restores the original $ZSTORAGE value. However, if you call LOG^%ETN or BACK^%ETN following a <STORE> error, restoring the original $ZSTORAGE value might trigger another <STORE> error. For this reason, the system retains the increased available memory when these %ETN entrypoints are invoked for a <STORE> error.
Using Management Portal to View Application Error Logs
From the Management Portal, select System Operation, then System Logs, then Application Error Log. This displays the Namespace list of those namespaces that have application error logs. You can use the header to sort the list.
Select Dates for a namespace to display those dates for which there are application error logs, and the number of errors recorded for that date. You can use the headers to sort the list. You can use Filter to match a string to the Date and Quantity values.
Select Errors for a date to display the errors for that date. Error # integers are assigned to errors in chronological order. Error # *COM is a user comment applied to all errors for that date. You can use the headers to sort the list. You can use Filter to match a string.
Select Details for an error to open an Error Details window that displays state information at the time of the error including special variables values and Stacks details. You can specify a user comment for an individual error.
The Namespaces, Dates, and Errors listings include checkboxes that allow you to delete the error log for the corresponding error or errors. Check what you wish to delete, then select the Delete button.
Using %ERN to View Application Error Logs
The %ERN utility examines application errors recorded by the %ETN error trap utility. %ERN returns all errors logged for the current namespace.
Take the following steps to use the %ERN utility:
-
At the Terminal prompt, DO ^%ERN. The name of the utility is case-sensitive; responses to prompts within the utility are not case-sensitive. At any prompt you may enter ? to list syntax options for the prompt, or ?L to list all of the defined values. You may use the Enter key to exit to the previous level.
-
For Date: at this prompt, enter the date on which the errors occurred. You can use any date format that is accepted by the %DATE utility; if you omit the year, the current year is assumed. It returns the date and the number of errors logged for that date. Alternative, you can retrieve lists of errors from this prompt using the following syntax:
-
?L lists all dates on which errors occurred, most recent first, with the number of errors logged. The (T) column indicates how many days ago, with (T) = today and (T-7) = seven days ago. If a user comment is defined for all of the day’s errors, it is shown in square brackets. After listing, it re-displays the For Date: prompt. You can enter a date or T-n.
-
[text lists all errors that contain the substring text. <text lists all errors that contain the substring text in the error name component. ^text lists all errors that contain the substring text in the error location component. After listing, it re-displays the For Date: prompt. Enter a date.
-
-
Error: at this prompt supply the integer number for the error you want to examine: 1 for the first error of the day, 2 for the second, and so on. Or enter a question mark (?) for a list of available responses. The utility displays the following information about the error: the Error Name, Error Location, time, system variable values, and the line of code executed at the time of the error.
You can specify an * at the Error: prompt for comments. * displays the current user-specified comment applied to all of the errors of that day. It then prompts you to supply a new comment to replace the existing comment for all of these errors.
-
Variable: at this prompt you can specify numerous options for information about variables. If you specify the name of a local variable (unsubscipted or subscripted), %ERN returns the stack level and value of that variable (if defined), and all its descendent nodes. You cannot specify a global variable, process-private variable, or special system variable.
You may enter ? to list other syntax options for the Variable: prompt.
-
*A: when specified at the Variable: prompt, displays the Device: prompt; press Return to display results on the current Terminal device.
-
*V: when specified at the Variable: prompt, displays the Variable(s): prompt. At this prompt specify an unsubscripted local variable or a comma-separated list of unsubscripted local variables; subscripted variables are rejected. %ERN then displays the Device: prompt; press Return to display results on the current Terminal device. %ERN returns the value of each specified variable (if defined) and all its descendent nodes.
-
Note:
%ER is a legacy name for %ERN. Their functionality is identical, though %ERN is slightly more efficient.
Анализ ошибок компьютера диагностической картой (POST-карта)
1. Введение
2. Общее описание POST карты
4. Таблица кодов ошибок
5. Описание звуковых сигналов
6. Сброс забытого пароля к BIOS
Введение
Карта называется POST (Power On Self Test — карта самотестирования). Отображает коды ошибок, при невозможности загрузки операционной системы или нет изображения на экране или нет звуков BIOS.
Когда питание подано, BIOS проводит точный тест схемы, памяти, клавиатуры, видеокарты, жёсткого диска, затем анализирует системную конфигурацию. После инициализации базовой системы ввода/вывода идёт загрузка операционной системы.
Диагностическая карта не будет отображать данные в следующих случаях:
1. Карта вставлена в материнскую плату без центрального процессора.
2. Когда горит диод RST LED.
Общее описание POST карты
Описание светящихся диодов:
Светодиод |
Тип |
Описание |
RUN | Мерцание | Если светодиод горит, материнская плата включена, не имеет значения какие коды проходят |
CLK | BUS CLOCK | Горит когда питание подано на материнскую плату (обычно без процессора) |
BIOS | Считывание BIOS | Светодиод включается и выключается когда подаётся питание на материнскую плату, при чтении BIOS процессором |
IRDY | Менеджер готов | Светодиод включается и выключается когда есть сообщение |
OSC | Мигание | Загорается когда подано питание на материнскую плату, или если нет то кристалл колебательного контура сломан |
FRAME | Период кадра | Горит всё время. Включается и выключается когда есть сообщение |
RST | Reset | Загорается на пол секунды, когда нажимаете на кнопку включения или сброса. Если горит питание, то стоит проверить RESET (замыкает или сломан). |
12V | Power | Загорается единожды при включении, подаче питания, если не загорается это означает короткое замыкание на материнской плате или нет 12В. |
-12V | Питание | Тоже самое что и «12V» |
5V | Питание | Тоже самое что и «12V» |
-5V | Питание | Тоже самое что и «12V» (-5V только для ISA слота) |
3V3 | Питание | Загорается при подаче питания (только PCI), где есть 3,3В. Если нет на материнской плате дежурного напряжения 3,3В — не загорается |
Таблица кодов ошибок
Код |
Award |
AMI |
Phoenix4.0 / Tendy3000 |
00 | Code copying to specific areas is done/Passing control to INT 19h boot loader next. | ||
01 | Processor Test 1, Processor status (1FLAGS) verification. Test the following processor status flags: carry, zero, sign, overflow. The BIOS sets each flag, verifies they are set, then turns each flag off and verifies it is off. | CPU is testing the register inside or failed, please change the CPU and check it. | |
02 | Test All CPU Registers Except SS, SP, and BP with Data FF and 00 | Verify Real Mode | |
03 | Disable NMI, PIE, AIE, UEI, SQWV Disable video, parity checking, DMA Reset math coprocessor Clear all page registers, CMOS shutdown byte Initialize timer 0, 1, and2, including set EISA timer to a known state Initialize DMA controllers 0 and 1 Initialize interrupt controllers 0 and 1 Initialize EISA extended registers | Disable NMI, PIE, AIE, UEI, SQThe NMI is disabled. Next, checking for a soft reset or a power on condition | Disable Non-Mask-able interrupt (NMI) |
04 | RAM must be periodically refreshed to keep the memory from decaying. This refresh function is working properly | Get CPU type | |
05 | Keyboard Controller initialization | The BIOS stack has been built. Next, disabling cache mamory. | DMA initialization in progress or failure |
06 | Reserved | Uncompressing the POST code next. | Initialized system hardware |
07 | Verifies CMOS is Working Correctly, Detects Bad Battery | Next, initializing the CPU data area | Disable shadow and execute code from the ROM |
08 | Early chip set initialization Memory presence test OEM chip set routines Clear low 64K memory Test first 64K memory | The CMOS checksum calculation is | Initialize chipset with with initial POST values |
09 | Cyrix CPU initialization Cach initialization | Set IN POST flag | |
0A | Initialize first 120 interrupt vectors with SPURIOUS-INT-HDLR and initialize INT 00h-1Fh according to INT-TBL | The CMOS checksum calculation is done. Linitializing the CMOS status register for date and time next | Initialize CPU registers |
0B | Test CMOS RAM Checksum. If bad, or INS Key Pressed, Load Defaults | The CMOS status register is initialized. Next. Performing any requirect initialization before the keyboard BAT command is issued | Enable CPU cach |
0C | Detect Type of Keyboard Controller and Set NUM LOCK Status | The keyboard controller input butter is free Next, issuing the BAT command to the keyboard controller | Initialize caches to initial POST values |
0D | Detect CPU Clock Read CMOS location 14h to find out type of video in use Detect and initialize video adapter | ||
0E | Test Video Memory, write sign-on message to screen Setup shadow RAM? Enable shadew according to setup | The keyboard controller BAT command result has been verified. Next, performing any necessary initialization after the keyboard controller BAT command test | Initialize I/O component |
0F | Test DMA Cont. 0; BIOS Checksum Test Keyboard Detect and initialization | The initialization after the keyboard controller BAT command test is done. The keyboard command byte is written next | Initialization the local bus IDE |
10 | Test DMA Controller 1 | Test DMA The keyboard controller command byte is written. Next, issuing the Pin 23 and 24 Blocking and unblocking command | Initialize Power Management |
11 | Test DMA Page Registers | Next, checking if «End» or «Ins» keys were pressed during power on. Initializing CMOS RAM in every boot AMIBIOS POST option was set in AMIBCP or the «End» key was pressed | |
12 | Reserved | Next, disabling DMA controllers 1 and 2 and interrupt controllers 1 and 2 | Restore CPU control word during warm boot |
13 | Reserved | The video display has been disabled. Port B has been initialized. Next, initializing the chipset | initialize PCI Bus Mastering devices |
14 | Test 8254 Timer 0 Counter 2 | The 8254 timer test will begin next | |
15 | Verify 8259 Channel 1 interrupts by Turning Off and On the interrupt Lines | ||
16 | Verify 8259 Channel 2 interrupts by Turning Off and On the interrupt Lines | BIOS ROM checksum | |
17 | Turn Off interrupts Then Verify No Interrupt Msk Register is On | Initialize cach before memory Auto size | |
18 | Force an interrupt and Verify the interrupt and Verify the interrupt Occurred | 8254 timer initialization | |
19 | Test Stuck NMI Bits; Verify NMI Can Be Cieared | The 8254 timer test is over. Starting the memory refresh test next | |
1A | Display CPU clock | The memory refresh line is toggling. Checking the 15 second on/off time next | |
1B | Reserved | ||
1C | Reserved | Reset Programmable interrupt Controller | |
1D | Reserved | ||
1E | Reserved | ||
1F | If EISA non-volatile memory checksum is good, execute EISA initialization If not, execute ISA tests an clear EISA mode flag Test EISA configuration memory Integrity (checksum & communication interface) | ||
20 | Initialize Slot O (System Board) | Test DRAM refresh | |
21 | Initialize Slot 1 | ||
22 | Initialize Slot 2 | Test 8742 Keyboard Controller | |
23 | Initialize Slot 3 | Reading the 8042 input port and disabling the MEGAKEY Green PC feature next. Making the BIOS code segment writable and performing any necessary configuration before initializing the interrupt vectors | |
24 | Initialize Slot 4 | The configuration required before interrupt vector initialization has completed. Interrupt vector initialization is about to begin | Set ES segment register to 4Gb |
25 | Initialize Slot 5 | Interrupt vector initialization is done. Clearing the password if the POST DIAG awitch is on | |
26 | 1. test the exeptional situation of protected of protected mode, check the memory of cpu and mainboard. 2. no fateful trouble, VGA displayed normally. If nonfateful trouble occurred, then display error message in VGA otherwise boot operating system, and code «26» is OK code, no any other codes to display |
1. read/write input, output port of 8042 keyboard; ready for revolve mode, continue to get ready for initialization of all data, check the 8042 chips on mainboard. 2. refere to the left |
1. enable A20 adress line, check the A20 pins of memory controlling chips, and check circuit, correlated to pins, in memory slot, may be A20 pin and memory pins are not in contact, or memory A20 pins bad. 2. refere to the left |
27 | Initialize Slot 7 | Any initialization before setting the video mode will be done next | |
28 | Initialize Slot 8 | Initialization before setting the video mode is complete. Configuring the monochrome mode and color mode settings next | Auto size DRAM |
29 | Initialize Slot 9 | Initialize POST Memory Manager | |
2A | Initialize Slot 10 | Initializing the different bus system, static, and output devices, if present | Clear 512 KB base RAM |
2B | Initialize Slot 11 | Passing control to the video ROM to perform any required configuration before the video ROM test | |
2C | Initialize Slot 12 | All necessary processing before passing control to the video ROM is done. Looking for the video ROM next and passing control to it | RAM failure on address line xxx* |
2D | Initialize Slot 13 | The video ROM has returned has returned control to BIOS POST Performing any required processing after the video ROM had control | |
2E | Initialize Slot 14 | Completed pest-video ROM test processing. If the EGA/VGA controller is not found, performing the display memory Read/write test next | RAM failure on data bits Xxxx* of low byte of memory bus |
2F | Initialize Slot 15 | The EGA/VGA controller was not found. The display memory read/write test is about to begin | Enable cach before system BIOS shadow |
30 | Size Base Memory From 256K to 640K and Extended Memory Above 1MB | The display memory read/write test passed. Look for retrace checking next | |
31 | Test Base Memory From 256K to 640K and Extended Memory Above 1MB | The display memory read/write test or retrace checking failed. Performing the alternate display memory read/write test next | |
32 | If EISA Mode, Test EISA Memory Found in Slots initialization | The alternate display memory read/write test passed. Looking for alternate display retrace checking next | Test CPU Bus-clock frequency |
33 | Reserved | Initialize Phoenix Dispatch manager | |
34 | Reserved | Video display checking is over. Setting the display mode next | |
35 | Reserved | ||
36 | Reserved | Warm start and shut down | |
37 | Reserved | The display mode is set. Displaying the power on message next | |
38 | Reserved | Initializing the bus input, IPL, general device next, if present | Shadow system BIOS ROM |
39 | Reserved | Displaying bus initialization error messages | |
3A | Reserved | The new cursor position has been read and saved. Displaying the Hit «Del» message next | Auto size cach |
3B | Reserved | The Hit «Del» message is displayed. The protected mode memory test is about to start | |
3C | Setup Enabled | Advanced configuration of chipset registers | |
3D | Detect if mouse is present, initialize mouse, install interrupt vectors | ||
3E | Initialize cache controller | ||
3F | Reserved | ||
40 | Display virus protect. Disable or Enable | Preparing the descriptor tables next | |
41 | Initialize Floppy Disk Drive Controller and any drives | Initialize extended memory for RomPilot | |
42 | Initialize Hard Drive Controller and any drives | The descriptor tables are prepared. Enteling protected mode for the memory test next | Initialize interrupt vectors |
43 | Detect and initialize Serial & Parallel Ports and Game Port | Entered protected mode. Enabling interrupts for diagnostics mode next | |
44 | Reserved | Interrupts enabled if the diagnostics switch is on. Initializing data to check memory wraparound at 0:0 next | |
45 | Detect and initialize math coprocessor | Data initialized. Checking for memory wraparound at 0: 0 and finding the total system memory size next | POST device initialization |
46 | Reserved | The memory wraparound test is done. Memory size calculation has been done. Writing patterns to tset memory next | Check ROM copyright notice |
47 | Reserved | The memory pattern has been to extended memory. Writing patterns to the base 640 KB memory | Initialize 120 support |
48 | Reserved | Patterns written in base memory. Determining the amount of memory below 1MB next | |
49 | Reserved | The amount of memory below 1MB has been found and verified. Determining the amount of memory above 1 MB memory next | |
4A | Reserved | ||
4B | Reserved | The amount of memory above 1MB has been found and verified. Checking for a soft reset and clearing the memory below 1MB for the soft reset next. If this is a power on situation, going to checkpoint 4Eh next | QuletBoot start (optional) |
4C | Reserved | The memory below 1MB has been cleared via a soft reset. Clearing the memory above 1MB next | Shadow video BIOS ROM |
4D | Reserved | The memory above 1MB has been cleared via a soft reset. Saving the memory size next. Going to checkpoint 52h next | |
4E | Reboot if Manufacturing Mode; if not, Display Messages and Enter Setup | The memory test started, but not as the result of a soft reset. Displaying the first 64KB memory size next | Display BIOS copyright notice |
4F | Ask Password Security (Optional) | The memory size display has started. The display is updated during the memory test. Performing the sequential and random memory test next | Initialize MultiBoot |
50 | Write All CMOS Values Back to RAM and Clear | The memory below 1MB has been tested and initialized. Adjusting the displayed memory size fot relocation and shadowing next | Display CPU type and speed |
51 | Enable Parity Checker. Enable NMI, Enable Cache Before Boot | The memory size display was adjusted for relocation and shadowing. Testing the memory above 1MB next | Initialize EISA board |
52 | Initialize Option ROMs from C8000h to EFFFFh or if FSCAN Enabled to F7FFFh | The memory above 1MB has been tested and initialized. Saving the memory size information next | Test keyboard |
53 | Initialize Time Value in 40h: BIOS Area | The memory size information and the CPU registers are saved. Entering real mode next | |
54 | Shutdown was successful. The CPU is in real mode. Disabling the Gate A20 line, parity, and the NMI next | Set key click if enabled | |
55 | |||
56 | Enable USB devices | ||
57 | The A20 address line, parity, and the NMI are disabled. Adjusting the memory size depending on relocation and shadowing next | ||
58 | The memory size was adjusted for relocation and shadowing. Clearing the Hit «DEL» message next | ||
59 | The Hit «DEL» message is cleared. The «WAIT…» message is displayed. Starting the DMA and interrupt controller test next | Initialize POST display service | |
5A | Display prompt Press F2 to enter SETUP | ||
5B | Disable CPU cache | ||
5C | Test RAM betweeb 512 and 640 kB | ||
60 | Setup virus protection (boot sector protection) functionality according to setup setting | The DMA page register test passed. Performing the DMA Controller 1 base register test next | Test extended memory |
61 | Try to turn on level 2 cach (if L2 cach already turned on in post 3D, this part will be skipped) Sat the boot up speed according to setup setting Last chance for chipset initialization Last chance for power management initialization (Green BIOS Only) Show the system configuration table | ||
62 | Setup the NUM lock. According to setup values Programm the NUM lock. Typematic rate & typematic speed according to setup setting | The DMA controller 1 base register test passed. Performing the DMA controller 2 base register test next | Test extended memory address lines |
63 | If there is any changes in the hardware configuration. Update the ESCD information (PnP BIOS only) Clear memory that have been used Boot system via INT 19h | ||
64 | Jump to UserPatch1 | ||
65 | The DMA controller 2 base register test passed. Programming DMA controller 1 and 2 next | ||
66 | Completed programming DMA controllers 1 and 2 initializing the 8259 interrupt controller next | Configure advanced cach registers | |
67 | Completed 8259 interrupt controller initialization | Initialize Multi Processor APIC | |
68 | |||
69 | Setup System Management Mode (SSM) area | ||
6A | Display external L2 cach size | ||
6B | Load custom defaults (optional) | ||
6C | Display shadow-area message | ||
6E | Display possible high address for UMB recovery | ||
6F | |||
70 | Display error message | ||
71 | |||
72 | |||
76 | Check for keyboard errors | ||
7C | Set up hardware interrupt vectors | ||
7D | Initialize intelligent System Monitoring | ||
7E | Initialize coprocessor if present | ||
7F | Extended NMI source enabling is in progress | ||
80 | The keyboard test has started. Clearing the output buffer and checking for stuck keys. Issuing the keyboard reset command next | Disable onboard Super I/O ports and IRQs | |
81 | A keyboard reset error or stuck key was found. Issuing the keyboard controller interface test command next | Late POST device initialization | |
82 | The keyboard controller interface test completed. Writing the command byte and initializing the circular buffer next | Detect and install external RS232 ports | |
83 | The command byte was written and global data initialization has completed. Checking for a locked key next | Configure non-MCD IDE controllers | |
84 | Locked key checking is over. Checking for a memory size mismatch with CMOS RAM data next | ||
85 | The memory size check is done. Displaying a soft error and checking for a password or bypassing WINBIOS Setup next | Initialize PC-compatible PnP ISA devices | |
86 | The password was checked. Performing any required programming before WINBIOS Setup next | ||
87 | The programming before WINBIOS Setup has completed Uncompressing the WINBIOS Setup code and executing the AMIBIOS Setup or WINBIOS Setup utility next | Configure Motherboard Configurable Devices (optional) | |
88 | Returned from WINBIOS Setup end cleared the screen. Performing any necessary programming after WINBIOS Setup next | Initialize BIOS Data Area | |
89 | The programming after WINBIOS Setup has completed. Displaying the power on screen message next | Enable Non-Maskable interrupts (NMis) | |
8A | Initialize Extended BIOS Data Area | ||
8B | The first screen message has been displayed. The «WAIT…» message is displayed. Performing the PS/2 mouse check and extended BIOS data area allocation check next | Test and initialize PS/2 mouse | |
8C | Programming the WINBIOS Setup options next | Initialize floppy controller | |
8D | The WINBIOS Setup options are programmed. Resetting the hard disk controller next | ||
8E | The hard disk controller has been reset. Configuring the floppy drive controller next | ||
8F | Determine number of ATA drives (optional) | ||
90 | Initialize hard-disk controllers | ||
91 | The floppy drive controller has been configured. Cjnfiguring the hard disk drive controller next | Initialize local-bus hard-disk controllers | |
92 | Jump to UserPatch2 | ||
93 | Build MPTABLE for multi-processor board | ||
95 | Initializing bus adaptor ROMs from C8000h through D8000 | Install CD ROM for boot | |
96 | Initializing before passing control to the adaptor ROM at C800 | ||
97 | Initialation before the C800 adaptor ROM gains control has completed. The adaptor ROM check is next | Fix up Multi Processor table | |
98 | The adaptor ROM had control and now returned control to BIOS POST. Performing any required processing after the option ROM returned controlA | Search for option ROMs. One long, two short beeps on checksum failure | |
99 | Any initialization required after the option ROM test has completed. Configuring the timer data area and printer base address next | Check for SMART Drive (optional) | |
9A | Set the timer and printer base address. Setting the RS-232 base address next | Shadow option ROMs | |
9B | Returned after setting the RS-232 base address. Performing any required initialization before the coprocessor test next | ||
9C | Required initialization before the Coprocessor test is over. Initializing the Coprocessor next | Set up Power Management | |
9D | Coprocessor initialized Performing any required initialization after the Coprocessor test next | Initialize security engine (optional) | |
9E | Initialization after the Coprocessor test is complete. Checking the extended keyboard, keyboard ID, and NumLock key next. Issuing the keyboard ID command next | Enable hardware interrupts | |
9F | Determine number of ATA and SCSI drivers | ||
A0 | Set time of day | ||
A1 | Check key lock | ||
A2 | Displaying any soft error next | ||
A3 | The soft error display has completed. Setting the keyboard typematic rate next | ||
A4 | The keyboard typematic rate is set. Programming the memory wait states next | Initialize typematic rate | |
A5 | Memory wait state programming is over. Clearning the screen and enabling parity and the NMI next | ||
A7 | NMI and parity enabled. Performing any initialization required before passing control to the adaptor ROM at E000 next | ||
A8 | Initialization before passing control to the adaptor ROM at E000h completed. Passing control to the adaptor ROM at E000h next | Erase F2 prompt | |
A9 | Returned from adaptor ROM at E000h control. Performing any initialization required after the E000 option ROM had control next | ||
AA | Initialization after E000 option ROM control has completed. Displaying the system configuration next | Scan for F2 key stroke | |
AB | Uncompressing the DMI data and executing DMI POST initialization next | ||
AC | Enter SETUP | ||
AE | Clear boot flag | ||
B0 | If interrupts Occurs in protected mode | The system configuration is displayed | Check for errors |
B1 | If unmasked NMI Occurs. Display Press F1 to Disable NMI, F2 Reboot | Copying any code to specific areas | Inform RomPilot about the end of POST |
B2 | POST done prepare to boot operating system | ||
B3 | |||
B4 | 1 One short beep before boot | ||
B5 | Terminate Quiet Boot (optional) | ||
B6 | Check password (optional) | ||
B7 | Initialize ACPI BIOS | ||
B8 | |||
B9 | Prepare Boot | ||
BA | Initialize SMBIOS | ||
BB | Initialize PnP Option ROMs | ||
BC | Clear parity checkers | ||
BD | Display MultiBoot menu | ||
BE | Program chipset registers with power on BIOS defaults | Clear screen (optional) | |
BF | Program the rest of the chipset»s value according to setup (later setup value program) If auto configuration is anabled, programmed the chipset with predefined values in the MODBINable Auto Table | Check virus and backup reminders | |
C0 | Turn off OEM specific cach, shadow Initialize standard devices with default values: DMA controller (8237); Programmable interrupt Controller (8259); Programmable interval Timer (8254); RTC chip | Try to boot with INT 19 | |
C1 | OEM Specific-Test to size On-Board memory | Initialize POST error manager (PEM) | |
C2 | Initialize error logging | ||
C3 | Test the first 256K DRAM Expand the compressed codes into temporary DRAM area including the compressed system BIOS & Option ROMs | Initialize error display function | |
C4 | Initialize system error handler | ||
C5 | OEM Specific-Early Shadow Enable for fast boot | PnPnd dual CMOS (optional) | |
C6 | External Cache Size Detection | Initialize note dock (optional) | |
C7 | Initialize note dock late | ||
C8 | Force check (optional) | ||
C9 | Extended checksum (optional) | ||
CA | Redirect int 15h to enable remote keyboard | ||
CB | Redirect int 13h to Memory Technologies Devices such as ROM, RAM, PCMCIA, and serial disk | ||
CC | Redirect int 10h to enable remote serial video | ||
CD | Re-map I/O and memory for PCMCIA | ||
CE | Initialize digitizer and display message | ||
D0 | The NMI is disable. Power on delay is starting. Next, the initialization code checksum will be verified | ||
D1 | Initializing the DMA controller, performing the keyboard controller BAT test, starting memory refresh, and entering 4GB flat mode next | ||
D2 | Unknown interrupt | ||
D3 | Starting memory sizing next | ||
D4 | Returning to real mode. Executing any OEM patches and setting the stack next | ||
D5 | Passing control to the uncompressed code in shadow RAM at E000: 0000h. The initialization code is copied to segment 0 and control will be transferred to segment 0 | ||
D6 | Control is in segment 0 Next, checking if «Ctrl» «Home» was pressed and verifying the system BIOS checksum. If either «Ctrl» «Home» was pressed or the system BIOS checksum is bad, next will go to checkpoint code E0h. Otherwise, going to checkpoint code D7h | ||
E0 | The onboard floppy controller if available is initialized. Next, beginning the base 512 KB memory test | Initialize the chipset | |
E1 | E1 Setup-Page E1 | Initializing the interrupt vector table next | Initialize the bridge |
E2 | E2 Setup-Page E2 | Initializing the DMA and interrupt controllers next | Initialize the CPU |
E3 | E3 Setup-Page E3 | Initialize system timer | |
E4 | E4 Setup-Page E4 | Initialize system I/O | |
E5 | E5 Setup-Page E5 | Check force recovery boot | |
E6 | E6 Setup-Page E6 | Enabling the floppy drive controller and Timer IRQs. Enabling internal cach memory | Checksum BIOS ROM |
E7 | E7 Setup-Page E7 | Go to BIOS | |
E8 | E8 Setup-Page E8 | Set Huge Segment | |
E9 | E9 Setup-Page E9 | Initialize Multi Processor | |
EA | EA Setup-Page EA | Initialize OEM special code | |
EB | EB Setup-Page EB | Initialize PIC and DMA | |
EC | EC Setup-Page EC | Initialize Memory type | |
ED | ED Setup-Page ED | Initializing the floppy drive | Initialize Memory size |
EE | EE Setup-Page EE | Looking for a floppy diskette in drive A: Reading the first sector of the diskette | Shadow boot block |
EF | EF Setup-Page EF | A read error occurred while reading the floppy drive in drive A: | System memory test |
F0 | Next, searching for the AMIBOOT.ROM file in the root directory | Initialize interrupt vectors | |
F1 | The AMIBOOT.ROM file is not in the root directory | Initialize Run Time Clock | |
F2 | Next, reading and analyzing the floppy diskette FAT to find the clusters occupied by the AMIBOOT.ROM file | Initialize video | |
F3 | Next, reading the AMIBOOT.ROM file, cluster by cluster | Initialize System Management Manager | |
F4 | The AMIBOOT.ROM file is not the correct size | Output one beep | |
F5 | Next, disabling internal cach memory | Clear Huge Segment | |
F6 | Boot to mini DOS | ||
F7 | Boot to full DOS | ||
FB | Next, detecting the type of flash ROM | ||
FC | Next, erasing the flash ROM | ||
FD | Next, programming the flash ROM | ||
FF | Flash ROM programming was successful. Next, restarting the system BIOS |
Описание звуковых сигналов
AMI BIOS Фатальные ошибки
1 beep | DRAM Refresh Failure. Try reseating the memory first. If the error still occurs, replace the memory with known good chips. |
2 beeps | Parity error in first 64K RAM. Try reseating the memory first. If the error still occurs, replace the memory with known good chips |
3 beeps | Base 64K RAM Failure. Try reseating the memory first. If the error still occurs, replace the memory with known good chips |
4 beeps | System timer failure |
5 beeps | Process failure |
6 beeps | Keyboard controller 8042-Gate A20 Error. Try reseating the keyboard controller chip. If the error still occurs, replace the keyboard chip. If the error persists, check parts of the system relating to the keyboard, e.g. try another keyboard, check to see if the system has a keyboard fuse |
7 beeps | Processor, Virtual Mode Exception Interrupt Error |
8 beeps | Display memory Read/Write test failure (non-fatal). Replace the video card or the memory on the video card |
9 beeps | ROM BIOS Checksum (32KB at F800:0) Failed. It is not likely that this error can be corrected by reseating the chips. Consult the motherboard supplier or an AMI product distributor for replacement part(s) |
10 beeps | CMOS shutdown register read/write error |
11 beeps | Cache memory error |
AMI BIOS звуковые коды (не фатальные ошибки)
2 short | POST Failure-one or more of the hardware tests has failed |
1 long 2 short | An error was encountered in the video BIOS ROM, or a horizontal retrace failure has been encountered |
1 long 3 short | Conventional/Extended memory failure |
1 long 8 short | Display/Retrace test failed |
Award BIOS звуковые коды
1 short | No error during POST |
2 short | Any Non-fatal error, enter CMOS SETUP to reset |
1 long 1 short | RAM or motherboard error |
1 long 2 short | Video error, cannot initialize screen to display any information |
1 long 3 short | Keyboard controller error |
1 long 9 short | Flash RAM/EPROM (which on the motherboard) error. (BIOS error) |
long beep | Memory bank is not plugged well, or broken |
Phoenix BIOS звуковые коды
Звуковые коды |
Описание/Что проверять? |
1-1-1-3 | Verify real mode |
1-1-2-1 | Get CPU type |
1-1-2-3 | Initialize system hardware |
1-1-3-1 | Initialize chipset registers with initial POST values |
1-1-3-2 | Set in POST flag |
1-1-3-3 | Initialize CPU registers |
1-1-4-1 | Initialize cache to mitial POST values |
1-1-4-3 | Initialize I/O |
1-2-1-1 | Initialize Power management |
1-2-1-2 | Load alternate registers with initial POST values |
1-2-1-3 | Jump to User Patch0 |
1-2-2-1 | Initialize keyboard controller |
1-2-2-3 | BIOS ROM checksum |
1-2-3-1 | 8254 timer initialization |
1-2-3-3 | 8237 DMA controller initialization |
1-2-4-1 | Reset programmable interrupt controller |
1-3-1-1 | Test DRAM refresh |
1-3-1-3 | Test 8742 keyboard controller |
1-3-2-1 | Set ES segment to register to 4GB |
1-3-3-1 | 28 Autosize DRAM |
1-3-3-3 | Clear 512K base RAM |
1-3-4-1 | Test 512K base address lines |
1-3-4-3 | Test 512K base memory |
1-4-1-3 | Test CPU BUS-clock frequency |
1-4-2-4 | Reinitialize the chipset |
1-4-3-1 | Shadow system BIOS ROM |
1-4-3-2 | Reinitialize the cache |
1-4-3-3 | Autosize cache |
1-4-4-1 | Configure advanced chipset registers |
1-4-4-2 | Load alternate registers with CMOS values |
2-1-1-1 | Set initial CPU speed |
2-1-1-3 | Initialize interrupt vectors |
2-1-2-1 | Initialize BIOS interrupts |
2-1-2-3 | Check ROM copyright notice |
2-1-2-4 | Initialize manager for PCI options ROMs |
2-1-3-1 | Check video configuration against CMOS |
2-1-3-2 | Initialize PCI bus and devices |
2-1-3-3 | Initialize all video adapters in system |
2-1-4-1 | Shadow video BIOS ROM |
2-1-4-3 | Display copyright notice |
2-2-1-1 | Display CPU typE and speed |
2-2-1-3 | Test keyboard |
2-2-2-1 | Set key click if enabled |
2-2-2-3 | 56 enable keyboard |
2-2-3-1 | Test for unexpected interrupts |
2-2-3-3 | Display prompt «press F2 to enter SETUP» |
2-2-4-1 | Test RAM between 512 and 640k |
2-3-1-1 | Test expanded memory |
2-3-1-3 | Test expanded memory address lines |
2-3-2-1 | Jump to user patch1 |
2-3-2-3 | Configure advanced cache registers |
2-3-3-1 | Enable external and CPU caches |
2-3-3-3 | Display extemal cache size |
2-3-4-1 | Display shadow massage |
2-3-4-3 | Display non-disposable segments |
2-4-1-1 | Display error massages |
2-4-1-3 | Check for configuration errors |
2-4-2-1 | Test real-time clock |
2-4-2-3 | Check for keyboard errors |
2-4-4-1 | Set up hardware interrupts vectors |
2-4-4-3 | Test coprocessor of present |
3-1-1-1 | Display onboard I/O ports |
3-1-1-3 | Detect and install external Rs232 ports |
3-1-2-1 | Detect and install external parallel ports |
3-1-2-3 | Re-initialize onboard I/O ports |
3-1-3-1 | Initialize BIOS data area |
3-1-3-3 | Initialize extended BIOS data area |
3-1-4-1 | Initialize floppy controller |
3-2-1-1 | Initialize hard-disk controller |
3-2-1-2 | Initialize local-bus hard-disk controller |
3-2-1-3 | Jump to userPatch2 |
3-2-2-1 | Disable A20 address line |
3-2-2-3 | Clear huge ES segment register |
3-2-3-1 | Search for option ROMs |
IBM BIOS звуковые коды
Звуковые коды |
Описание |
No beeps | No Power, Loose card or short |
1 short beep | Normal POST, computer is ok |
2 short beep | POST error, review screen for error code |
Continuous beep | |
Repeating short beep | No power, loose card, or short |
One long and one short beep | Motherboard issue |
One long and two short beeps | Video (EGA) display circuitry |
Three long beeps | Keyboard / keyboard card error |
One beep, blank or incorrect display | Video display circuitry |
Сброс забытого пароля к BIOS
AMI пароли:
Другие BIOS:
Phoenix BIOS: phoenix | Megastar: star |
Biostar Biostar: Q54arwms | Micron: sldkj754xyzall |
Compag: compag | Micronies: dn 04rie |
CTX international: CTX_123 | Packard Bell: bell9 |
Dell: Dell | Shuttle: spacve |
Digital Equipment: komprie | Siements Nixdorf: SKY FOX |
HP Vectra: hewlpack | Tinys: tiny |
IBM: IBM MBIUO sertafu | TMC: BIGO |
Сброс пароля BIOS программно.
CMOS ROM может быть сброшен программно, используя командную строку, командой debug
(Работает только до Windows 7 версии, в 8-ке не работает).
Сброс Award BIOS пароля:
C:>debug
-o 70 34 «Enter»
-o 71 34 «Enter»
-q «Enter»
или
C:>debug
-o 70 11 «Enter»
-o 71 11 «Enter»
-q «Enter»
Сброс AMI BIOS пароля:
C:>debug
-o 70 16 «Enter»
-o 71 16 «Enter»
-q «Enter»
или
C:>debug
-o 70 10 «Enter»
-o 71 0 «Enter»
-q «Enter»
Сброс Phoenix BIOS пароля:
C:>debug
-o 70 ff «Enter»
-o 71 17 «Enter»
-q «Enter»
Как выглядит в командной строке:
Настройки BIOS будут стёрты, так что при следующей загрузки системы, возможно надо будет изменить настройки (например если у Вас очередность запуска дисков другая, то надо переназначить, а то система не загрузится).
Аппаратный сброс CMOS BIOS перемычкой
Обычно хватает выполнения двух первых пунктов, только перемычку верните в исходное положение. Можно просто замкнуть отвёрткой штырьки, если перемычка отсутствует. Штырьки обычно подписаны на материнской плате: Clear CMOS, CL_CMOS , CRTC , CCMOS , CL_RTC, Clean CMOS, CMOS ROM Reset. Или можно просто вытащить батарейку.
Можно воспользоваться универсальной утилитой CMOS De-Animator для сброса настроек BIOS программно. Может сохранять настройки в файл и восстанавливать их. Скачать с официального сайта CMOS De-Animator
И небольшая табличка, подсказка какими клавишами можно зайти в настройки BIOS:
Расшифровка кодов 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 6×86 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 последовательно пытается заг.
POST-
коды
Award BIOS Medallion V 6.0
POST-код (hex)
Выполненная проверка
Выполнение стартовых процедур POST из Flash BIOS
CF Раннее определение типа процессора. Запись результатов в CMOS. Функциональный тест чтения/записи CMOS.
Если определение типа процессора или запись в CMOS закончились неудачей, устанавливается фатальная ошибка операции и выполнение POST останавливается
C0 Предварительная инициализация чипсета.
Запрет областей теневого ОЗУ, отключение кэша L2. Очистка кэша L1.
Программирование следующих базовых регистров чипсета.
- Контроллеров прерываний: прием по фронту IRQ, Master Controller — IRQ 00h=INT 8…IRQ 7=INT 0Fh, Slave Controller — IRQ 8= INT 70h…IRQ 15=INT 77h.
- Контроллеров ПДП.
- Интервального таймера: Counter 0 — режим деления частоты на 65 536 (18,2 Гц) для генерации запросов IRQ 0 системных часов. Counter 1 — выработка импульсов для регенерации DRAM (128 циклов выполняется за 2 мс или интервал между регенерацией двух строк составляет около 15 мкс). Counter 2 — используется для озвучивания системного динамика.
- RTC инициализируется в том случае, если произошел сбой питания от аккумулятора. Если сбоя Vcc (bat) не было, то инициализируются только регистры, отвечающие за взаимодействие RTC и процессора, но не часы
Проверка типа, объема, старшего адреса и ECC ОЗУ. Проверка первых 256 Кбайт ОЗУ. |
|
Организация в этой области транзитного буфера, в который из Flash BIOS |
|
копируется Boot Block для проверки контрольных сумм |
|
Проверка контрольной суммы BIOS и наличия метки BBSS. Если проверки некорректны, |
|
принимается решение о частичном повреждении ИМС Flash BIOS. Если проверки |
|
корректны, то в буфер копируется программа распаковки системной BIOS |
|
Распаковка системной BIOS в ОЗУ, копирование в ОЗУ факультативной системы |
|
BIOS. Подготовка к затенению BIOS |
|
Копирование выполняемого кода POST в область E000h-F000h теневого ОЗУ. |
|
Передача управления модулю Boot Block. |
|
Начало выполнения POST из теневого ОЗУ. |
Проверка целостности структуры BIOS. Если контрольные суммы проверки служебных полей BIOS совпадают, выполнение проверки ОЗУ продолжается, в противном случае управление передается программам восстановления BIOS
Выполнение POST в теневом ОЗУ (Shadow RAM
)
1 По физическому адресу 1000:0000h распаковывается модуль BIOS — программа XGROUP, позволяющая установить все ресурсы системной платы, включая системный таймер, контроллеры прерываний и ПДП, математический сопроцессор и видеоконтроллер по умолчанию
3 Выполнение ранней инициализации чипа Super I/O, первый этап был выполнен на шагах алгоритма CFh и C0h
5 Установка начальных атрибутов видеосистемы.
Проверка флага состояния CMOS, его содержимое обнуляется
7 Сброс входного и выходного буферов контроллера клавиатуры (совместимого с ИМС 8042 или 8742). Контроллер входит в состав чипа Super I/O системной
платы. Самотестирование, инициализация контроллера клавиатуры. Разрешается подключение интерфейса клавиатуры
Запрет подключения интерфейса компьютерной мыши PS/2. |
|
Определяется тип интерфейса клавиатуры (PS/2 или AT/DIN). Программируется |
|
контроллер клавиатуры. Разрешается использование клавиатуры |
|
Интерфейс PS/2-мыши еще запрещен. |
|
Для некоторых систем — определение портов, к которым подключены PS/2-клавиатура |
|
и мышь, что может вызвать переназначение портов |
|
Проверка теневого сегмента F000h циклами чтения и записи. Данная область |
|
будет использоваться для DMI и ESCD. Если проверка некорректна, то |
|
вырабатывается звуковой сигнал и код ошибки EFh выводится в порт 0080h |
|
Если записанные и считанные данные из сегмента F000h не совпадают, |
|
констатируется ошибка и выполнение POST останавливается |
10 Определение типа установленной Flash BIOS. Проверка позволяет выбрать для BIOS соответствующую программу записи, с помощью которой загружается специальная команда Read Intelligent Identifier. Команда используется также процедурами модификации блоков ESCD и DMI, которые могут быть перезаписаны как при загрузке, так и после нее — при обращении приложений к функциям Plug and Play или DMI.
Код BIOS, выполняемый в рабочем сеансе, будет декодирован и переписан в область Run-time area (F000h).
Программирование регистров чипсета
12 Выполнение цепочки тестов CMOS. В часах RTC устанавливается режим питания. Ячейки CMOS используются в дальнейшем для хранения промежуточных результатов в ходе процедуры инициализации. В частности, в ячейки загружаются значения по умолчанию
14 Выполнение ранней инициализации чипсета. На первом этапе программируются ресурсы, недоступные разработчику системной платы. На втором этапе в регистры чипсета загружаются значения, изменяемые с помощью утилиты MODBIN. Становится возможной тонкая настройка ОЗУ и устройств PCI
16 Ранняя инициализация системного тактового генератора — установка значений по умолчанию
18 Определение параметров процессора: компании производителя, семейства, поколения, определение вида и объема кэша L1 и L2, типа SMI. Выполнение функции команды CPUID (коды и архитектура процессоров различных производителей отличаются).
Проверка регистров процессора, измерение тактовой частоты ядра процессора. После выполнения функции результат размещается в 128-разрядном слове, образованном ячейками регистров центрального процессора — EAX+EBX+ECX+EDX. Для расшифровки значения используемого кэша код сдвигается и перемещается в регистр AL
Инициализация таблицы векторов прерываний (объем 1 024 байта, 256 типов |
|
прерываний). На данном этапе устанавливаются типы для 32 векторов (INT 00h- |
|
INT 1Fh), указывающих на процедуры BIOS. |
|
Выполнение проверок, направленных на обеспечение требований Y2K |
|
Проверка контрольной суммы CMOS и соответствия напряжения питания |
|
аккумулятора номиналу. Если выявлены ошибки — устанавливаются значения по |
|
умолчанию, задаваемые производителем системной платы |
|
На данном этапе прием скан-кодов с клавиатуры и их обработка контроллером 8742 и процессором невозможны, поскольку запрещены прерывания, не подготовлена область данных BIOS, а клавиатура не инициализирована. Настройки Setup BIOS не должны противоречить выполнению последовательности POST
21 Инициализация системы Hardware Power Management для ноутбуков.
Формирование таблицы физических параметров, структуры для обслуживания автономного аккумуляторного питания, функций энергосбережения при работе жестких дисков, а также операций сохранения образа ОЗУ на диске
23 Обнаружение математического сопроцессора.
Проверка количества цилиндров — 40 или 80, а также типа установленного флоппи-диска.
Выполнение ранней инициализации чипсета.
Подготовка карты ресурсов BIOS, предназначенной для дальнейшей инсталляции устройств Plug and Play, а также УВВ на шине PCI
24 В процессорах поколений Intel P6 и P7 предусмотрена возможность организации доступа к памяти микропрограмм, в которой содержатся алгоритмы выполнения каждой машинной команды. На данном этапе в микрокод микропрограмм могут быть внесены изменения, позволяющие модернизировать алгоритмы или ввести новые микрокоды, предназначенные для новых машинных команд. Процедура обновления микрокода выполняется следующим образом.
- С помощью команды CPUID идентифицируется процессор и определяются его параметры — тип (Type), семейство (Family), модель (Model) и коэффициент умножения частоты (Stepping).
- Из модуля обновления микрокода, хранимого в BIOS, считывается нужный блок объемом 2 048 байт и распаковывается не в ОЗУ, а в SM RAM.
- Обновляется микрокод процессора.
Для некоторых процессоров Intel выполняется дополнительная идентификация. Обновляется карта распределения ресурсов
Инициализируются устройства Plug and Play. Информация о ресурсах, затребованных устройствами Plug and Play, обновляется на основании сканирования данных из CMOS, расширений BIOS, расположенных на шинах расширения УВВ, а также информации, хранящейся в блоке данных ESCD. Запись данных в ESCD откладывается на финальную стадию выполнения POST
25 Ранняя инициализация PCI. Перечисление устройств на шине. Назначение ресурсов ОЗУ и УВВ.
Поиск устройства видеосистемы, расширения BIOS и запись информации в область C000:0h (сегментный адрес в регистре CS:адрес смещения в регистре IP)
26 Настройка логики, обслуживающей линии Vendor Identification.
Завершение инициализации системного тактового генератора. Отключение синхронизации неиспользуемых слотов DIMM и PCI.
Инициализация системы мониторинга напряжений и температур, выполняемая в соответствии с типом системной платы
На данном этапе прием скан-кодов с клавиатуры и их обработка контроллером 8742 и процессором невозможны, поскольку запрещены прерывания, не подготовлена область данных BIOS, а клавиатура не инициализирована. Настройки Setup BIOS не должны противоречить выполнению последовательности POST
27 Разрешение прерывания INT 09h. Повторная инициализация контроллера клавиатуры на основе новых данных (таблицы векторов прерываний, инициализации чипсета).
Для BIOS формируется 16-символьный буфер ввода и устанавливается область памяти для полноценного функционирования
29 Программирование регистров MTRR процессора поколения Р6, а также инициализация контроллера APIC процессоров Pentium.
Программирование чипсета (например, контроллера IDE) в соответствии |
|
с установками в CMOS. |
|
Измерение внутренней частоты процессора. |
|
Вызов расширения BIOS видеосистемы |
|
Инициализация модуля многоязычности. |
|
Посылка данных для отображения на экране дисплея (заставка Award, тип |
|
процессора и его скорость) |
|
Программирование чипа Super I/O |
|
Проверка битов маскирования канала 1 контроллера прерываний (совместимого |
|
40 Проверка битов маскирования канала 2 контроллера прерываний (совместимого с ИМС 8259)
Проверка функционирования контроллера прерываний (совместимого с ИМС 8259) |
|
Подсчет общей памяти проверкой каждого двойного слова в каждой странице 64 Кбайт. |
|
Запись программы, предназначенной для проверки процессоров семейства AMD |
|
Программирование регистров MTRR процессора семейства Syrix. Инициализация |
|
кэша L2 процессоров поколения P6, а также инициализация APIC для P6 |
|
Инициализация шины USB |
|
Проверка всей памяти, очистка расширенной памяти |
55 Для многопроцессорной платформы выполняется отображение числа процессоров
57 Отображение экрана логотипа Plug and Play. Ранняя инициализация устройств Plug and Play
59 Активизация ресурса антивирусной защиты — интегрированного антивирусного средства Trend Anti-Virus
60 Этап, позволяющий загрузить программу Setup.
До этой стадии POST вы должны успеть нажать соответствующую клавишу
65 Инициализация компьютерной мыши PS/2
67 Подготовка информации для адресного пространства, предназначенного для функции вызова: INT 15h (содержимое регистра AX=E820h)
На данном этапе прием скан-кодов с клавиатуры и их обработка контроллером 8742 и процессором невозможны, поскольку запрещены прерывания, не подготовлена область данных BIOS, а клавиатура не инициализирована. Настройки Setup BIOS не должны противоречить выполнению последовательности POST
Включение кэша L2 |
|
Программирование регистров чипсета в соответствии с элементами, описанными |
|
в Setup и в таблице автоконфигурирования |
|
Назначение ресурсов для всех устройств Plug and Play. |
|
Автоматическое распределение COM-портов для интегрированных устройств |
|
в том случае, если установлена опция Setup “AUTO” |
|
Инициализация контроллера флоппи-дисков. |
|
Дополнительная настройка регистров флоппи-диска |
73 Факультативная функция ввода утилиты обновления BIOS AWDFLASH.EXE, если она находится на флоппи-диске и выбрана комбинация клавиш
75 Обнаружение и инсталляция всех IDE-устройств: жестких дисков, LS-120, ZIP, CD-R/RW, DVD и т.д.
Если обнаружена ошибка, выводится соответствующее сообщение, и программа ожидает нажатия клавиши.
Если ошибка не обнаружена или нажата клавиша , выполнение POST продолжается.
Очистка заставки с логотипом EPA или производителя
82 В зависимости от типа чипсета и системной платы в ОЗУ выделяется область для управления питанием.
В таблицу ESCD вносятся последние изменения, связанные с управлением питанием.
После снятия заставки с логотипом EPA видеорежим восстанавливается. Запрос пароля, если таковой предусмотрен установками CMOS
83 Восстановление данных из стека временного хранения в CMOS
84 Вывод на экран сообщения “Initializing Plugand Play Cards…” об обнаруженных ранее устройствах Plug and Play и параметрах
85 Завершение инициализации USB.
Определение порядка загрузки с жестких дисков SCSI
87 Переключение видеосистемы на текстовый режим работы.
Построение таблиц SYSID в области DNI согласно спецификации “System Management BIOS”.
Для обслуживания сетевых устройств создается идентификатор UUID (Universal Unique ID), а также идентификатор для загрузки с устройств Fire Wire IEEE 1394
На данном этапе все основные процедуры инициализации завершены. Выполняется подготовка к загрузке операционной системы, составляются необходимые для этого таблицы, формируются массивы, структуры
89 Если программой Setup предусмотрено использование протокола ACPI, в верхнюю область адресного пространства 4 Гбайт вставляются соответствующие таблицы
Сканирование в пространстве PCI расширений BIOS, предназначенных для |
|
реализации протокола AOL (Alert On LAN). Инициализация средств AOL |
|
Разрешение использования логических средств поддержки немаскированного |
|
прерывания NMI. |
|
Разрешение использования контроля четности модулей ОЗУ |
|
Для горячего подключения мыши PS/2 разрешается линия IRQ 12. |
|
Обслуживание линии IRQ 11, нормализация параметров шумовых помех линий |
|
запросов прерываний |
91 Подготовка условий для обслуживания жестких дисков в режиме Power Management. Операции подобного типа (Suspend to RAM) могут быть реализованы в рабочем сеансе операционной системы.
Установка переменных BIOS, хранящих базовые адреса последовательных и параллельных портов, которые располагают программами расширения BIOS
93 Подготовка к сохранению информации о разделах загрузочных устройств
94 Если Setup предусмотрена, включается кэш L2. Программируется параметр Boot Up Speed.
Завершение инициализации чипсета и системы управления питанием.
Снятие стартовой заставки BIOS, на экран монитора выводится таблица распределения ресурсов.
Настройка регистров процессоров семейства AMD K6. Завершающее обновление регистров процессоров семейства Intel P6.
Окончательная инициализация подсистемы удаленной загрузки Remote Pre Boot
95 Установка режима автоматического перехода на зимнее/летнее время Daylight Saving.
Программирование контроллера клавиатуры на число нажатий в секунду и время ожидания до входа в режим автоповтора.
Чтение идентификатора клавиатуры KBD ID.
Для 101-кнопочной клавиатуры устанавливается флаг NumLock в соответствии с информацией CMOS
96 Сохранение информации о разделах загрузочных устройств.
В многопроцессорных системах выполняется завершающая настройка системы, формируются служебные таблицы и поля, используемые в рабочем сеансе операционной системы.
Настройка регистров процессоров семейства Cyrix.
Заполнение и корректировка таблицы ESCD в соответствии с состоянием системы Power Management устройств Plug and Play и ATAPI.
Корректировка CMOS в соответствии с требованиями протокола Y2K.
Установка счетчика системных часов DOS Time в соответствии с показаниями RTC CMOS. Значение времени из формата “часы:минуты:секунды” пересчитывается
в такты (временные интервалы следования импульсов) интервального таймера 18,2 Гц и записывается в область переменных BIOS — DOS Time.
На данном этапе все основные процедуры инициализации завершены. Выполняется подготовка к загрузке операционной системы, составляются необходимые для этого таблицы, формируются массивы, структуры
Сохранение разделов устройств загрузки для дальнейшего использования интегрированными антивирусными средствами Trend Anti-Virus и Paragon Anti-Virus Protection.
Разрешение использования кэша L1.
На динамик системного блока генерируется звуковой сигнал окончания POST. Построение и сохранение таблицы MSIRQ.
Выполнение подготовки к загрузке операционной системы
FF Передача управления программе-загрузчику начального сектора BOOT. Выполнение прерывания BIOS INT 19h.
Вызванная подпрограмма позволяет (в соответствии с опцией меню BIOS Features Set Up программы Setup) опросить загрузочные устройства для поиска сектора загрузки. Для загрузки информация из сектора Цилиндр: 0, Головка: 0, Сектор:
1 считывается по адресу 07C0:0000h, после чего управление командой FAR JMP передается на начало этого блока
Выполнение программы, записанной в загрузочном секторе
ПРИМЕЧАНИЕ.
ECC
(Error Correcting Code) — код коррекции ошибок
применяется в модулях ОЗУ,
способствуя
повышению отказоустойчивости ПК. ECC позволяют исправить ошибку в одном разряде и обнаружить в двух разрядах. Поэтому компьютер, в памяти которого используются подобные коды, в случае ошибки в одном разряде может работать без прерывания, причем данные не будут искажены
BBSS
(Boot Block Specification Signature) —
метка сигнатуры спецификации загрузочного блока.
SMI
(System Management Interrupt) —
аппаратное обеспечение,
интегрированное в процессор,
предназначенное для управления потребляемой мощностью. Для обслуживания этих компонентов используется высокоприоритетное прерывание.
Y2K
—
требования,
предъявляемые к коммерческим продуктам компьютерных систем для
обеспечения функциональной совместимости, функциональности и прочих параметров, имевших место до и после 2000 года.
DMI
(Desktop Management Interface) —
протокол,
позволяющий обеспечить взаимодействие
программных средств с компонентами системных плат.
MTRR
(Memory Type Range Registers) —
регистры процессоров поколений
P6
и
P7,
в которые
заносятся данные, описывающие свойства областей памяти и определяющие тип кэши-рования памяти.
APIC (Advanced Programmable Interruption Controller) — усовершенствованный программируемый контроллер прерываний
,
входящий в состав чипсета.
Процессор поколения
P6
также
располагает подобным контроллером для мультипроцессорного применения.
MSIRQ
(Microsoft IRQ Routing Map) — таблица
карты
распределения
прерываний
, стандартизирована Microsoft.
SM RAM
(System Management RAM) —
одно из названий оперативной регистровой памяти
небольшой емкости, предусмотренной в архитектуре процессоров, начиная с Pentium Pro и выше, предназначенной для хранения служебных данных.
В случае неадекватного завершения каждого из процессов алгоритм переходит на обра ботку особого случая, и POST BIOS Medallion генерирует коды, отмеченные ниже:
POST-
коды
особых
случаев
Award BIOS V 6.0 Medallion
Код системных событий (System Events codes)
Код, активизируемый при обслуживании компонентов APM или ACPI (Power Management Debug codes)
Энергосбережение с отключением напряжения питания +12 В |
|
Переход в режим работы с минимальным энергопотреблением |
|
Прерывание для выхода из режима энергосбережения по событию |
|
Переход процессора в режим энергосбережения путем снижения его тактовой |
|
Переход в режим частичного энергосбережения с использованием технологии ACPI |
|
Использование компонента SMI для перехода в режим энергосбережения |
|
Переход процессора в режим энергосбережения с использованием технологии APM |
|
Переход системы в режим энергосбережения с использованием технологии APM |
|
Перевод системы в режим полного энергосбережения |
|
Сообщение о фатальных ошибках выполнения операций (System Error codes)
Ошибка обработки кода ECC |
|
Ошибка жесткого диска при возврате из режима энергосбережения |
|
Несовпадение данных при записи в сегмент F000h и считывании из него |
|
Для сокращения времени прохождения тестовой программы POST Award BIOS вы можете воспользоваться опцией Quick Power On Self Test, которую можно обнаружить в программе Setup. В этом случае запускается модифицированная версия теста Award Software, которая, в отличие от полной версии программы, выполняется быстро.
Коды контрольных точек POST AMI BIOS 8 V1.4
Представление о дисплее кодов контрольных точек
Для отображения контрольных точек POST AMI BIOS применяются диагностические платы POST Diagnostic Card, индикаторы на системных платах, а также дисплеи контроль
ных точек AMI BIOS Checkpoint Display
.
Дисплей представляет собой строку кода в нижнем правом углу экрана монитора, отобра жаемую во время прохождения POST
Недостаток использования дисплея кодов контрольных точек состоит в невозможности при-менения этого метода при отключенной видеосистеме.
Назначение диспетчера инициализации устройст
В различные периоды тестирования POST управление передается специальной про грамме диспетчеру инициализации устройств DIM
(Device Initialization Manager).
Эта программа получает управление от BIOS в том случае, если необходимо проверить сис темные или локальные шины компьютера. Существует несколько контрольных точек POST, предназначенных для запуска этой программы.
2Ah инициализация устройств на системной шине.
38h инициализация устройств IPL.
39h индикация ошибок при инициализации шин.
95h инициализация шин, управляемых расширениями BIOS.
DEh — ошибка конфигурации ОЗУ.
DFh — ошибка конфигурации ОЗУ.
Сообщения, генерируемые DIM, также выводятся в диагностический порт 80h и хранятся в информационном слове в процессе выполнения проверки.
Слово, в котором хранится отмеченная информация, содержит младший байт, совпадаю щий с системным POST кодом. Старший байт делится на две тетрады. Ниже представлено описание кодов, загружаемых в тетрады.
Поля старшей тетрады.
Инициализация всех устройств на интересующих шинах запрещена.
Инициализация статических устройств на интересующих шинах.
Инициализация устройств вывода информации на интересующих шинах.
Инициализация устройств ввода информации на интересующих шинах.
Инициализация устройств системной загрузки (IPL) на интересующих шинах.
Инициализация устройств общего назначения на интересующих шинах.
Сообщение об ошибках для интересующих шин.
Инициализация устройств, управляемых расширениями BIOS (для всех шин).
Инициализация загрузочных расширений BIOS, соответствующих BIOS Boot Specification (для всех шин).
Младшая тетрада.
Системные процедуры инициализации (DIM).
Шины подключения интегрированных системных устройств.
Шина ISA Plug and Play.
Шина PCMCIA.
В том случае, если обнаружена ошибка конфигурации ОЗУ, в диагностический порт вы водится циклическая последовательность кодов DEh, DFh и контрольных точек конфигура ции, которые могут принимать следующие значения.
00 ОЗУ не обнаружено.
01 установлены модули DIMM различных типов.
02 чтение из узла SPD (Serial Presence Detect) модуля DIMM произведено неудачно.
03 модуль DIMM не может быть использован на данной частоте.
04 модуль DIMM не может быть использован в данной системе.
05 ошибка в младшей странице памяти.
Контрольные точки процедур POST, выполняемых в AMIBIOS
, были переработаны и дополнены в 1995 году и до настоящего времени не претерпели существенных изменений. Первое описание POST-кодов или чекпойнтов (check points), как они именуются в AMI, в их нынешнем виде появилось в связи с выходом в свет ядра v6.24 от 15 июля 1995 года. Некоторые изменения в своё время были внесены в AMIBIOS v7.0.
Особенности выполнения стартовых процедур AMIBIOS
Если в процессе старта в диагностическом порту появляются данные 55
, AA
, не следует сопоставлять эту информацию с POST-кодами – мы имеем дело с типовой тестовой последовательностью, в задачи которой входит проверка целостности шины данных как таковой.
На этапе старта вывод в диагностический порт данных носит специфический для каждой платформы характер. В некоторых реализациях первый визуализируемый код связан с действиями, который компания AMI называет chipset specific stuff. Эта процедура сопровождается выводом в порт 80h значения CC
и выполнением ряда действий по настройке регистров системной логики. Как правило, код CC
возникает в тех случаях, когда используется системная логика от Intel.
PIIX — это чипсеты TX, LX, BX
Некоторые бортовые микросхемы ввода-вывода содержат RTC и контроллер клавиатуры, которые по старту находятся в отключенном состоянии. Цель BIOS – проинициализировать эти ресурсы платы для дальнейшего использования. В этом случае первая стартовая процедура, связанная с настройкой контроллера клавиатуры, сопровождается выводом значения 10
, затем выполняется инициализация RTC, о чем свидетельствует появление в диагностическом порту кода DD
. Следует отметить, что отказ хотя бы одного из этих ресурсов повлечет нестарт системной платы в целом на первом же этапе выполнения POST.
На ряде плат процесс инициализации начинается с перевода CPU в защищенный режим. В этом случае вслед за первым визуализируемым кодом 43
выполнение POST продолжается так, как описано в документации AMIBIOS – управление передается в точку D0
.
Device Initialization Manager
Начиная с AMIBIOS95+ компания American Megatrends задекларировала обобщенный подход к инициализации устройств на всех типах шин. Для этого был разработан универсальный механизм – Device Initialization Manager (DIM), реализованный в виде автономного модуля. Запуск процедур DIM осуществляется в особые моменты выполнения POST, когда необходимо отобразить состояние инициализации Option ROM, устройств ввода и отображения информации:
Старший байт отображается в порт 81, указывая на тип выполняемой процедуры Function Number и топологию, где локализованы заданные устройства: Device Number. Топология, как аргумент, отображается в младшей тетраде 81 порта и может принимать следующие значения:
Старшая тетрада 81-го порта Function Number указывает либо на процедуру инициализации, применимую к выбранным устройствам, либо на подмножество устройств, объединенных по заданному признаку, которые следует подготовить к работе.
Этот параметр в современной редакции допускает следующие значения:
0 | Reset, Detect, Disable | Построение с помощью менеджера ресурсов карты распределения ресурсов. Из блока конфигурационных компонентов NVRAM строится стратегия инициализации всех устройств, описанных функциями 01,…,05 |
---|---|---|
1 | Initialization for Static Devices | Инициализация дополнительных (off-board) контроллеров PCI IDE |
2 | Initialization for Output Devices | К инициализации средств отображения относится поиск в контрольной точке 2Ah видеоадаптеров, VGA BIOS которых размещается в сегменте C000h. Функция выполняет процедуру ROM Scan, начиная с региона Optional EGA ROM путем поиска сигнатуры 55AAh. Если сигнатура обнаружена, проверяется контрольная сумма и принимается решение о том, что Add-ROM верифицирован и готов принять управление от BIOS. Особенность процедуры — уменьшение пространства RAM выделенного для ROM в связи с «усадкой», когда код занимает меньше места, чем зарезервировано. В этом случае освобождаются регионы C800h/CC00h. |
3 | Initialization for Input Devices | Инициализация устройств консольного ввода (клавиатура и манипулятор «мышь») выполняется только если это указано в установках CMOS Setup. |
4 | Initialization for IPL Devices | Инициализация устройств Initial Program Load (IPL), с которых возможна загрузка операционной системы, выполняется в контрольной точке 38h. К IPL-устройствам согласно BIOS Boot Specification относятся FDD и HDD, позволяющие загрузить ОС. Функция проверяет соответствие найденных дисков по списку, хранящемуся в NVRAM, разрешает их использование и формирует запрос на выделение адресного пространства, портов, IRQ. Использование устройств не указанных в NVRAM становится возможным только если они поддерживают Auto-Detect. |
5 | Initialization for General Devices | Инициализация периферийных (on-board) и дополнительных (off-board) контроллеров, поддерживающих стандарт PnP, а также подключенных к шине PCI контроллеров USB (Universal Serial Bus). |
6 | POST Error Flags | Функция сбора и обработки информации об ошибках выполняется для вывода на экран сообщений пользователю в контрольной точке 39h. Обрабатываются ситуации конфликтов при распределении доступа к ресурсам памяти, портов ввода-вывода, запросов IRQ. Исследуются загрузочные возможности HDD, исходя из информации об их подключении (Master/Slave, Device ID) к соответствующим контроллерам и проверяется бесконфликтность таких подключений. Обрабатываются ошибки от консольных устройств (клавиатура и монитор). Проверяется достоверность и контрольные суммы информации в NVRAM, а также функциональность носителей NVRAM: CMOS и EEPROM. |
7 | Special Function | К специальным функциям модуля DIM относится поиск и инициализация устройств в контрольной точке 95h, Optional ROM которых размещается в сегменте C800h. Этот сегмент используется для дополнительных BIOS контроллеров SCSI/IDE и их RAID модификаций, которые соответствуют BIOS Boot Specification (BBS). Если обнаружен хотя бы один Optional ROM, не поддерживающий BBS, к примеру, MFM-контроллер, AMIBIOS выбирает особый режим старта операционной системы. Специальная функция обслуживает также классифицированные USB Mass Storage устройства. |
8 | Configure Before Boot IPL Devices | Финальное конфигурирование устройств системной загрузки, ранее инициализированных с помощью функции 4 в контрольной точке 38h, требуется на этапе передачи управления операционной системе. По результатам выполнения CMOS Setup, если изменены параметры Boot Device Priority, корректируются таблицы HDD IDE/SCSI, устройств со сменными носителями и CD-ROM. Завершается процедура построением списка загрузочных устройств в порядке, предписанном пользователем. |
POST-коды
AMIBIOS 6.x
Как следует из названия, новая версия увидела свет в 1997 году. AMIBIOS97 – это современный во всех отношениях продукт с поддержкой AGP, InstantON и прочих новинок. Разработка и управление проектом доведены до совершенства с помощью разнообразных скрипт-процессоров, позволяющих генерировать код, в зависимости от особенностей построения NVRAM, DMI и т.п.
00 | 03 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0E | 0F | ||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
10 | 11 | 12 | 13 | 14 | 19 | 1A | |||||||||
23 | 24 | 25 | 26 | 27 | 28 | 29 | 2A | 2B | 2C | 2D | 2E | 2F | |||
30 | 31 | 32 | 33 | 34 | 37 | 38 | 39 | 3A | 3B | ||||||
40 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 4B | 4C | 4D | 4E | 4F | ||
50 | 51 | 52 | 53 | 54 | 57 | 58 | 59 | ||||||||
60 | 62 | 63 | 65 | 66 | 67 | ||||||||||
7F | |||||||||||||||
80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8B | 8C | 8D | 8F | ||
91 | 95 | 96 | 97 | 98 | 99 | 9A | 9B | 9C | 9D | 9E | 9F | ||||
A0 | A2 | A3 | A4 | A5 | A6 | A7 | A8 | A9 | AA | AB | AC | AD | AE | ||
B0 | B1 | ||||||||||||||
CC | CD | CE | CF | ||||||||||||
D0 | D1 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | DA | DB | DC | DD | DE | DF | |
E0 | E1 | E2 | E4 | E6 | EC | ED | EE | EF | |||||||
F0 | F1 | F2 | F4 | F5 | FB | FC | FD | FF |
код | название | описание |
---|---|---|
EE | В современных реализациях AMIBIOS первый визуализируемый код связан с обращением к устройству, с которого возможна загрузка для восстановления BIOS | |
CC | Chipset specific stuff Инициализация регистров системной логики |
В некоторых версиях AMIBIOS первый визуализируемый код связан с инициализацией регистров системной логики от Intel, построенной на основе контроллера PIIX: чипсеты TX, LX, BX. Если система находится в режиме энергосбережения, выполняется 5V Resume — возврат к полноценному функционированию. В этом случае в диагностический порт посылается значение DD , и выполняется процедура, задача которой состоит в восстановлении из CMOS содержимого регистров контроллера памяти. |
CD | Chip ID is unknown Тип Flash ROM не опознан |
Специфичная для плат Gigabyte процедура обслуживания DualBIOS — код производителя и код микросхемы Flash ROM стартового BIOS не найдены в списке поддерживаемых устройств. В числе причин, по которым происходит данное событие — неисправность Flash ROM, нарушение (повреждение) проводников и элементов в схеме подключения BIOS. |
CE | System halts to wait for hardware reset Несовпадение контрольных сумм в стартовом BIOS |
Специфичная для плат Gigabyte процедура обслуживания DualBIOS. Если обнаружено несовпадение контрольных сумм в стартовом BIOS, выполняется остановка. После перезагрузки система запускается с запасной микросхемы Flash ROM. |
CF | DualBIOS Feature inaccessible Ошибка в доступе к запасной микросхеме Flash ROM |
Ошибка в доступе к запасной микросхеме Flash ROM возникает в случае, когда невозможно коммутировать сигналы, подключенные к выводам GPIO (General Purpose Input Output), управляющие опцией DualBIOS Feature. Кроме аппаратных проблем, подобная ситуация может произойти также по причине того, что запасная микросхема Flash ROM отсутствует на системной плате. |
D0 | Power on delay is starting, Verify initialization code checksum Запрет немаскируемого прерывания NMI. Отработка временной задержки для затухания переходных процессов. Проверка контрольной суммы Boot Block, останов при несовпадении. |
Для того, чтобы «переждать» переходные процессы, связанные с включением питания, выполняется аппаратная задержка сигнала Power Good. Временная задержка в BIOS состоит из вывода тестовых последовательностей в диагностический порт для проверки линий данных. Базовая проверка адресных линий выполняется с помощью вычисления объема загрузочного блока (Boot Block) и его контрольной суммы. Если контрольная сумма не совпадает, прохождение POST прекращается. В виду того, что процессор не имеет средств запрета NMI, эта процедура осуществляется через программно-доступный триггер, управляемый из индексных регистров CMOS. Аналогичным образом выполняется запрет контроля четности. |
D1 | Performing the keyboard controller BAT Test, check Wake-Up status, starting memory refresh, and entering 4 GB flat mode Выполнение процедуры регенерации памяти и Basic Assurance Test. Переход в 4 GB режим адресации памяти. |
Контроллеру клавиатуры дается команда BAT (Basic Assurance Test), и проверяется результат ее отработки. Если старт системы выполнен по команде Wake Up, управление передается соответствующим процедурам. Запускаются схемы регенерации памяти — задается режим счета и константа счета для первого канала системного таймера. Содержимое регистров центрального процессора сохраняется в CMOS. Процессор переключается в защищенный режим и устанавливает 4Gb лимиты сегментов в регистрах Descriptor Cache. Затем выполняется возврат в реальный режим. При этом установленные лимиты сегментов сохраняются, что обеспечивает адресацию 4Gb пространства. |
D3 | Starting memory sizing Определение объема и первичный тест памяти |
Первичная инициализация регистров системной логики позволяет приступить к определению объема памяти. Эта процедура устанавливает значение адреса BIOS и диапазон адресов для каждого из банков памяти, в соответствии с их объемами. Адрес, начиная с которого прекращается совпадение читаемых и записанных значений, принимается как граница памяти. Процедура памяти носит аппаратно-зависимый характер и выполняется с учетом особенностей платформы. |
D4 | Test 512 kB done. Returning to real mode Возврат в реальный режим адресации памяти. Ранняя инициализация чипсета Установка стека |
С помощью операций записи и контрольного чтения проверяется базовый регион Conventional Memory. Операция выполняется двойными словами с помощью ассемблерных команд repe stosd. Если задано прохождения POST в ускоренном режиме, то процедура носит характер обнуления области в 512 Кб с последующей верификацией данных в памяти. Процессор переводится в Real Mode, лимиты сегментов устанавливаются равными 0000FFFFh, что соответствует режиму 16-битовых адресов для обслуживания 64 Кб сегментов. |
D5 | The initialization code is copied to segment 0 and control will be transferred to segment 0 Перенос модуля POST из Flash ROM в транзитную область памяти |
Выполняется перенос модуля Boot Block из Flash ROM в транзитную область памяти, подготовленную на предыдущем шаге. Инициализационный код BIOS размещается начиная с адреса 0 и на него передается управление. |
D6 | Enable Internal Cache. Checking if Ctrl Home was pressed and verifying the system BIOS checksum При несовпадении контрольной суммы или CTRL+Home выполняется переход на процедуру восстановления Flash ROM (Код E0) |
Впервые с момента старта системы разрешается использование процессорного кэш L1. Контроллер клавиатуры программируется для ввода комбинации клавиш Ctrl+Home, по которой пользователь может форсировать выполнение процедуры восстановления Flash ROM. Проверка контрольной суммы BIOS выполняется только в режиме ускоренного прохождения POST, в штатной ситуации она переносится на следующий шаг. Если произошло хотя бы одно из этих событий, запускается процедура перезаписи Flash ROM. |
D7 | Transfer control to main BIOS Передача управления служебной программе, осуществляющей распаковку системного BIOS |
При штатном прохождении POST выполняется подсчет контрольной суммы BIOS и, в случае успешной проверки, управление передается системному интерфейсному модулю, в задачу которого входит распаковка исполняемого кода и запись его в Shadow RAM. Современные версии AMIBIOS на этом завершают стартовую процедуру из Flash ROM, и POST продолжается из оперативной памяти. Существует ряд реализаций, в частности на некоторых платформах Intel, где перенос кода BIOS в RAM детализирован промежуточными процедурами D8-DC. Если контрольные суммы BIOS не совпадают, принимается решение о вызове процедуры перезаписи Flash ROM. Выполняется инициализации контроллера ввода-вывода (SIO) и управление передается на шаг E0h. |
D8 | The main system BIOS runtime code will be decompressed Полная распаковка системного BIOS |
В ранних версиях AMIBIOS выполняется распаковка исполняемого кода в транзитный буфер по адресу 1000:0000. Необходимость временного хранения связана с тем, что копия BIOS в системной памяти не может быть создана до тех пор, пока не будет запрещен доступ к ROM. |
D9 | Passing control to the main system BIOS in shadow RAM Передача управления системному BIOS в Shadow RAM |
Регистры системной логики настраиваются так, что обращение к Flash ROM перенаправляется на копию BIOS в Shadow RAM. Исполняемый код переносится из области временного хранения в сегмент F000. POST передает управление в контрольную точку 03 . |
DA | Read SPD is over. Load CAS latency into memory controller Чтение информации из SPD (Serial Presence Detect) модулей DIMM |
В зависимости от аппаратных особенностей платформы, выполняется чтение SPD из установленных модулей DIMM. По результатам опроса устанавливаются регистры чипсета, отвечающие за временные характеристики работы с памятью. Формируется значение Memory Top. |
DB | Use MTRRs to control memory access Настройка MTRR регистров центрального процессора |
Платформы, построенные на процессорах AMD, выполняют настройку MTRR-регистров таким образом, чтобы перенаправить циклы обращения к памяти с шины ISA в область PCI-адресов. После включения кэш инициализация памяти завершается и выполняется запуск процедуры регенерации. |
DC | End of memory detection. RAM is in normal operation mode Контроллеры памяти программируются согласно данным, полученным из SPD |
Регистры контроллера памяти программируются согласно значениям, полученным из SPD. Модули DIMM переводятся из командного режима в режим нормального функционирования. |
DD | Early initialization RTC and KBC Ранняя инициализация RTC, который интегрирован в SIO чип |
Некоторые бортовые микросхемы ввода-вывода содержат RTC и контроллер клавиатуры, которые по включению питания находятся в отключенном состоянии. Цель BIOS — проинициализировать эти ресурсы платы для дальнейшего использования. Следует отметить, что отказ хотя бы одного из этих ресурсов повлечет нестарт системной платы в целом на первом же этапе выполнения POST. Если система находится в режиме энергосбережения, выполняется 5V Resume — возврат к полноценному функционированию: выполняется процедура, которая восстанавливает содержимое регистров контроллера памяти из CMOS. В этом случае управление передается в контрольную точку 11 . |
DE | Ошибка конфигурации системной памяти. Фатальная ошибка | Если в процессе инициализации возникает фатальная ошибка конфигурации памяти, в диагностический порт последовательно выводятся значения DF и DE , а следом за ними код ошибки. . На системный динамик выводится последовательность звуковых сигналов, соответствующая коду ошибки, увеличенному на 5. Выполнение POST прекращается. |
DF | Invalid Memory Configuration Ошибка конфигурации системной памяти |
|
E0 | Start recovery procedure Выполняется подготовка к перехвату INT19 и проверяется возможность старта системы в упрощенном режиме |
Процедура восстановления BIOS выполняется, если пользователь форсировал программирование Flash ROM, удерживая по старту клавиши Ctrl+Home, либо при несовпадении контрольных сумм. В современных BIOS конфигурирование контроллера гибких дисков в составе SIO завершено еще на предыдущем этапе, а группа процедур, выполнявшихся ранее в точках E1 , E2 , E6 сведена к установке векторов прерываний и подготовке контроллера DMA. Выполняется подготовка к перехвату INT19 и проверяется возможность старта в упрощенном режиме. Если обнаружены ошибки, выводится предупреждение пользователю. См. комментарий к коду 11 . |
E1 | Initializing the interrupt vector table Установка векторов прерываний |
Установка векторов прерываний выполняется исходя из ограниченных возможностей загрузочного блока. В нем хранится Run-Time код, содержащий обработчики прерываний для процедуры перезаписи Flash ROM, который определяет сокращенный вариант сервиса. См. комментарий к коду 12 . |
E2 | Восстановление содержимого CMOS, поиск и инициализация BIOS | См. комментарий к коду 14 . |
E3 | Подготовка контроллеров прерываний и непосредственного доступа к памяти | Инициализация контроллера DMA состоит в установке полярности сигналов DRQ и DACK, назначении приоритетов каналов и запрете удлиненного цикла записи. Для контроллера прерываний устанавливается режим прием запросов по фронту сигнала IRQ и назначается режим фиксированных приоритетов. Векторные прерывания IRQ0-IRQ7 картируются на INT8-INT0F, а IRQ8-IRQ15 — на INT70h-INT77. См. комментарий к коду 13 . |
E6 | Enabling the floppy drive controller and Timer IRQs. Enabling internal cache memory Разрешение прерываний от системного таймера и FDC |
Разрешаются прерывания от системного таймера IRQ0 и контроллера дисковода IRQ6, для этого в регистре маскирования запросов мастер-контроллера (порт 21) обнуляются биты 0 и 6. Для того чтобы читаемая информация была кэширована в Internal Cache, необходимо выполнение двух условий, объединенных по «И»: в регистре управления процессора CR0 бит 30 должен быть обнулен; при выполнении цикла чтения памяти сигнал разрешения кэширования KEN#, формируемый логикой, должен быть активен. |
EC | Initializing the DMA and Interrupt controllers Повторная инициализация контроллеров IRQ и DMA |
Настройка контроллера прямого доступа к памяти и контроллера прерываний. Генерация таблицы векторов прерываний. |
ED | Initializing the floppy drive Инициализация дисковода |
Инициализация дисковода состоит из ряда процедур, одна из которых предназначена для определения количества дорожек. Если дисковод 80-дорожечный, после позиционирования на цилиндр с номером 60 обратный ход на цилиндр 1 переводит сигнал track0 в пассивное состояние, а еще один шаг на цилиндр 0 — в активное. Если дисковод 40-дорожечный, при попытке позиционирования на цилиндр 60 головки упрутся в ограничитель, часть шаговых импульсов не будет отработана и собьется момент перехода с цилиндра 1 на 0, что обнаружится при анализе сигнала track0. Определяется продольная плотность записи для установленного носителя, для чего выполняется чтение при двух значениях тактовой частоты FDC, управляемой через порт 3F7h. Если успешное чтение имело место при обмене данными со скоростью 500 Кбит/с, принимается решение, что установлена дискета 1.2/1.44Mb, при 250 Кбит/с — 360/720Кb. По значению байта количества секторов в загрузочном секторе уточняется объем носителя. 15 sec/track соответствует дисководам объемом 1.2 Mb, а для устройств 1.44 Mb используется значение 18 sec/track. Размер устройства — 5.25« или 3.5» — для данной процедуры определять не обязательно, так как стоит задача получить информацию о дисководе и носителе достаточную для загрузки, при условии, что из CMOS ее брать нельзя. Если в процессе выполнение инициализации дисковода обнаружены ошибки, дальнейшее прохождение POST не выполняется. |
EE | Looking for a floppy diskette in drive A: Reading the first sector of the Diskette Чтение загрузочного сектора с дискеты |
В современных реализациях AMIBIOS код EE — первый визуализируемый POST код, который выводится в диагностический порт при обращении к устройству, с которого возможна загрузка для восстановления BIOS. Повторный вызов процедуры чтения загрузочного сектора с дискеты (Cylinder:00, Head:00, Sector:01) выполняется на этапе восстановления BIOS. Если носитель не обнаружен, выводится приглашение пользователю «Insert diskette in A:». |
EF | A read error occurred while reading the floppy drive Ошибка дисковых операций |
В эту точку управление передается, если обнаружены ошибки при дисковых операциях и с носителя не удалось прочитать загрузочный сектор. Сообщение об ошибках выводится на монитор, прохождение POST продолжается до успешного завершения операции. Если сбои при чтении вызваны аппаратными проблемами, неуспешные попытки чтения формируют бесконечный цикл, выход из которого требует вмешательства пользователя. |
F0 | Searching for the AMIBOOT.ROM file in the root directory Поиск файла AMIBOOT.ROM |
По содержимому служебных полей загрузочного сектора определяется, где помещен корневой каталог, в котором выполняется поиск файла с именем AMIBOOT.ROM. Имя файла AMIBOOT.ROM — зарезервированная константа. Для успешного восстановления BIOS необходимо переименовать файл на гибком диске в соответствии с данным соглашением. |
F1 | The AMIBOOT.ROM file is not in the root directory В корневом каталоге файл AMIBOOT.ROM не найден |
В эту точку управление передается при ошибке чтения корневого каталога либо если в нем не найден файл AMIBOOT.ROM. |
F2 | Reading and analyzing the floppy diskette FAT to find the clusters occupied by the AMIBOOT.ROM file Считывание FAT |
Считывается FAT (File Allocation Table) дискеты и по содержимому каталога определяется начало кластерной цепочки, соответствующей файлу AMIBOOT.ROM. В случае, если файл с указанным именем не найден, выполняется безусловный переход в контрольную точку F1 для организации бесконечного цикла, выход из которого возможен только при успешном чтении файла с образом BIOS. |
F3 | Reading the AMIBOOT.ROM file, cluster by cluster Считывание AMIBOOT.ROM |
На основании цепочки кластеров, описанной в FAT, считывается файл AMIBOOT.ROM. |
F4 | The AMIBOOT.ROM file is not the correct size Объем файла AMIBOOT.ROM не соответствует объему Flash ROM |
В эту точку управление передается, если размер файла с образом BIOS не соответствует объему микросхемы Flash ROM, установленной на системной плате. |
F5 | Disabling internal cache memory Запрет Internal Cache |
Путем установки в «1» бита 30 регистра CR0 запрещается Internal Cache для того, чтобы обеспечить когерентность данных при взаимодействии с Flash ROM. В противном случае, после считывания статусного регистра микросхемы все действия будут выполняться над кэш-копией. Процедура отключения кэш носит аппаратно-зависимый характер. Для некоторых наборов системной логики запрет кэш на данном шаге не выполняется, так как адресный регион, в котором находится Flash ROM, является некэшируемым. |
FB | Detecting the type of Flash ROM Определение типа Flash ROM |
Определение типа Flash ROM выполняется, как правило, с помощью команды Read Intelligent Identifier. После её записи по любому адресу в регионе ROM, запоминающее устройство переключается из режима чтения памяти в режим ReadID. В таком состоянии из указанного региона будет читаться не содержимое ROM, а идентификаторы: по смещению 0 — Manufacturer Code; по смещению 1 — Device Code. Перед выполнением всех этих действий необходимо снять блокировку сигнала Flash WE, а также разрешить доступ к региону, для этого программируются регистры системной логики. |
FC | Erasing the Flash ROM Стирание основного блока Flash ROM |
Flash ROM состоит из загрузочного блока, одного или нескольких блоков параметров и основного блока. Для стирания основного блока выполняется команда Erase Flash, состоящая из кодов Erase Setup и Erase Confirm. Flash ROM переходит в режим стирания и в его адресном пространстве считывается не содержимое, а статус, на основании которого процессор определяет момент завершения операции и ее успешность. |
FD | Programming the Flash ROM Программирование основного блока Flash ROM |
Программирование основного блока выполняется по алгоритму, который специфицирован производителем запоминающего устройства. Как правило, для каждой записываемой ячейки передается команда, которая состоит из двух кодов: Program Setup и записываемого байта. Момент завершения и успешность операции записи контролируется по статусному регистру Flash ROM. Процесс циклически повторяется для всех ячеек основного блока. |
FF | Flash ROM programming was successful. Next, restarting the system BIOS Рестарт BIOS Коды распакованного системного BIOS, выполняемые в ShadowRAM (Runtime code is uncompressed in F000 shadow RAM) |
В эту точку управление передается в случае успешного программирования FlashROM. Далее необходимо выполнить рестарт BIOS. Для этого выполняется команда прямого межсегментного перехода по адресу FFFF:0000 (CS=FFFF, IP=0000). |
10 | Issuing KBC blocking and unblocking command Ранняя инициализация контроллера клавиатуры |
Клавиатуре передана команда сброса. В порт 64h посылаются команды C8/C9 разрешающие или запрещающие управление линией А20. В зависимости от аппаратной реализации используются выводы общего назначения Pin23 и Pin24, соответствующие первому и второму биту второго порта контроллера клавиатуры, совместимого по программной модели с 82С42. |
11 | Restore the DRAM registers Возврат из состояния STR (Suspend to RAM) |
Возврат из состояния STR (Suspend to RAM) предполагает восстановление контента оперативной памяти. Для этого из CMOS считывается, а в регистры контроллера памяти записывается содержимое, актуальное к моменту выполнения STR. Запускаются схемы регенерации памяти. E0 . |
12 | Reenable SMRAM. Setup MTRRs Восстановление доступа к SMRAM (System Management RAM) |
Выполняется настройка System Management RAM (SMRAM) для процедуры обработки System Management Interrupt (SMI Handler). Регистры процессора MTRR настраиваются на обеспечение требуемых условий доступа к региону памяти в сегментах A000 и B000, картируемых на SMRAM. На некоторых платформах для обозначения данной процедуры используется код E1 . |
13 | Restore the Refresh rate Восстановление регенерации памяти |
Платформы, построенные на процессорах Intel, восстанавливают содержимое регистров контроллера памяти, отвечающих за регенерацию памяти. На платформах AMD данная процедура не выполняется. На некоторых платформах для обозначения данной процедуры используется код E2 . |
14 | Restore CMOS and call VGA BIOS Поиск и инициализация VGA BIOS |
Для платформ с интегрированным видео выполняется поиск и инициализация VGA BIOS. На некоторых платформах для обозначения данной процедуры используется код E3 . |
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 |
Звуковые сигналы
В обязанности данной функции входит поддержка удаленной загрузки по сети, поэтому требуется выполнить посик Boot ROM сетевого адаптера. Если он найден, а установками CMOS Setup в меню Boot Device Priority загрузка по сети указана как первое устройство, выполняется настройка процедур INT18h и INT19h.
Код ошибки может принимать следующие значения: * 0: оперативная память не обнаружена * 1: установлены модули DIMM различных типов * 2: модуль DIMM не оснащен SPD либо чтение содержимого SPD закончилась неудачей * 3: модуль не соответствует системным требованиям для работы на заданной частоте * 4: модуль не может быть использован в данной системе * 5: время между активацией строк модуля и переходом его в состояние регенерации не соответствует системным требованиям * 6: обнаружена ошибка в младшей странице — первые 64 Kb памяти
звуки | ошибка |
---|---|
1 короткий | Ошибка регенерации памяти. Возможно, неисправен программируемый таймер прерываний или программируемый контроллер прерываний. |
2 коротких | Ошибка процедуры POST. Не прошла одна из проверок оборудования. |
3 коротких | Ошибка чётности памяти в первых 64K. Возможно, неисправна микросхема памяти. |
4 коротких | Ошибка системного таймера или первого банка памяти |
5 коротких | Ошибка процессора |
6 коротких | Ошибка линии управления A20. Неисправность контроллера клавиатуры, которая не позволяет переключить процессор в защищенный режим. |
7 коротких | Ошибка виртуального режима процессора |
8 коротких | Ошибка чтения/записи видеопамяти. Отсутствует или неисправен видеоадаптер. |
9 коротких | Контрольная сумма BIOS неверна |
10 коротких | Ошибка чтения/записи регистра управления питанием в энергонезависимой памяти (CMOS). Неисправность цепей управления питанием. |
11 коротких | Ошибка кэша 2-го уровня |
1 длинный | Все проверки прошли нормально — компьютер готов к загрузке операционной системы |
1 длинный, 1 короткий | Ошибка блока питания |
1 длинный, 2 коротких | Ошибка в ПЗУ BIOS-а видеокарты или ошибка гашения обратного хода строчной развертки |
1 длинный, 3 коротких | Обнаружена ошибка в памяти выше 64К |
PI0049
POST-карта для дефектации компьютерных материнских плат, модель PI0049, предназначена для ото-бра-же-ния POST-кодов всех производителей BIOS. Данное изделие более известно под названием PC Ana-lyz-er 2 , особенности функционирования которого неоднократно рассматривались на страницах нашего сайта. Руководство пользователя содержит перечень инженерных паролей, а также список стандартных сочетаний клавиш для входа в BIOS . Разработка POST-карты защищена патентом 01224987.4 (Китай).
PI0050
POST-карта IC80 V5.0
QiGuan KLPI6
Диагностическая карта KLPI6-SD производства QiGuan Electronics выполнена в соответствии с нормами международного стандарта IEC 61010-1, устанавливающему требования к низковольтному испы-та-тель-но-му оборудованию по перенапряжению. Функциональная особенность POST-карты KLPI6-SD — воз-мож-ность индикации POST-кодов персонального компьютера на внешней дисплейной панели. Кроме те-ку-ще-го кода на обеих индикаторах отображаются предыдущие значения, а также POST-код фатального сбоя.
QiGuan MKCP6A
Плата для диагностики персональной платформы и тестирования ее на стабильность (Diagnostics and Stability Test Card), модель MKCP6A , разработана компанией QiGuan Electronics с использованием технологии, защищенной национальным патентом 03126857.9 (Китай). Для отображения ПОСТ-кодов на плате имеется три пары(!) индикаторов: первая пара предназначена для вывода сбойного кода, следующая выводит текущий POST-код, последняя — предыдущий код.
SL-M04A
Раритетная версия руководства пользователя на турецком языке к диагностическому POST-контроллеру PC Analyzer (по-турецки PC Analizoru). Кроме широко известных описаний POST-кодов включает в себя перечень контрольных точек почти всех известных производителей BIOS. Для удобства все пост-коды отсортированы по номеру, что облегчает доступ и понимание. Комментарии к ним следуют не-по-сред-ствен-но за кодом и разделены названием BIOS.
18.03.2019
Hardware:
Board: ESP32 Dev Module node32
IDE name: Platform.io on Visual Studio Code
Computer OS: Ubuntu?
Description:
Decoding Guru Meditation does not provide a place of the issue.
Exception Cause: Not found
0x400d1d90: loop() at /home/peter/Documents/PlatformIO/Projects/monitorv1/src/main.cpp:150 (discriminator 10)
0x40084774: _xt_coproc_exc at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/freertos/xtensa_vectors.S:1091
0x40086a21: spi_flash_restore_cache at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/spi_flash/cache_utils.c:283
0x400d1d90: loop() at /home/peter/Documents/PlatformIO/Projects/monitorv1/src/main.cpp:150 (discriminator 10)
0x400d1d90: loop() at /home/peter/Documents/PlatformIO/Projects/monitorv1/src/main.cpp:150 (discriminator 10)
0x40084771: _xt_coproc_exc at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/freertos/xtensa_vectors.S:1090
0x40086a1e: spi_flash_phys2cache at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/spi_flash/flash_mmap.c:466
0x40082b8b: esp_reset_reason_get_hint at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/esp32/reset_reason.c:117
0x40088b7d: vQueueDelete at /home/runner/work/esp32-arduino-lib-builder/esp32-arduino-lib-builder/esp-idf/components/freertos/queue.c:1796 (discriminator 1)
The system reads sensor data over simple 433Mhz ASK routine ( RFReceiver or RadioHead ) and updates a web page on ESPAsyncWebServer. There is also a routine to read the time from NTP server.
If I don’t initialize 433Mhz radio objects, failure of the WiFi does not influence the system. If WiFi will be available again the system recovers the WiFI connection and works as design.
With an active radio object and failure of the WiFi after few seconds system reboots with guru meditation:
Guru Meditation Error: Core 1 panic’ed (Cache disabled but cached memory region accessed)
Core 1 register dump:
PC : 0x400d1d90 PS : 0x00060034 A0 : 0x40084774 A1 : 0x3ffbe7b0
A2 : 0x00000004 A3 : 0x3ffc192c A4 : 0x00000000 A5 : 0x00000010
A6 : 0x00000000 A7 : 0x1300005c A8 : 0x80080f80 A9 : 0x00000001
A10 : 0x00000000 A11 : 0x00000000 A12 : 0x3ffc1c7c A13 : 0x00000000
A14 : 0x3ffc1c78 A15 : 0xffffffff SAR : 0x00000018 EXCCAUSE: 0x00000007
EXCVADDR: 0x00000000 LBEG : 0x00000000 LEND : 0x00000000 LCOUNT : 0x00000000
Core 1 was running in ISR context:
EPC1 : 0x40086a21 EPC2 : 0x00000000 EPC3 : 0x00000000 EPC4 : 0x400d1d90Backtrace: 0x400d1d90:0x3ffbe7b0 0x40084771:0x3ffbe7d0 0x40086a1e:0x3ffba1f0 0x40082b8b:0x3ffba210 0x40088b7d:0x3ffba230
The reboots happen also even if the transmitter is switched off and actually there is no reason to call any radio method.
I read here1 and here2 that a part of the code within interrupt routine must always be in the ESP32’s IRAM — is that correct?
I tried to add IRAM_ATTR to few function handling radio parts without any success.
Question1:
Can i somehow disable (taking into consideration a slowdown of the performance) the caching? Is there something similar in Arduino / Platformio config to disable SPI_MASTER_ISR_IN_IRAM in ESP32 config settings?
Question2:
Or how can I identify a function, which requires to stay in IRAM (if it is the solution of my problem)?
Sketch:
#include <Arduino.h> #include "main.h" #include "index.h" #include "credentials.h" #include <NTPClient.h> #include <WiFiUdp.h> #include <TimeLib.h> #include <Timezone.h> #include "WiFi.h" #include <ESPmDNS.h> #include "ESPAsyncWebServer.h" #include <PinChangeInterruptHandler.h> #include <RFReceiver.h> void updateJson(); void blink(); void printData(Tdata&); void printDateTime(Timezone, time_t, const char *); // Central European Time (Frankfurt, Paris) WiFiUDP ntpUDP; NTPClient timeClient(ntpUDP, "europe.pool.ntp.org", 0); /// get UTC TimeChangeRule CEST = {"CEST", Last, Sun, Mar, 2, 120}; // Central European Summer Time TimeChangeRule CET = {"CET ", Last, Sun, Oct, 3, 60}; // Central European Standard Time Timezone CE(CEST, CET); TimeChangeRule *tcr; time_t syncNTP(); getExternalTime NtpTime = &syncNTP; AsyncWebServer server(80); AsyncEventSource events("/events"); Tdata sensorsData[sensorNumber]; char jsonData[370]; RFReceiver receiver(4); void setup() { for (int i=0; i<sensorNumber; i++) { sensorsData[0].timeStamp = 0; sensorsData[0].temperature = 0.0; sensorsData[0].humidity = 0.0; sensorsData[0].pressure = 0.0; sensorsData[0].battery = 0.0; } pinMode(LED_BUILTIN, OUTPUT); Serial.begin(115200); delay(1000); WiFi.begin(ssid, password); Serial.setDebugOutput(true); PRINTS("Connecting to WiFi "); while (WiFi.status() != WL_CONNECTED) { PRINTS("."); blink(); } PRINTS(" connectedn"); PRINTS(WiFi.localIP()); if (!MDNS.begin(localDomain)) { PRINTS("Error setting up MDNS responder! Program Stopedn"); while(1) { blink(); } } PRINTS("mDNS responder startedn"); timeClient.begin(); if (!timeClient.update()) { PRINTS("1st NTP Update Failed. Program Stopedn"); while(1) { blink(); } }; setSyncInterval(_setSyncInterval); setSyncProvider(NtpTime); server.on("/", HTTP_GET, [](AsyncWebServerRequest *request){ request->send(200, "text/html", index_html); }); server.on("/favicon.ico", HTTP_GET, [](AsyncWebServerRequest *request) { request->send(404); }); events.onConnect([](AsyncEventSourceClient *client){ syncNTP(); updateJson(); client->send(jsonData,"data",millis()); }); server.addHandler(&events); server.begin(); MDNS.addService("http", "tcp", 80); receiver.begin(); PRINT("Max Buf: ", MAX_PACKAGE_SIZE); } time_t last_utc=0; void loop() { uint8_t buf[MAX_PACKAGE_SIZE]; uint8_t buflen = sizeof(buf); uint8_t sensorID; byte senderId = 0; byte packageId = 0; //PP2 if (receiver.ready()) { // (driver.recv(buf, &buflen)) // Non-blocking buflen = receiver.recvPackage(buf, &senderId, &packageId); // Message with a good checksum received, dump it. #if DEBUG_ON //driver.printBuffer("Got:", buf, buflen); PRINT("Buf Len:", buflen); PRINTLN; PRINT("Size of TData:", sizeof(Tdata)); PRINTLN; #endif if (buflen==dataSize) { //data = *(Tdata *) buf; sensorID=(*reinterpret_cast<Tdata *> (buf)).sensorID; memcpy(&sensorsData[sensorID],&buf, sizeof(Tdata)); PRINT("Sensor ID: ", sensorID); PRINTLN; sensorsData[sensorID].timeStamp = now(); updateJson(); events.send(jsonData,"data",millis()); printData(sensorsData[sensorID]); } } if (now()-last_utc >= 1) { last_utc = now(); updateJson(); events.send(jsonData,"data",millis()); //printDateTime(CE, last_utc,(timeStatus()==timeSet)? " OK":(timeStatus()==timeNeedsSync)? " Need Sync":" Not Set"); } } void updateJson() { time_t t = CE.toLocal(now(), &tcr); time_t t0 = CE.toLocal(sensorsData[0].timeStamp, &tcr); time_t t1 = CE.toLocal(sensorsData[1].timeStamp, &tcr); time_t t2 = CE.toLocal(sensorsData[2].timeStamp, &tcr); sprintf(jsonData,jsonStruc, (timeStatus()==timeSet)? "white":(timeStatus()==timeNeedsSync)? "red":"yellow", hour(t), minute(t), second(t), day(t), month(t), year(t), hour(t0), minute(t0), second(t0), day(t0), month(t0), year(t0)%100U, sensorsData[0].temperature, sensorsData[0].humidity, sensorsData[0].pressure, sensorsData[0].battery, hour(t1), minute(t1), second(t1), day(t1), month(t1), year(t1)%100U, sensorsData[1].temperature, sensorsData[1].humidity, sensorsData[1].pressure, sensorsData[1].battery, hour(t2), minute(t2), second(t2), day(t2), month(t2), year(t2)%100U, sensorsData[2].temperature, sensorsData[2].humidity, (float)sensorsData[0].counter); } time_t syncNTP() { bool NTPSyncOK=true; PRINTS("nNTP Syncing ... "); // WiFi.printDiag(Serial); if (WiFi.isConnected()) { NTPSyncOK = timeClient.forceUpdate(); } else { PRINTS("nRecovering WiFi connectionn"); //WiFi.mode(WIFI_STA); WiFi.begin(); if (WiFi.isConnected()) { NTPSyncOK = timeClient.forceUpdate(); //WiFi.mode(WIFI_OFF); } else { PRINTS("nWIFI failed ...n"); NTPSyncOK = false; } } if (NTPSyncOK) { PRINTS("NTP Sync OKn"); return timeClient.getEpochTime(); } else { PRINTS("NTP Sync Failedn"); return 0; } } void blink() { digitalWrite(LED_BUILTIN, HIGH); delay(500); digitalWrite(LED_BUILTIN, LOW); delay(500); } // -------------------------------- void printData(Tdata& data) { PRINT ("Sensor = ", data.sensorID); PRINTLN; PRINT ("Temperature = ", data.temperature); PRINTS(" *Cn"); PRINT ("Pressure = ", data.pressure); PRINTS(" hPan"); PRINT ("Humidity = ", data.humidity); PRINTS(" %n"); PRINT ("Battery = ", data.battery); PRINTS(" Vn"); PRINTS("Time = "); printDateTime(CE, data.timeStamp,(timeStatus()==timeSet)? " OK":(timeStatus()==timeNeedsSync)? " Need Sync":" Not Set"); PRINT ("Counter = ", data.counter); PRINTLN; } void printDateTime(Timezone tz, time_t utc, const char *descr) { char buf[40]; char m[4]; // temporary storage for month string (DateStrings.cpp uses shared buffer) TimeChangeRule *tcr; // pointer to the time change rule, use to get the TZ abbrev time_t t = tz.toLocal(utc, &tcr); strcpy(m, monthShortStr(month(t))); sprintf(buf, "%.2d:%.2d:%.2d %s %.2d %s %d %s", hour(t), minute(t), second(t), dayShortStr(weekday(t)), day(t), m, year(t), tcr -> abbrev); PRINTS(buf); PRINTS(descr); PRINTLN; }
Sketch main.h:
#include <Arduino.h> #define DEBUG_ON 1 #define localDomain "pogoda" #define _setSyncInterval 15 typedef struct { float temperature; float humidity; float pressure; float battery; long counter; uint8_t sensorID; long dummy; time_t timeStamp; } Tdata; const char jsonStruc[] PROGMEM = R"rawliteral( {"XC1":"%s", "clock":"%02d:%02d:%02d %02d:%02d:%02d", "time0":"%02d:%02d:%02d %02d:%02d:%02d", "temp0":"%.2f", "hum0" :"%.0f", "pres0":"%.0f", "bat0" :"%.2f", "time1":"%02d:%02d:%02d %02d:%02d:%02d", "temp1":"%.2f", "hum1" :"%.0f", "pres1":"%.0f", "bat1" :"%.2f", "time2":"%02d:%02d:%02d %02d:%02d:%02d", "temp2":"%.2f", "hum2" :"%.0f", "pres2":"%.0f"} )rawliteral"; const uint8_t sensorNumber = 3; const uint8_t dataSize = 21; // data frame size #if DEBUG_ON #define PRINT(s, v) { Serial.print(s); Serial.print(v); } #define PRINTX(s, v) { Serial.print(s); Serial.print(v, HEX); } #define PRINTS(s) Serial.print(s) #define PRINTLN Serial.println() #else #define PRINT(s, v) #define PRINTX(s, v) #define PRINTS(s) #define PRINTLN #endif
Sketch index.h:
const char index_html[] PROGMEM = R"rawliteral( <!DOCTYPE html> <html lang=pl> <head> .... </body> </html> )rawliteral";
Привет друзья! В предыдущей статье с Вами узнали о лучшей программе по диагностике и ремонту жёстких дисков под названием Victoria. Также мы теперь знаем, что такое S.M.A.R.T. и о чём говорят его атрибуты, как за секунду определить состояние здоровья Вашего винчестера или твердотельного накопителя SSD. В этой статье мы переходим к самому главному, а именно процессу восстановления информации на жёстких дисках и избавления винчестера от сбойных секторов (бэд-блоков), но перед началом статьи я хочу предупредить Вас. Столкнувшись с неудовлетворительной работой жёсткого диска (скрипы, щёлкания, зависания операционной системы, невозможность скопировать важные данные) простые пользователи без соответствующего опыта сразу обращаются к таким серьёзным программам, как Victoria, MHDD, HDDScan и к сожалению, зачастую только ухудшают ситуацию. Почему? Я Вам отвечу.
Очень много того, что написано о Виктории в интернете, — написано непрофессионалами, а любителями. Профессионалы редко пишут статьи, они в этом отношении немного ленивые. Если Вы хотите узнать о программе Victoria всё, нужно много работать с этой программой самому и посещать специализированные форумы в интернете касающиеся расшифровки показателей S.M.A.R.T., восстановлению данных (создание посекторного образа больного винта с бэдами), и уже в последнюю очередь там обсуждают механизм работы программы Виктория. Именно такая последовательность в большинстве случаев правильная — сначала спасение данных (снятие посекторного образа с неисправного винчестера), затем лечение жёсткого диска.
- Запомните, самое главное правило при восстановлении информации с неисправного жёсткого диска, да и любого накопителя информации звучит так: винчестер в любой момент может «приказать долго жить», поэтому число обращений к нему должно быть сведено к минимуму. А значит, перед работой с Victoria нужно обязательно делать образ «больного» жёсткого диска и восстанавливать информацию уже с образа, как только информация будет восстановлена, тогда можно проводить какие-то операции с жёстким диском, к примеру лечить его алгоритмами Advanced REMAP или Erase.
Поэтому в нашей сегодняшней статье много информации не только о программе Victoria, но и о программе DMDE, при помощи которой мы и будем создавать посекторный образ неисправного жёсткого диска, это тоже нужно сделать правильно, дабы пользовательские данные не пропали. Не спорю, многим читателям, читающим сейчас эти строки, информация на жёстком диске может быть и не нужна, они просто хотят подлечить свой винчестер от сбойных секторов (бэд-блоков) и запустить его обратно в эксплуатацию, дабы сэкономить деньги и не покупать новый жёсткий диск. В этом случае, они просто могут пропустить некоторые части статьи.
Друзья, если Вы читаете эти строки, значит у Вас какая-то проблема с жёстким диском. Когда мы задумываемся о том, что с нашим жёстким диском происходит что-то не то?
-
С жёсткого диска невозможно скопировать нужную информацию на другой накопитель, при копировании операционная система зависает и спасает только перезагрузка.
-
Windows может неожиданно зависнуть на любом этапе работы.
-
Невозможно переустановить операционную систему, в процессе установки происходит зависание на распаковке файлов Windows или установщик сообщает об ошибке «Невозможно продолжить установку…», или Windows очень долго устанавливается, например несколько часов.
-
При включении компьютера сразу запускается утилита Chkdsk и проверяет разделы жёсткого диска на ошибки.
-
Жёсткий диск издаёт посторонние звуки (щелчки, скрип) и периодически не определяется в BIOS.
Итак, поехали, во-первых, в программе Виктория точно установим номера сбойных секторов (бэд-блоков), затем сделаем посекторную копию жёсткого диска и этим спасём пользовательские данные, а дальше произведём скрытие сбойных секторов бэд-блоков (рэмап) в программе Victoria. Также узнаем, как делать «Запись по всей поляне» (тест Erase), то есть при обнаружении сбойного сектора переписывать весь блок (256 секторов) жёсткого диска нулями.
Примечание: если вы не читали первую статью из нашей серии о программе Виктория, то вам будет не всё понятно, поэтому я рекомендую сначала прочитать начальную статью, затем переходить к этой. В данный момент вы читаете вторую статью, но есть ещё статьи:
Для примера возьмём реальный жёсткий диск, имеющий сбойные сектора. Друзья, минимальная единица информации на жёстком диске, это сектор, объём пользовательских данных составляет 512 байт, если информацию в секторе невозможно прочесть, значит сектор является нечитаемым или другими словами сбойным. Все зависания операционной системы происходят при чтении инфы с такого сектора. Данный винчестер WDC WD5000AAKS-00A7B2 (объём 500 ГБ) реально неисправен.
Операционная система на нём постоянно зависает и периодически при загрузке запускается проверка жёсткого диска на ошибки. Последней каплей для хозяина винчестера стало то, что не получалось скопировать важные данные на другой диск и даже переустановка операционной системы закончилась очередным зависанием на распаковке файлов Windows, замена установочного диска с операционкой ничего не дала, зависание повторилось на другом этапе установки. Вот тогда и встал вопрос о том, что делать с этим жёстким диском, ведь на одном из разделов находились важные данные и их нужно было скопировать.
Запускаем программу Victoria от имени администратора. Соглашаемся со всеми предупреждениями о работе в 64-битной системе.
Выбираем начальную вкладку Standard. Если у нас несколько жёстких дисков, в правой части окна выделяем левой мышью нужный жёсткий диск, в нашем случае WDC WD5000AAKS-00A7B2
и переходим на вкладку SMART,
жмем кнопку Get SMART, справа от кнопки засветится сообщение GOOD и откроется S.M.A.R.T. выбранного нами жёсткого диска.
S.M.A.R.T. этого винта оказался не самый хороший. Почему? Читайте нашу первую статью из цикла о программе Виктория. Здесь скажу лишь, что целых четыре атрибута S.M.A.R.T. горят красным, в том числе и самый важный параметр, атрибут
5 Reallocated Sector Count— (remap), обозначающий число переназначенных секторов это значит запасные сектора на резервных дорожках заканчиваются и скоро сбойные сектора переназначать будет нечем.
Переходите на вкладку Tests.
В правой части окна программы отметьте пункт Ignor и пункт read, затем нажмите Start. Запустится простой тест поверхности жёсткого диска без исправления ошибок. Этот тест не принесёт никаких плохих или хороших воздействий на Ваш винчестер, но когда тест закончится, мы узнаем в каком состоянии находится наш жёсткий диск.
Начинается сканирование поверхности жёсткого диска и через некоторое время обнаруживаются сбойные сектора. Через 40 минут Victoria выдаёт нам такой результат:
-
Очень много хороших секторов с хорошей задержкой чтения не более 5 ms — 3815267
-
Также имеются сектора с нехорошей задержкой чтения 200 ms
-
Секторов с неудовлетворительной задержкой чтения более 600 ms (кандидаты в бэд-блоки) нет совсем, но…
-
Что совсем плохо, присутствуют полноценные сбойные сектора (бэд-блоки), информацию из которых прочитать совсем не удалось — 13!
13 сбойных секторов (бэд-блоков), все они начинаются в области 6630400, а заканчиваются на 980000000, то есть рассыпаны по всему жёсткому диску. Номера бэд-блоков нужно записать. Друзья, вполне возможно все наши проблемы с жёстким диском могут быть из-за этих 13 бэдов и от них нужно избавиться, но сначала сделаем посекторный образ больного винта.
Жёсткий диск пострадавшего WDC WD5000AAKS-00A7B2 (объём 500 ГБ) был разделён на два раздела: диск D: с операционной системой объём 120 ГБ и диск E: с данными объём 345 ГБ.
Перед работой с программой Victoria обезопасим себя и сделаем полный образ раздела диск E: объём 345 ГБ и данные будем вытаскивать именно с образа. Образ сделаем в другой программе DMDE и расположим его на другом физическом диске SAMSUNG HD403LJ (объём 400 ГБ) я покажу Вам как это сделать.
Управление дисками моего компьютера
Важные данные находятся на Новом томе (E:) объём 347 ГБ жёсткого диска WDC WD5000AAKS (общий объём 500 ГБ), значит создавать будем образ раздела (E:). Посекторный образ раздела (E:) создадим на жёстком диске SAMSUNG HD403LJ (объём 400 ГБ), на нём всего один раздел без данных Новый том (F:). Третий физический диск в системе, это твердотельный накопитель SSD (объём 120 ГБ) диск (C:), на нём находится наша работающая операционная система Windows 8.1, в которой мы сейчас и находимся.
И скачиваем программу, жмём GUI для Windows.
DMDE скачивается в архиве, разархивируем его и запускаем файл dmde.exe.
Затем выбираем язык Русский.
Принимаем условия Лицензионного соглашения. В начальном окне программы нам нужно для создания образа выбрать или Физическое устройство (то есть полностью жёсткий диск) или раздел с данными.
Нужен нам только том (E:), поэтому отмечаем левой мышью наш жёсткий диск WDC WD5000AAKS, затем отмечаем пункт Логические диски
и раздел (E:), затем жмём ОК.
Меню. Создать образ/клон…
Место для записи, жмём Диск.
Новый том (F:) и ОК. Нужно чтобы раздел, на котором будет создан посекторный образ неисправного жёсткого диска (или раздела с нечитаемыми данными) был по объёму не меньше этого диска.
ОК.
На новом томе (F:) удалятся все данные, соглашаемся Да.
Начинается создание посекторной копии раздела (E:) больного жёсткого диска WDC WD5000AAKS на новом томе (F:) другого здорового жёсткого диска диска SAMSUNG HD403LJ, которое продолжается 6 часов (с особо «бэдастых» винтов образ снимается несколько суток) и наглухо зависает на 83 процентах, прождав пару часов я нажал на кнопку Прервать! Друзья, если прервать создание образа посекторного раздела под самый конец (всё-таки 83%) то нас ждёт два варианта, как говаривал Суворов — «либо грудь в крестах, либо голова в кустах».
После прерывания операции заходим на Новый том (F:) и смотрим, есть ли на нём какие-либо данные и…они есть, всё основное, что нам было нужно программе DMDE удалось перенести на диск (F:), практически все данные читаются без ошибок. Значит случай у нас не сложный и бэды в основном софтовые.
Но в некоторых случаях не всё так будет радужно и при попытке войти на раздел с посекторной копией нас будет ждать вот эта ошибка: Нет доступа к F:. Файл или папка повреждены. Чтение невозможно.
Нет доступа к F:. Файловая система не распознана. Убедитесь, что все требуемые системные драйвера загружены и том не повреждён.
Но и в этом случае сдаваться мы не будем и поступим так.
Друзья, не всегда процесс создания посекторной копии заканчивается успешно даже по истечении нескольких часов, но если прекратить создание посекторной копии данные в ней могут оказаться нечитаемые.
Или в процессе создания посекторной копии появится вот такая ошибка «Запрос не был выполнен из-за ошибки ввода/вывода на устройстве» (смотрите скришнот ниже) обозначающая, что DMDE не смогла прочитать информацию в сбойном секторе (номер сектор указан в ошибке) в этом случае нажмите
«Повторить», произойдёт повторная попытка считывания информации с данного сектора и она может закончится успехом. Если данная ошибка с этим же сектором появится опять, тогда нажмите
«Игнорировать» и создание посекторного образа продолжится, но информацию в этом секторе мы потеряем и в результате в посекторной копии не откроется один какой-либо файл. Если ошибка «Запрос не был выполнен из-за ошибки ввода/вывода на устройстве» будет появляться слишком часто, можно выбрать
«Игнорировать всё» и подобные ошибки будут пропущены, а можно нажать кнопку
«Параметры» и соответствующе настроить программу DMDE для такого тяжёлого случая. Нажмите в этом окне кнопку Параметры.
В параметрах нужно быть внимательным, так как настроить здесь можно много чего. Например заставить DMDE создавать посекторный образ с жёсткого диска не с начала, а с конца, для этого нужно отметить пункт
«Обратный ход», иногда это приносит результат.
И опять нажмите «Параметры».
В этом окне отметьте пункт «Не ждать, если устройство не готово — Всегда». При выборе опции операция будет продолжена даже
в случае ошибки, связанной с отсутствием готовности устройства. Если не отметить эту опцию, то на некоторых «бэдастых» винчестерах будет выводиться предупреждение с ожидаемой реакцией пользователя, то есть на автомате создание образа происходить не будет.
Число повторов авто при ошибке CRC — 0
Число авто повторов, если сектор не найден — 0
Заполнять плохие секторы (hex)
Затем ОК и ОК, начинается создание посекторного образа.
Щёлкните левой мышью для увеличения изображения
Также работоспособным показал себя такой вариант настроек.
Пропускать ошибки ввода-вывода — Всегда
Не ждать, если устройство не готово — Всегда
Число повторов при ошибке CRC — 0
Число авто повторов, если сектор не найден — 0
Вообще я Вам посоветую изучить мануал к программе DMDE http://dmde.ru/manual.html или http://dmde.ru/docs/DMDE-manual-ru.pdf, так же можете дождаться нашей статьи о создании посекторного образа неисправного жёсткого диска различными программами, в ней мы рассмотрим даже создание загрузочной флешки с программой DMDE.
- Если DMDE Вам не поможет, тогда можно попробовать другие программы, например Acronis True Image. Конечно, существуют ещё способы, с помощью которых можно сделать посекторный образ сбойного винта, например загрузиться с какой-нибудь операционной системы, основанной на Linux, к примеру Ubuntu, но сам процесс описывать здесь не буду и лучше напишу отдельную статью. Также под Линуксом можно запустить утилиту safecopy..
- Что делать, если всё же посекторную копию жёсткого диска Вам сделать не удастся, выбирать Вам. Можете обратиться в хороший и зарекомендовавший себя сервис по восстановлению данных и посекторную копию с Вашего жёсткого диска снимут на специальном дорогостоящем оборудовании специалисты, например с помощью того же комплекса PC−3000. Если Вам не жалко Ваши данные, то можете рискнуть и запустить в программе Victoria алгоритмы, избавляющие поверхность Вашего жёсткого диска от сбойных секторов (бэд-блоков), как это сделать написано далее, жёсткий диск после этой операции может вернуться к жизни.
- Важно: Казанский (разработчик программы Виктория) обещает, что самый новаторский алгоритм скрытия бэд-блоков BB = Advanced REMAP НЕ деструктивен для данных, но в некоторых случаях для Ваших файлов это может быть деструктивно, так как даже самый продвинутый алгоритм Виктории Advanced REMAP скрытие дефектов (ремап), это по любому изменение трансляции винта, а значит потеря пользовательских данных (подробности далее. Хочу сказать, что иногда бывало и так, что вылечит Victoria жёсткий диск от бэдов и Вам даже удастся скопировать инфу с такого харда, но к сожалению не вся информация получается читаемая.
Итак, в нашем случае сделать посекторную копию больного жёсткого диска, а именно нового тома (E:) программе DMDE сделать удалось, правда в некоторых местах DMDE немного зависала, но всё закончилось успешно. Посекторная копия нового тома (E:) представляет из себя точную копию и расположена на томе (F:). Все имеющиеся данные успешно читаются и копируются.
Основная задача решена и пользовательские данные спасены, теперь приступаем к процедуре лечения жёсткого диска.
Друзья, давайте теперь представим, что у нас не получилось сделать посекторный образ жёсткого диска с бэд-блоками и мы ничего другого не придумали и решили избавить наш хард от бэдов в программе Victoria, в надежде на то, что после скрытия сбойных секторов нам удастся прочитать и скопировать информацию на жёстком диске.
Примечание: избавить винт от бэдов в работающей Windows трудно, тем более, если к примеру у Вас ноутбук с одним жёстким диском и на этом же жёстком диске установлена операционная система и Вы эту же операционную хотите излечить от бэд-блоков. В таких случаях создают загрузочную флешку с Викторией, загружают с неё ноутбук и избавляются от сбойных секторов. Предлагаю создать загрузочную флешку в следующей статье, а сейчас мы узнаем как это делается прямо в работающей операционной системе, я Вам всё продемонстрирую.
Remap
В главном окне Виктории отмечаем пункт Remap, обозначающий алгоритм переназначения бэд-блоков секторами с резервных дорожек в процессе сканирования. Тест в режиме чтения Read, то есть от начала к концу и жмём на кнопку Start.
Пока идёт сканирование поговорим вот о чём.
1. Что происходит при данном алгоритме Remap? Производится (несколько раз) попытка принудительной записи информации в сбойный сектор жёсткого диска, если попытка удачна, значит сектор становится здоровым и удаляется из списка бэд-блоков (ремап не происходит). Если попытка записи неудачна, значит больной сектор переназначается здоровым сектором со специально предназначенной для таких случаев резервной дорожки винчестера.
2. Remap это переназначение (замена) больного сектора, присвоение его номера LBA другому физически здоровому сектору из резервной дорожки. Информация из сектора (на момент переназначения) висит в ОЗУ винта, и как только сектор переназначен — записывается назад.
Remap в основном не деструктивен для информации, если Ваши данные и потеряются, то только в одном сбойном секторе, но согласитесь, данные в бэд-блоке и так были нечитаемы. Во втором случае данные будут просто перенесены на сектор с резервной дорожки.
Результат. Как я и говорил в работающей Windows трудно что-либо исправить и Victoria не может осуществить Ремап. Через 20 минут тот же самый результат, 13 бэд-блоков и нам с Вами придётся делать загрузочную флешку с Викторией и работать в ДОСе.
Как в программе Victoria сканировать определённую область на жёстком диске
Если Вам известны точные адреса сбойных секторов, вы можете задать в программе Victoria точные параметры сканирования. Например, мы знаем, что наши бэд-блоки начинаются с сектора 770 000 000, тогда в пункте Start LBA: здесь задать это число и программа Victoria именно с сектора 770 000 000 начнёт сканирование и исправление поверхности жёсткого диска, также, если задать нужное Вам число в пункте End LBA: то Victoria закончит сканирование на нужном Вам секторе.
Алгоритм Erase
Друзья, вы можете спросить меня, а что будет если применить тест Erase или ещё есть Write?
Erase при обнаружении нечитаемого сектора принудительно переписывает весь блок из 256 секторов нулями (осторожно, в некоторых случаях ваши данные на жёстком диске удалятся).
- Чаще всего попадаются софтовые (программные) бэды, которые убираются быстрее всего обнулением — алгоритмом Erase, да и при неудачной записи в сектор нулей вполне может произойти Remap, так как микропрограмма винчестера может посчитать такой сектор сбойным. Если Erase не поможет, тогда можно выбрать Remap, но как мы знаем, шансы, что Remap будет произведён в работающей Windows невелики.
- Софтовые (программные) бэды в некоторых случаях можно убрать даже простым форматированием средствами самой Windows. Всю разницу между существующими бэд-блоками: физическими и программными, читайте в нашей статье всё о бэд-блоках. В двух словах объясню, что физические бэды (физически разрушившийся сектор) восстановить невозможно (возможен только ремап, переназначение), а логические (программные, ошибки логики сектора) восстановить можно.
- Друзья, мы можем избавиться от бэд-блоков посекторно, но тогда наша статья будет ещё длиннее, это мы тоже сделаем в следующей статье.
Мне не хочется ставить эксперимент над нашим жёстким диском WDC WD5000AAKS, так как я планирую в следующей статье вылечить его от бэд-блоков в ДОС режиме с помощью загрузочной флешки с программой Виктория и всё таки вернуть хозяину вылеченный от бэдов жёсткий диск с неповреждёнными данными.
Я просто покажу Вам на другом винчестере как запустить этот тест в работающей Windows.
В главном окне Виктории выбираем наш жёсткий диск и идём на вкладку Tests отмечаем пункт Erase (осторожно, в некоторых случаях ваши данные на жёстком диске удалятся) — при обнаружении нечитаемого сектора принудительно переписывает весь блок из 256 секторов нулями, естественно информация при этом в целом блоке секторов полностью теряется, но если перезапись происходит, блок возвращается в работу (становится здоровым).
Тест в режиме чтения Read, то есть от начала к концу и жмём Start.
Часто при «обнулении» в работающей Windows будут выходить вот такие ошибки:
Block (номер сбойного сектора) try Erase 256 sectors. Переписать блок секторов не удалось.