Существует два основных метода, используемых для адресации секторов накопителей. Первый из них называется CHS (Cylinder Head Sector). Это название образовано по трем соответствующим координатам, которые используются для адресации каждого сектора дисковода. Во втором методе, который носит название LBA (Logical Block Address), для адресации секторов накопителя используется только одно значение. В основе метода CHS лежит физическая структура накопителей (а также способ организации его внутренней работы).
Метод LBA, в свою очередь, представляет собой более простой и логический способ нумерации секторов, не зависящий от внутренней физической архитектуры накопителей. Использование нумерации LBA заметно облегчает и упрощает процесс обработки данных. Несмотря на это, при создании первых ПК вся адресация BIOS для накопителей была выполнена методом CHS. Программы BIOS (когда объем HDD был очень скромным) использовали адресацию CHS, например:
INT 13, функция 02h. Чтение сектора.
Читает один или группу секторов с физического диска в память. Для начального сектора указываются абсолютные координаты (цилиндр, сектор, головка). Секторы физического диска нумеруются на каждой дорожке от 1, цилиндры нумеруются от 0, головки нумеруются от 0. Сначала идут секторы 1...n цилиндра 0, головки (поверхности) 0, затем секторы 1...n цилиндра 0, головки (поверхности) 1, далее секторы 1...п цилиндра 1, головки 0 и т.д. Таким образом, на HDD сектор 1 цилиндра 0 головки 0 относится к главной загрузочной записи (Master boot).
При вызове:
AH=02h
AL=число читаемых секторов
СН=цилиндр
CL=начальный сектор
DH=головка
DL=дисковод
00h...7Fh - гибкий диск , 80h...FFh - жесткий диск
ЕS:ВХ=адрес буфера
При возврате:
CF=0
АН=0
АL=число переданных секторов
При ошибке:
CF=1
АН=состояние (код ошибки).
Но для работы с HDD-дисками большого объема возможности адресации CHS стали «тормозом»и не позволяли работать с полным объемом дисков. Поэтому для обеспечения поддержки новых возможностей HDD в набор функций Int 13h фирмой Phoenix Technologies были введены дополнительные функции (BIOS Extensions). Дополнительные функции имеют номера 41h - 49h и 4Eh. Порядок работы с этими функциями существенно отличается от принятого для стандартных функций прерывания Int 13h :
- вся адресная информация передается через буфер в оперативной памяти, а не через регистры;
- соглашения об использовании регистров изменены (для обеспечения передачи новых структур данных);
- для определения дополнительных возможностей аппаратуры (параметров) используются флаги.
Пакет дискового адреса.
Фундаментальной структурой данных для дополнительных функций прерывания Int I3h является так называемый «Пакет дискового адреса» (Disk Address Packet). Получив пакет дискового адреса, прерывание Int 13h преобразует содержащиеся в нем данные в физические параметры, соответствующие используемому носителю информации. Формат пакета дискового адреса описан в табл. 1.
Таблица 1. Формат пакета дискового адреса.
Правила передачи параметров дополнительным функциям.
При вызове прерывания дополнительным функциям BIOS передаются через регистры процессора следующие данные:
- в АН — номер вызываемой функции;
- в DL — номер диска;
- в DS: SI — адрес буфера, содержащего пакет дискового адреса.
Передача остальных параметров, как было уже указано выше, производится через пакет дискового адреса.
Дополнительные функции BIOS предназначены только для жестких дисков и дисководов сменных дисков большой емкости, причем функции рассчитаны на использование не более четырех устройств. Передаваемый функции номер диска, таким образом, должен находиться в диапазоне 80h-83h.
После выполнения функции в регистре АН выдается код состояния (статус возврата). Кроме принятого для классических функций BIOS стандартного набора кодов возврата, для дополнительных функций введено еще несколько кодов.
Прерывание INT 13, функция 42: расширенное чтение. Функция осуществляет передачу секторов с заданной области диска в буфер памяти. Перед вызовом прерывания требуется записать в регистры следующие значения:
- в АН — значение 42h;
- в DL — номер дисковода;
- в DS: SI — адрес пакета дискового адреса.
После завершения операции функция возвращает в регистре АН состояние дисковой системы. В случае аварийного завершения выполнения функции поле счетчика блоков в пакете дискового адреса содержит число блоков, которые были успешно прочитаны (прочитаны до того, как произошла ошибка).
Рис. 1. Пример программы «Чтение BOOT-сектора (LBA = 3F)»(в AFD).