6. Распределитель памяти ядра
1. Частое выделение/освобождение структур
2. Необходимо динамическое выделение объектов
3. Если нет памяти:
1. Заблокировать вызывающий процесс
2. Вернуться с ошибкой без блокировки
4. Должен отслеживать свободные части выделенного страничным
аллокатором пула и уменьшать степень фрагментации
7. Оценка аллокаторов
1. Фактор использования
𝑉𝑟𝑒𝑞
, где 𝑉𝑟𝑒𝑞 − запрашиваемая память, 𝑉𝑡𝑜𝑡 − требуемая память
𝑉𝑡𝑜𝑡
2. Скорость выделения/освобождения памяти
3. Простота использования аллокатора
10. Виды аллокаторов
1. Список свободных элементов
2. Выделение памяти по степени 2
3. Алгоритм Мак-Кьюзи-Кэрелса
4. Алгоритм двойников
5. Слябовый аллокатор
11. Список свободных элементов.
Основные положения
1. Свободные блоки организуем в список
2. Блок хранит размер и ссылку на следующий свободный блок
3. Стратегии выбора свободного блока:
a)
b)
c)
d)
Первое подходящее
Следующее подходящее
Наиболее подходящее
Наименее подходящее
12. Алгоритм выделения/освобождения
памяти
1. Выделение
a) Находим нужный блок памяти
b) Уменьшаем его размер на N
c) Если есть свободный блок длиной N+1 нельзя выделить из него блок длиной
N
2. Освобождение
a) Находим место для вставки освобожденного блока
b) При необходимости производим слияние соседних блоков
c) С односвязным списком сложность O(n)
13. Улучшения
1. Использование двусвязного списка
a) В занятом блоке храним: размер, тег «занят» вначале и конце блока
b) В свободном блоке: ссылки на следующий и предыдущие свободные блоки,
тег «свободен» в начале блока
2. Хранение размера занятого блока
14. Анализ аллокатора: «список
свободных элементов»
Плюсы
◦
◦
◦
◦
Простота
Можно выделять ровно запрошенное количество байт
Можно освобождать меньше, чем размер занятого блока
Есть слияние свободных блоков
Минусы
◦ Большая фрагментация при длительной работе
◦ Для ускорения требуется значительное количество дополнительной памяти
15. Выделение памяти по степени 2
1. Вся память делится на списки свободных элементов равного размера
2. Если элемент свободен, то хранит ссылка на следующий свободный
элемент
3. Если элемент занят, то хранит на ссылка на голову списка, откуда он был
взят
4. При освобождение нужно просто добавить элемент к голове указанного
списка
5. При выделении выбирается список K = [log2(N)]
17. Блоки по
n:
2
анализ
Плюсы
◦ Удобный интерфейс для free()
◦ Быстрый поиск ресурса для выделения
Минусы
◦
◦
◦
◦
Использование лишней памяти
В занятой памяти хранится указатель на голову списка
Нельзя освобождать буферы частично
Нет слияния буфера и возвращение памяти страничному аллокатору
18. Алгоритм Мак-Кьюзика-Кэрелса
1. Является улучшенной версией алгоритма «Блоки по 2n»
2. Храним массив страниц
a) Страница может быть свободной и хранить ссылку на следующую свободную
страницу
b) Может быть разбита на блоки, в массиве содержится размер блока, на
которые разбита страница
c) Указатель на то, что страница является частью одной объединения страниц
3. Храним массив с указателями на списки свободных блоков
◦
◦
Блоки имеют размер равный степени 2
Блоки внутри одной страницы имеют одинаковый размер
19. Выделение/освобождение памяти
Выделение
◦ При запросе памяти округляем запрос до степени 2
◦ При выделении блока в блоке не требуется хранить дополнительную
информацию
◦ Если нет блока нужного размера, то выделяем новую страницу, которую
разбиваем на блоки данного размера
Освобождение
◦ Для освобождения не требуется указывать размер блока
21. Анализ
Плюсы
◦ Блоки можно выделять нужного размера
◦ Блоки формируются по требованиям системы
◦ Функция free не требует размера освобождаемого блока
Минусы
◦ Нет возможности возвращать страницы обратно страничному аллокатору
◦ Нет возможности слияния блоков
◦ Возможны потери при неравномерном распределении запрашиваемых
размеров памяти
26. Основные положения алгоритма
1. Бьем свободный пул до тех пор пока не получаем блок нужного размера
2. Части разделенного блока называют двойниками
3. В каждом блоке надо хранить тег «свободен»/ «занят»
4. Если известен адрес блока и его размер, то известен адрес двойника
Адрес: 10110000, размер: 16 -> адрес двойника: 10100000
5. Если освобождается блок, и его двойник оказывается свободен, то
двойников сливают. Полученный блок пытаются слить с его двойником.
Блок, который не удалось слить добавляют в список свободных блоков
6. Свободные блоки хранятся в двусвязном списке
27. Анализ и улучшения
Плюсы
◦ Объединение смежных блоков
◦ Легко обмениваться со страничным аллокатором
Минусы
◦ При частом выделении/освобождение падает производительность из-за
слияния
◦ При удалении необходимо указывать размер блока
◦ Можно выделить только блок кратный степени 2
Улучшения
◦ N=A+L+G
◦ slack = N – 2*L – G - отложенное слияние, только если slack < 2
28. Слябовый аллокатор
1. Цикл жизни объекта: создание – использование – уничтожение –
освобождение
2. Возможно использовать повторно объекты без инициализации
3. Объекты ядра делятся на группы-кэши, кэш делится на слябы (слябы
представляют собой одна или последовательность нескольких страниц),
которые содержат объекты. При создании пытаемся найти свободный
объект в слябе. При удалении помечаем объект в слябе, как свободный.