Каждая страница в страничной памяти обладает ассоциированной с ней структурой раде. Эта структура содержит поля для хранения указателя на vnode и смещение, которые вместе образуют имя страницы. Подсистема виртуальной памяти инициализирует эти поля при первом переносе страницы в память.
Также вам может показаться, что такая тема как http://www.paliha14.ru/oformlenie-sharami никак не связана и даже не тематична. Хотя, может быть и связана. В любом случае все-таки зайдите на сайт paliha14.ru. Тема оформление шарами там представлена весьма широко. На том сайте можно узнать много интересного на тему оформление шарами. Что означает вообще тема оформление шарами, где найти оформление шарами - про это написано на сайте paliha14.ru. Это очень важная для многих людей тема - оформление шарами. Спасибо сайту paliha14.ru за информацию на тему оформление шарами.
Демон pagedaemon периодически выгружает все «грязные» (то есть содержащие изменения) страницы на диск. Он выбирает страницы для записи исходя из правила - описание алгоритма давно использованных страниц), согласно которому наиболее часто используемые страницы остаются в памяти.
Существуют и некоторые другие операции ядра, сбрасывающие страницы на диск, такие как выгрузка в область свопинга адресного пространства процесса целиком или вызов функции fsync.
Для сброса страницы на диск ядро получает объект vnode из структуры раде и запускает для него операцию VOP_PUTPAGE. Если страница относится к файлу устройства, это приведет к вызову функции spec_putpage(), которая получит номер устройства из объекта vnode и вызовет для этого устройства процедуру d_strategy().
Если нужно сбросить на диск страницу обычного файла, то реализация этой задачи будет зависеть от конкретной файловой системы. Например, для записи на диск страниц файлов ufs применяется функция ufs_putpage(). Она вызывает ufs_bmap() для получения физического номера блока и затем вызывает процедуру d_strategy() устройства (номер которого содержится в индексном дескрипторе, доступном через объект vnode). Функция ufs_putpage() также производит некоторые оптимизирующие действия, такие как кластеризация (clustering) (сбор смежных измененных страниц и одновременная их запись в одном запросе ввода-вывода).
Ввод-вывод файлов, отображаемых в память
Процесс может отображать файл или какую-либо его часть в сегмент своего адресного пространства, используя для этой цели системный вызов mmap. При загрузке программы посредством ехес происходит отображение ее текстов и данных в адресное пространство процесса. Более подробно о файлах, отображаемых в память, читайте в разделе 14.2. После создания отображения процесс может попытаться прочесть страницу, не находящуюся в памяти (либо не отображенную в таблице аппаратного преобразования адресов, HAT). В этом случае произойдет страничное исключение (page fault). Так как страницы файлов, отображаемых в памяти, относятся к сегментам vnode (seg_vn), для обработки ошибки вызывается процедура segvn_fault(). Она запускает операцию VOP_GETPAGE объекта vnode файла, имеющего указатель на закрытые структуры данных сегмента.
Точно также при изменении процессом страницы, отображенной в режиме разделения (shared mapping), необходимо произвести ее запись в соответствующий файл. Это действие наиболее часто производится при выгрузке страницы процессом pagedaemon, как это описывалось в предыдущем подразделе.
Блочный ввод-вывод
В системе SVR4 чтение и запись обычных файлов реализовано через драйвер seg_map. Например, при вызове системной функции read ядро использует дескриптор файла для определения структуры file, из которой, в свою очередь, получает данные об объекте vnode файла. Затем ядро вызывает операцию V0P_READ объекта vnode, реализованную в виде функции, зависимой от конкретной файловой системы. Для примера выберем файловую систему ufs. В этом случае применяется функция ufs_read(), которая производит чтение в указанной ниже последовательности.
1. Вызывает segmap_getmap() с целью создания отображения ядра для нужной записи (байтовой области) файла. Функция возвращает адрес, по которому произошло отображение данных в пространстве ядра.
2. Вызывает uiomove() для передачи данных файла в прикладное пространство. Адрес источника данных берется из информации, полученной на предыдущем шаге.
3. Вызывает segmap_release() для открепления отображения. Драйвер seg_ map кэширует такие отображения в порядке LRU, предполагая, что недавно использованные страницы наиболее вероятно будут запрошены повторно.
Если страница не оказалась в памяти или ядро не обладает корректным преобразованием адреса для нее, функция uiomove() вырабатывает страничную ошибку. Обработчик исключения определяет, что данная страница относится к сегменту seg_map, и вызывает segmap_fault() для загрузки ее в память. Функция segmap_fault() запускает операцию VOP_GETPAGE объекта vnode, которая и считывает страницу с диска, если это необходимо.
Прямой ввод-вывод блочных устройств
Опубликовал katy
June 24 2015 16:41:11 ·
0 Комментариев ·
3693 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.