Дескриптор сегмента

Дескриптор сегмента (в архитектуре x86) — служебная структура в памяти, которая определяет сегмент. Длина дескриптора равна 8 байт.

Структура сегментного дескриптора

Байт прав доступа (AR, англ. Access Rights, биты 8-15 на рисунке):

  • Бит P определяет доступность сегмента (0 — сегмента нет, 1 — есть). При обращении к сегменту со сброшенным битом P происходит исключение #NP, обработчик которого может загрузить/создать сегмент.
  • Номер привилегий DPL содержит 2-битный номер (0-3), определяющий, к какому уровню (кольцу) защиты относится этот сегмент.
  • Тип сегмента (биты 8-12 на рисунке). Старший бит (S) определяет сегмент как системный (S=0) или пользовательский (S=1). Значение прочих бит для системных и пользовательских сегментов описано в таблице:
Типы системных сегментов
Биты ARОписание
3210
00000Запрещенное значение
10001Свободный 16-битный TSS
20010LDT
30011Занятый 16-битный TSS
4010016-битный шлюз вызова
50101Шлюз задачи
6011016-битный шлюз прерывания
7011116-битный шлюз ловушки
81000Запрещенное значение
91001Свободный 32-битный TSS
A1010Зарезервировано
B1011Занятый 32-битный TSS
C110032-битный шлюз вызова
D1101Зарезервировано
E111032-битный шлюз прерывания
F111132-битный шлюз ловушки
Типы пользовательских сегментов
Биты ARОписание
321
0000Сегмент данных только для чтения
2001Сегмент данных для чтения/записи
4010Сегмент данных только для чтения, растёт вниз
6011Сегмент данных для чтения/записи, растёт вниз
8100Сегмент кода только для выполнения
A101Сегмент кода для выполнения/чтения
C110Подчинённый сегмент кода только для выполнения
E111Подчинённый сегмент кода для выполнения/чтения

Младший бит байта AR пользовательских сегментов (A, англ. Accessed, бит 8 на рисунке) можно использовать для сбора статистики о сегменте. При первом же обращении к сегменту (чтение, запись, выполнение) он устанавливается процессором в 1.

  • Флаг гранулярности G определяет лимит сегмента: при G=0 лимит равен значению соответствующего поля в дескрипторе, а при G=1 лимит равен полю дескриптора, умноженному на (212 = 4096). Таким образом при G=0 максимальный размер сегмента 1 МБайт, а при G=1 4 ГБайт.
  • Флаг разрядности DB (бит 22 на рисунке) актуален для пользовательских сегментов кода и стека. Определяет разрядность в 16 бит при нулевом и 32 бит при единичном значении.
  • Зарезервированный флаг (серое поле) должен всегда равняться нулю в 32 битных дескрипторах и режиме совместимости, одному для 64 битного режима.
  • Пользовательский флаг AVL (A, бит 20 на рисунке) отдан операционной системе. Его состояние никак не влияет на работу с сегментом.

См. также

Примечания

  1. Разорванность полей дескриптора объясняется эволюционированием процессоров.

Ссылки

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.