• Элитная недвижимость в испании

    элитная недвижимость в испании на море.

    inmobilaria.ru

  • Входные парадные двери

    С хорошей скидкой входные парадные двери без дополнительной оплаты.

    www.dverivse.ru





Linux Kernel (Ядро линукса) (часть 3)


Обратное отображение для отображающих страниц

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

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

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

Дерево приоритетного поиска существует для каждого файла, а его корень хранится В поле i_mmap объекта address space, встроенного В объект inode данного файла. Всегда есть возможность быстро получить корень этого поискового дерева, потому что поле mapping в дескрипторе отображающей страницы указывает на объект address space.

Предыдущая страница | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | Следующая страница




Возможно, Вас также заинтересует:

ОС Knoppix - это Linux без проблем

ВведениеЕсли вы цените свое время, умеете считать деньги и знаете стоимость информации, то эта книга для вас. А так как к книге прилагается компакт- диск с готовой к работе операционной системой Knoppix Live CD, то лишь достаточно вставить его в привод и перегрузить компьютер,...

Linux Kernel (Ядро линукса) (часть 1)

Спин-блокировкаСпин-блокировка необходима в многопроцессорной системе, потому что могут возникнуть другие прерывания того же типа, и другие процессоры могут приступить к их обработке. Без спин-блокировки к главному дескриптору прерывания могли бы обратиться сразу несколько процессоров. Как мы...

Linux Kernel (Ядро линукса) (часть 2)

Копирование при записи В системах Unix первых поколений создание процесса было реализовано довольно неуклюже: получив системный вызов fork о, ядро в буквальном смысле дублировало все адресное пространство родителя и присваивало копию процессу-потомку. Такая операция...

Linux Kernel (Ядро линукса) (часть 3)

Буферы блоков и головы буферовУ каждого буфера есть дескриптор голова буфера, имеющий тип buffer head. Этот дескриптор содержит всю информацию, необходимую ядру для работы с блоком, так что перед обработкой блока ядро обязательно проверяет голову...