Защита памяти на уровне сегментов
В х86 определено понятие привилегии для сегмента и установлены 4 уровня привилегий PL (рис. 7.7), которые задаются номерами от 0 (наиболее защищенный) до 3 (низший). В ядро входит часть ОС, обеспечивающая инициализацию работы, управление доступом к памяти, защиту и ряд других жизненно важных функций, нарушение которых полностью выводит из строя МПС. Основная часть ОС должна иметь уровень 1. К уровню 2 обычно относят ряд служебных программ ОС, например, драйверы внешних устройств, системы управления базами данных, специализированные подсистемы программирования и др. Рис. 7.7. Кольца защиты сегментов Выше отмечалось, что основой организации памяти x86 является сегмент. С каждым сегментом (данных, кода или стека) ассоциируется уровень привилегий DPL и все, что находится внутри этого сегмента, имеет данный уровень привилегий. DPL располагается в байте доступа дескриптора сегмента, поэтому его называют уровнем привилегий дескриптора (Descriptor Privilege Level), однако правильнее считать его уровнем привилегий сегмента. Уровень привилегий выполняющегося кода называется текущим уровнем привилегий CPL (Current Privilege Level или Code Privilege Level) и он задается полем RPL селектора в сегментном регистре CS. Значение CPL можно считать уровнем привилегий процессора в текущий момент времени, т. к. при передаче управления сегменту кода с другим уровнем привилегий процессор будет работать на новом уровне привилегий. Каждый селектор выбирает точно один дескриптор и, соответственно, один сегмент, но конкретный сегмент могут идентифицировать несколько селекторов ("альтернативное именование"). Младшие два бита селектора содержат поле запрашиваемого уровня привилегий RPL (Requested Privilege Level). Это поле не влияет на выбор дескриптора, но учитывается при контроле привилегий. (Страница187) Таким образом, текущее состояние системы защиты характеризуется следующими признаками: □ CPL — уровень привилегий выполняемого кода, размещается в поле RPL сегментного регистра кода CS; □ DPL — уровни привилегий для каждого из восьми открытых сегментов, располагаются в байте доступа дескрипторов, помещенных в "теневые регистры"; □;RPL — определяют уровни привилегий источника селектора, размещаются в полях RPL сегментных регистров. Процессор постоянно контролирует, обладает ли текущая программа достаточным уровнем привилегий, чтобы: □ выполнять некоторые команды; □ обращаться к данным других программ; □ передавать управление внешнему (по отношению к программе) коду командами передачи управления типа FAR. Рис. 7.8. Правила доступа к сегментам В системе команд существуют специальные привилегированные команды, которые могут выполняться процессором, работающим только на уровне привилегий 0. При попытке выполнить их на другом уровне привилегий генерируется прерывание 13 — нарушение общей защиты. К привилегированным относятся команды: □ останов процессора; □ сброс флага переключенной задачи; □загрузка регистров дескрипторных таблиц; □загрузка регистра задачи; □ загрузка слова состояния машины; □ модификация флага прерываний IF*; □ команды ввода/вывода*. Последние две группы команд (отмеченные *) не обязательно выполняются на нулевом уровне, достаточно, чтобы уровень привилегий программы был выше уровня привилегий ввода/вывода, определяемого полем IOPL в регистре EFLAGS.
|