Прерывания в защищенном режиме
В защищенном режиме работы (а также в виртуальном V- режиме), хотя и сохраняется общая тенденция в организации реакции процессора на запросы прерывания, но имеются и существенные изменения. В основном они заключаются в следующем:
· Вместо таблицы векторов прерываний используется дескрипторная таблица прерываний, элементами которой являются теперь дескрипторы шлюзов задач, шлюзов прерываний и шлюзов ловушек. В связи с тем, что дескрипторы шлюзов занимают 8 байт, дескрипторная таблица прерываний в адресном пространстве, при том же размере кода типа прерывания в один байт, занимает теперь два килобайта оперативной памяти, а не один.
· Расположение дескрипторной таблицы прерываний в адресном пространстве может быть установлено по любому физическому адресу, который заносится в регистр дескрипторной таблицы прерываний IDTR. Туда же заносится и размер самой дескрипторной таблицы.
· Возможна передача подпрограмме обработки дополнительной информации о причине возникновения особого случая.
В защищенном режиме, как и в реальном, каждому аппаратному прерыванию или особому случаю соответствует свой код типа прерывания, по которому процессор обращается уже не к таблице векторов прерывания, а к дескрипторной таблице прерывания, получая из ОЗУ соответствующий 8-ми байтовый дескриптор шлюза. Извлекая затем из дескриптора шлюза селектор целевого сегмента и смещения в нем, процессор, пользуясь глобальной или локальной таблицей дескрипторов, формирует физический адрес подпрограммы обработки запрашиваемого прерывания.
Таким образом, последовательность действий для передачи управления подпрограмме обработки разрешенного прерывания, после получения запроса прерывания, в случае защищенного режима работы будет следующая.
· Из регистра IDTR процессор извлекает 32 разрядный базовый адрес сегмента дескрипторной таблицы прерываний IDT .
· Код типа прерывания, полученный от контроллера прерываний (при аппаратных внешних запросов прерывания), или фиксированный код типа, соответствующий данному особому случаю или команде (при внутренних прерываниях), умножается на 8 (сдвигается на 3 разряда влево), поскольку каждый дескриптор имеет размер в 8 байт.
· Сформированный таким путем 11 разрядный двоичный код, суммируется с базовым адресом сегмента IDT. Полученный 32 разрядный код является адресом дескриптора шлюза, в котором хранится селектор сегмента, где находится подпрограмма обработки прерывания, а также смещение в этом сегменте, т.е. логический адрес подпрограммы обработки прерывания.
· Для получения физического адреса этой подпрограммы, процессор обращается к ОЗУ и выбирает по полученному адресу дескриптор шлюза.
· Из полученного дескриптора шлюза выбирается селектор и по его индексу, через дескрипторную таблицу, выбирается дескриптор искомого сегмента.
· Из выбранного дескриптора искомого сегмента процессор извлекает его базовый адрес, суммирует со смещением в этом сегменте, который берется из дескриптора шлюза и получает физический адрес требуемой подпрограммы обработки прерывания.
Следует отметить, однако, что вторичное обращение к ОЗУ за дескриптором искомого сегмента приходится делать только в тех редких случаях, когда подпрограмма обработки прерывания находится в другом сегменте, отличном от сегмента, где располагается текущая программа. Если же подпрограмма находится в том же сегменте, что и основная текущая программа, то его дескриптор уже находится в соответствующем теневом регистре (кэш-регистре) процессора. Поэтому в большинстве случаев базовый адрес искомого (целевого) регистра берется из теневого регистра, расположенного в самом процессоре, и дополнительного обращения к ОЗУ, при формировании физического адреса подпрограммы обработки прерывания, не требуется.
Кроме того, заметим следующее. Последний пункт из последовательности действий, изложенных выше, как правило, реализуется только при обработке прерываний и ловушек. Если же происходит запрос прерывания при переключении задач и из дескрипторной таблицы прерываний выбирается дескриптор шлюза задач, по которому находится сегмент состояния задачи TSS, то для этого достаточно знать только его селектор. Поэтому в дескрипторе шлюза задачи приведен только селектор соответствующего TSS, а байты, используемые для размещения смещения, в нем не используется.
Принцип функционирования системы прерываний МП семейства Х86 в защищенном режиме работы, при использовании шлюзов прерываний и ловушек, иллюстрирован на рис V.3.
Рис.V.2 Принцип организации системы прерывания МП семейства Х86
в реальном режиме работы.
Рис. V.3 Принцип функционирования системы прерываний МП
семейства Х86 в защищенном режиме работы при использовании
шлюзов прерываний и ловушек.