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