8. Иерархия памяти
Страничная организация памяти
В системах со страничной организацией основная и внешняя память
(главным образом дисковое пространство) делятся на блоки или страницы
фиксированной длины. Каждому пользователю предоставляется некоторая
часть адресного пространства, которая может превышать основную память
компьютера и которая ограничена только возможностями адресации,
заложенными в системе команд. Эта часть адресного пространства называется
виртуальной памятью пользователя. Каждое слово в виртуальной памяти
пользователя определяется виртуальным адресом, состоящим из двух
частей: старшие разряды адреса рассматриваются как номер страницы,
а младшие - как номер слова (или байта) внутри страницы.
Управление различными уровнями памяти осуществляется программами
ядра операционной системы, которые следят за распределением страниц
и оптимизируют обмены между этими уровнями. При страничной организации
памяти смежные виртуальные страницы не обязательно должны размещаться
на смежных страницах основной физической памяти. Для указания соответствия
между виртуальными страницами и страницами основной памяти операционная
система должна сформировать таблицу страниц для каждой программы
и разместить ее в основной памяти машины. При этом каждой странице
программы, независимо от того находится ли она в основной памяти
или нет, ставится в соответствие некоторый элемент таблицы страниц.
Каждый элемент таблицы страниц содержит номер физической страницы
основной памяти и специальный индикатор. Единичное состояние этого
индикатора свидетельствует о наличии этой страницы в основной памяти.
Нулевое состояние индикатора означает отсутствие страницы в оперативной
памяти.
Для увеличения эффективности такого типа схем в процессорах используется
специальная полностью ассоциативная кэш-память, которая также называется
буфером преобразования адресов (TLB traнсlation-lookaside buffer).
Хотя наличие TLB не меняет принципа построения схемы страничной
организации, с точки зрения защиты памяти, необходимо предусмотреть
возможность очистки его при переключении с одной программы на другую.
Поиск в таблицах страниц, расположенных в основной памяти, и загрузка
TLB может осуществляться либо программным способом, либо специальными
аппаратными средствами. В последнем случае для того, чтобы предотвратить
возможность обращения пользовательской программы к таблицам страниц,
с которыми она не связана, предусмотрены специальные меры. С этой
целью в процессоре предусматривается дополнительный регистр защиты,
содержащий описатель (дескриптор) таблицы страниц или базово-граничную
пару. База определяет адрес начала таблицы страниц в основной памяти,
а граница - длину таблицы страниц соответствующей программы. Загрузка
этого регистра защиты разрешена только в привилегированном режиме.
Для каждой программы операционная система хранит дескриптор таблицы
страниц и устанавливает его в регистр защиты процессора перед запуском
соответствующей программы.
Отметим некоторые особенности, присущие простым схемам со страничной
организацией памяти. Наиболее важной из них является то, что все
программы, которые должны непосредственно связываться друг с другом
без вмешательства операционной системы, должны использовать общее
пространство виртуальных адресов. Это относится и к самой операционной
системе, которая, вообще говоря, должна работать в режиме динамического
распределения памяти. Поэтому в некоторых системах пространство
виртуальных адресов пользователя укорачивается на размер общих процедур,
к которым программы пользователей желают иметь доступ. Общим процедурам
должен быть отведен определенный объем пространства виртуальных
адресов всех пользователей, чтобы они имели постоянное место в таблицах
страниц всех пользователей. В этом случае для обеспечения целостности,
секретности и взаимной изоляции выполняющихся программ должны быть
предусмотрены различные режимы доступа к страницам, которые реализуются
с помощью специальных индикаторов доступа в элементах таблиц страниц.
Следствием такого использования является значительный рост таблиц
страниц каждого пользователя. Одно из решений проблемы сокращения
длины таблиц основано на введении многоуровневой организации таблиц.
Частным случаем многоуровневой организации таблиц является сегментация
при страничной организации памяти. Необходимость увеличения адресного
пространства пользователя объясняется желанием избежать необходимости
перемещения частей программ и данных в пределах адресного пространства,
которые обычно приводят к проблемам переименования и серьезным затруднениям
в разделении общей информации между многими задачами.
|