• Планкен из лиственницы недорого

    Планкен продажа. Планкен из лиственницы недорого.

    kublesa.ru





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


Выделение и освобождение страничного слота

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

В Linux принят гибридный подход. Алгоритм всегда начинает с последнего выделенного страничного слота, если не возникает одна из следующих ситуаций:
- достигнут конец области подкачки;
- после последнего рестарта с начала области подкачки было выделено swapfile_cluster свободных страничных слотов (обычно 256).
Поле ciuster nr в дескрипторе swap info struct содержит количество выделенных свободных страничных слотов. Это поле сбрасывается в ноль, когда функция заново приступает к выделению с начала области подкачки. Поле ciuster next содержит индекс первого страничного слота, который нужно рассмотреть при следующем выделении10.

Чтобы ускорить процесс поиска свободных страничных слотов, ядро поддерживает в полях lowest bit и highest bit каждого дескриптора области подкачки самую свежую информацию. Эти поля определяют первый и последний страничные слоты, которые могут быть свободными. Иными словами, каждый страничный слот ниже lowest bit и выше highest bit наверняка занят.

Предыдущая страница | 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. Этот дескриптор содержит всю информацию, необходимую ядру для работы с блоком, так что перед обработкой блока ядро обязательно проверяет голову...