Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Олифер. Сетевые операционные системы.docx
Скачиваний:
8
Добавлен:
01.07.2025
Размер:
16.5 Mб
Скачать

Привилегированные команды

Операционная система должна обладать исключительными полномочиями для того, чтобы играть роль арбитра в споре приложений за ресурсы компьютера, а также для того, чтобы защитить себя от некорректного поведения пользовательских процессов и обеспечить взаимную защиту ресурсов этих процессов друг от друга. Приложения ставятся в подчиненное положение по отношению к ОС за счет ограничений в выполнении некоторых команд, называемых привилегированными.

Привилегированные команды — это команды, которые могут быть выполнены только при определенном уровне привилегий текущего кода (Current Privilege Level, CPL). В процессорах Pentium поддерживается четыре уровня привилегий, от самого привилегированного нулевого до наименее привилегированного третьего1..

К привилегированным командам относятся:

  • команды для работы с управляющими регистрами CRn, а также для загрузки регистров системных адресов GDTR, LDTR, IDTR и TR;

  • команда останова процессора HALT;

  • команды запрета/разрешения маскируемых аппаратных прерываний CLI/SLI;

  • команды ввода-вывода IN, INS, OUT, OUTS.

Первые две группы команд могут выполняться только при самом высшем уровне привилегий кода, то есть при CPL = 0. Для двух последних групп условия выполнения не требуют высшего уровня привилегий кода, а связаны с соотношением уровня привилегий ввода-вывода IOPL-и уровня привилегий кода CPL — выполнение этих команд разрешено в том случае, если CPL <= IOPL. Поэтому две последние группы команд иногда называют чувствительными.

Средства поддержки сегментации памяти

Средства поддержки механизма виртуальной памяти в процессорах Pentium позволяют отображать виртуальное адресное пространство на физическую память, максимальный размер которой определяется разрядностью адресов при работе с оперативной памятью. Поскольку здесь рассматривается 32-разрядная архитектура Pentium и, следовательно, 32-разрядные адреса оперативной памяти, то максимальный размер поддерживаемой физической памяти составляет 4 Гбайт.

Процессор может поддерживать две модели распределения памяти:

  • сегментную модель,

  • сегментно-страничную модель.

Средства сегментации образуют верхний уровень средств управления виртуальной памятью процессора Pentium, а средства страничной организации — нижний уровень. Это означает, что сегментные средства работают всегда, а средства страничной организации могут как включаться, так и выключаться путем установки одноразрядного признака РЕ (Paging Enable) в регистре CR0 процессора. В зависимости от того, включены ли средства страничной организации, изменяется смысл процедуры преобразования адресов, которая выполняется средствами сегментации. Сначала рассмотрим случай работы средств сегментации при отключенном механизме управления страницами.

Виртуальное адресное пространство

При работе процессора Pentium в сегментном режиме в распоряжении программиста имеется виртуальное адресное пространство, представляемое совокупностью сегментов.

Каждый сегмент виртуальной памяти процесса имеет описание, называемое дескриптором сегмента. Размер дескриптора сегмента равен 8 байт, и он содержит все характеристики сегмента, необходимые для проверки правильности доступа к нему и нахождения его в физическом адресном пространстве (рис. 6.3).

Рис. 6.3. Формат дескриптора сегмента данных или кода

Структура дескриптора, которая поддерживается в процессоре Pentium, сложилась исторически. Многое в ней связано с обеспечением совместимости с предыдущими процессорами семейства х86. Именно этим объясняется то, что базовый адрес сегмента представлен в дескрипторе в виде трех частей, а размер сегмента занимает два поля.

Ниже перечислены основные поля дескриптора.

  • База — базовый адрес, сегмента (32 бита).'

  • Размер — размер сегмента (24 бита).

  • G (Granularity) — единица измерения размера сегмента, один бит. Если G = 0, то размер задан в байтах, и тогда сегмент не может быть больше 64 Кбайт, если G = 1, то размер сегмента измеряется в страницах по 4 Кбайт.

  • Байт доступа (пятый байт дескриптора) содержит информацию, которая используется для принятия решения о возможности или невозможности обращения к данному сегменту. Бит Р (Present) определяет, находится ли соответствующий сегмент в данный момент в памяти (Р = 1) или он выгружен на диск (Р = 0). Поле DPL (Descriptor Privilege Level) содержит данные об уровне привилегий, необходимом для доступа к сегменту. Остальные 5 бит байта доступа зависят от типа сегмента и определяют способ, которым можно использовать данный сегмент (то есть читать, писать, выполнять). Различается три основных типа сегментов:

  • сегмент данных;

  • кодовый сегмент;

  • системный сегмент (GDT, TSS и т. п.).

Дескрипторы сегментов объединяются в таблицы. Процессор Pentium для управления памятью поддерживает два типа таблиц дескрипторов сегментов1:

  • глобальная таблица дескрипторов (Global Descriptor Table, GDT) предназначена для описания сегментов операционной системы и общих сегментов для всех прикладных процессов, например сегментов межпроцессного взаимодействия;

  • локальная таблица дескрипторов (Local Descriptor Table, LDT) содержит дескрипторы сегментов отдельного пользовательского процесса.

Таблица GDT одна, а таблиц LDT столько, сколько в системе выполняется задач (процессов). При этом в каждый момент времени операционной системой и аппаратными средствами процессора используется только одна из таблиц LDT, а именно та, которая соответствует выполняемому в данный момент поль­зовательскому процессу. Таблица GDT описывает общую часть виртуального адресного пространства процессов, a LDT —индивидуальную часть для каждо­го процесса. Таблицы GDT и LDT размещены в оперативной памяти в виде отдельных сегментов. Сегменты LDT и GDT содержат системные данные, поэтому их дескрипторы хранятся в таблице GDT. Таким образом, таблица GDT наряду с записями о других сегментах содержит запись о самой себе, а также обо всех таблицах LDT.

В каждый момент времени в специальных регистрах GDTR и LDTR хранит­ся информация о местоположении и размерах глобальной таблицы GDT и активной таблицы LDT соответственно. Регистр GDTR содержит 32-разрядный физический адрес начала сегмента GDT в памяти, а также 16-разрядный размер этого сегмента (рис. 6.4). Регистр LDTR указывает на расположение сегмента LDT в оперативной памяти косвенно — он содержит индекс дескриптора в таблице GDT, в котором содержится адрес таблицы LDT и ее размер.

Рис. 6.4. Формат регистра QDTR

Процесс обращается к физической памяти по виртуальному адресу, пред­ставляющему собой пару (селектор, смещение). Селектор однозначно определяет виртуальный сегмент, к которому относится искомый адрес, то есть он может интерпретироваться как номер сегмента, а смещение, как это и следует из его названия, фиксирует положение искомого адреса относительно начала сегмента. Смещение задается в машинной инструкции, а селектор помещается в один из сегментных регистров процессора. Под смещение отводится 32 бита, что обеспечивает максимальный размер сегмента 4 Гбайт (232).

Селектор извлекается из одного из шести 16-разрядных сегментных регистров процессора (CS, SS, DS, ES, FS или GS) в Зависимости от типа команды и стадии ее выполнения — выборка кода команды или данных. Например, при обращении к памяти во время выборки следующей команды используется селектор из сегментного регистра кода CS, а при записи результатов в сегмент данных процесса селекторы извлекаются из сегментных регистров данных DS или ES, если же данные записываются в стек по команде PUSH, то механизм виртуальной памяти извлекает селектор из сегментного регистра стека SS и т. п.

Рис. 6.5. Формат селектора

Селектор состоит из трех полей (рис. 6.5):

  • индекс — задает последовательный номер дескриптора в таблице GDT или LDT (13 бит);

  • указатель типа используемой таблицы дескрипторов: GDT или LDT (1 бит);

  • требуемый уровень привилегий — RPL (2 бита), это поле используется механизмом защиты данных, который рассматривается далее.

Виртуальное адресное пространство процесса складывается из всех сегментов, описанных в общей для всех процессов таблице GDT, и сегментов, описанных в его собственной таблице LDT. Разрядность поля индекса определяет максимальное число глобальных и локальных сегментов процесса — по 8 Кбайт (213) сегментов каждого типа, всего 16 Кбайт сегментов. Учтем также, что максимальный размер сегмента составляет 4 Гбайт. Отсюда следует, что:

Каждый процесс при сегментной организации виртуальной памяти (без включения страничного механизма) может работать в виртуальном адресном пространстве размером 64 Тбайт.

Каждый дескриптор в таблицах GDT и LDT имеет размер 8 байт, поэтому максимальный размер каждой из этих таблиц составляет 64 Кбайт (8 байт * 8 Кбайт дескрипторов).

Из приведенного описания видно, что процессор Pentium обеспечивает поддержку работы ОС в двух отношениях:

  • поддерживает работу подсистемы виртуальной памяти за счет быстрого аппаратного преобразования виртуального адреса в физический;

  • обеспечивает взаимную защиту данных и кодов различных прикладных процессов.