Общие принципы управления виртуальной памятью в Win32 презентация

Содержание


Презентации» Информатика» Общие принципы управления виртуальной памятью в Win32
Управление памятью в ОС Windows
 Общие принципы управления виртуальной памятью вОбщие принципы управления виртуальной памятью в Win32
 Менеджер виртуальной памяти иМенеджер виртуальной памяти
 Менеджер виртуальной памяти (VMM) является составной частью ядраАрхитектура API управления  32-разрядной памятьюИнтерфейсы управления памятью
 Virtual Memory API – набор функций, позволяющих приложениюВиртуальное адресное пространство процессаРасширенное пользовательское пространство
 Чтобы включить в Windows Server 2003 и WindowsСтраничное преобразование
 Виртуальная память в Windows 2000+ имеет страничную организацию. 
Размер страницыСредства защиты памяти 
 Объектно-ориентированная защита памяти. Каждый раз, когда процессОбщие принципы управления виртуальной памятью в Win32
 Управлению памятью на архитектуреАрхитектура процессора IA-32 (1)
 Все 32-разрядные процессоры, начиная с i386, имеютАрхитектура процессора IA-32 (2)
 Например, младший бит из регистра CR0 называетсяРегистры управления памятью на процессоре IA-32
 PG (Paging) включает использование страничногоРежим PAE
 Расширение физических адресов (Physical Address Extension – РАЕ)  –Поддержка PAE в различных операционных системах
 В 32-разрядных Microsoft Windows (начинаяСводная информация по управлению памятью в IA-32
 Таким образом, архитектура IA-32Общие принципы управления виртуальной памятью в Win32
 Реализация страничного преобразованияФормат 32-разрядного виртуального адреса в системах x86 (страница 4 КБайт)
 СтаршиеАдресация больших страниц для x86-архитектуры
 PSE-36
 PAEВопрос
 Какие проблемы Вы видите при использовании драйверами операционной системы «больших»Трансляция виртуального адреса в системах x86 (страница 4 КБайт)Формат PTE для страницы размером 4 Кбайта
 Таблица страниц – этоБиты PTE
 Global (G) – страница относится ко всем процессам
 PageКаталог страниц и формат PDE для страниц размером 4 Кбайта
 КаталогТрансляция виртуального адреса в системах x86 (страница 4 МБайт)
 210 PDEКаталог страниц и формат PDE для страниц размером 4 МБайта
 КаталогСовместное использование страниц разного размера
 При установленном бите PSE регистра CR4Расширение физического адресного пространства
 Благодаря поддержке процессором механизма расширения физического адресногоФормат PDE в режиме PAEРеализация механизма PAE для страниц размером 4 КбайтаФормат PTE для страницы 4 КБайтаФормат PDE для страницы 2 МБайтаПрактическое использование «больших» страниц
 Для пользовательского приложения – выделение виртуальной памятиОбщие принципы управления виртуальной памятью в Win32
 Ускорение страничных преобразованийРеализация TLB-кэша в Windows
 Часто используемым страницам (точнее их PTE) соответствуютСхема реализации TLBЭффективность использования больших страниц для TLB-кэша
 Недостатком «маленьких» страниц является неэффективноеПроблемы использования TLB
 При  переключении процессов нужно добиться того, чтобы новыйОбщие принципы управления виртуальной памятью в Win32
 Стратегия управления виртуальной памятьюСтратегия управления виртуальной памятью
 Стратегия  выборки (fetch policy) 
 Стратегия размещенияСтратегия выборки
 Стратегия  выборки (fetch policy):
 Выборка определяет, в какой моментСтратегия размещения
 Стратегия  выборки (fetch policy) 
 Стратегия размещения (placement policy):
Стратегия замещения
 Стратегия  выборки (fetch policy) 
 Стратегия размещения (placement policy)Реализация стратегии управления виртуальной памятьюСвопинг
 Для того, чтобы обеспечить все линейное адресное пространство процесса физическимиСостояния страниц
 Valid или Active – страница используется процессом. Она реальноФормат PTE для страницы в оперативной памяти
 Valid (Present) = 1Формат PTE для страницы в файле подкачки
 Valid (Present) = 0Формат PTE для «похищенной» страницы
 Valid (Present) = 0 – страницаТаблица состояний страницWindows-реализация алгоритма замещения LRU
 VMM периодически просматривает список страниц с установленнымГраф состояний страниц (1)Граф состояний страниц (2)



Слайды и текст этой презентации
Слайд 1
Описание слайда:
Управление памятью в ОС Windows Общие принципы управления виртуальной памятью в Win32


Слайд 2
Описание слайда:
Общие принципы управления виртуальной памятью в Win32 Менеджер виртуальной памяти и архитектура Win32 API

Слайд 3
Описание слайда:
Менеджер виртуальной памяти Менеджер виртуальной памяти (VMM) является составной частью ядра ОС. Приложения не могут получить к нему прямой доступ. Основные функции VMM: управление виртуальными адресными пространствами процессов; разделение памяти между процессами; защита виртуальной памяти одного процесса от других процессов.

Слайд 4
Описание слайда:
Архитектура API управления 32-разрядной памятью

Слайд 5
Описание слайда:
Интерфейсы управления памятью Virtual Memory API – набор функций, позволяющих приложению работать с виртуальным адресным пространством: назначать физические страницы блоку адресов и освобождать их, устанавливать атрибуты защиты. Memory Mapped File API – набор функций, позволяющий работать с файлами, отображаемыми в память. Heap Memory API – набор функций, позволяющих работать с динамически распределяемыми областями памяти (кучами). Local, Global Memory API – набор функций работы с памятью, совместимых с 16-разрядной Windows. Следует избегать их использования. CRT Memory API – функции стандартной библиотеки языка Си периода исполнения (runtime).

Слайд 6
Описание слайда:
Виртуальное адресное пространство процесса

Слайд 7
Описание слайда:
Расширенное пользовательское пространство Чтобы включить в Windows Server 2003 и Windows 2000 расширенное пользовательское пространство, необходимо указать в файле Boot.ini ключ /3GB. Windows XP и Windows Server 2003 поддерживают дополнительный ключ (/USERVA), который дает возможность задавать размер пользовательского адресного пространства между 2 и 3 Гб (значение указывается в мегабайтах). Приложение для адресации 3 Гб должно быть собрано с ключом /LARGEADDRESSAWARE:YES.

Слайд 8
Описание слайда:
Страничное преобразование Виртуальная память в Windows 2000+ имеет страничную организацию. Каждому процессу Windows назначается свой каталог страниц. Именно поэтому адресное пространство каждого процесса изолировано, что очень хорошо с точки зрения защиты процессов друг от друга. Процессоры Intel начиная с Pentium Pro позволяют применять одно-, двух- и трехступенчатые схемы, также разрешается одновременное использование страниц различного размера.

Слайд 9
Описание слайда:
Размер страницы

Слайд 10
Описание слайда:
Средства защиты памяти Объектно-ориентированная защита памяти. Каждый раз, когда процесс открывает указатель на блок адресов, монитор ссылок безопасности проверяет, разрешен ли доступ процесса к данному объекту. Отдельное адресное пространство для каждого процесса. Аппаратура запрещает процессу доступ к физическим адресам другого процесса. Два режима работы: режим ядра, в котором процессам разрешен доступ к системным данным, и пользовательский режим, в котором это запрещен. Страничный механизм защиты. Каждая виртуальная страница имеет набор признаков, который определяет разрешенные типы доступа в пользовательском режиме и в режиме ядра. Принудительная очистка страниц, освобождаемых процессами.

Слайд 11
Описание слайда:
Общие принципы управления виртуальной памятью в Win32 Управлению памятью на архитектуре IA-32

Слайд 12
Описание слайда:
Архитектура процессора IA-32 (1) Все 32-разрядные процессоры, начиная с i386, имеют набор системных регистров, предназначенных для использования в защищённом режиме, среди них есть регистры управления CR0, CR1, CR3 и CR4 (был введен в процессоре Pentium). Регистры управления, в основном, состоят из флагов. Назначение и использование каждого флага требует отдельного рассмотрения.

Слайд 13
Описание слайда:
Архитектура процессора IA-32 (2) Например, младший бит из регистра CR0 называется PE (Protection Enable). Если установить этот бит в 1, процессор перейдёт в защищённый режим, если сбросить – то в режим реальных адресов. 

Слайд 14
Описание слайда:
Регистры управления памятью на процессоре IA-32 PG (Paging) включает использование страничного преобразования; PSE (Page Size Extension) управляет размером страницы; PAE (Page Address Extension) включает режим расширения физического адресного пространства (36 бит).

Слайд 15
Описание слайда:
Режим PAE Расширение физических адресов (Physical Address Extension – РАЕ)  – режим работы встроенного блока управления памятью процессоров с архитектурой IA-32, в котором используются 64-битные элементы таблиц страниц (из которых для адресации используются только 36 бит). РАЕ делает возможной адресацию процессором 64 ГБайт физической памяти, хотя каждый процесс всё равно может адресовать максимум до 4 Гбайт адресов виртуальной памяти. Кроме того, режим PAE позволяет использовать «большие» страницы размером 2 Мбайта.

Слайд 16
Описание слайда:
Поддержка PAE в различных операционных системах В 32-разрядных Microsoft Windows (начиная с Windows XP SP2) использование 36-битного PAE включается ключом /PAE в файле boot.ini. Одним из пунктов минимальных системных требований Windows 8 является обязательная поддержка процессором PAE. Linux начиная с версии 2.3.23. FreeBSD поддерживает PAE: в линейке 4.x версий  – начиная с 4.9, в линейке 5.x версий – начиная с 5.1, все 6.x и более поздние. Solaris поддерживает PAE, начиная с версии 7. В Mac OS X режим PAE включён по умолчанию при использовании 32-разрядного ядра.

Слайд 17
Описание слайда:
Сводная информация по управлению памятью в IA-32 Таким образом, архитектура IA-32 поддерживает страницы нескольких размеров (4 КБайт, 2 МБайт и 4 МБайт), а также возможность адресации до 64 ГБайт физического адресного пространства.

Слайд 18
Описание слайда:
Общие принципы управления виртуальной памятью в Win32 Реализация страничного преобразования

Слайд 19
Описание слайда:
Формат 32-разрядного виртуального адреса в системах x86 (страница 4 КБайт) Старшие 10 разрядов адреса определяют номер одного из 1024 элементов в каталоге страниц, адрес которого находится в регистре процессора CR3. Этот элемент содержит физический адрес таблицы страниц. Следующие 10 разрядов линейного адреса определяют номер элемента таблицы. Элемент, в свою очередь, содержит физический адрес страницы виртуальной памяти. Размер страницы – 4 Кбайт, и младших 12 разрядов линейного адреса как раз хватает (212 = 4096), чтобы определить точный физический номер адресуемой ячейки памяти внутри этой страницы.

Слайд 20
Описание слайда:
Адресация больших страниц для x86-архитектуры PSE-36 PAE

Слайд 21
Описание слайда:
Вопрос Какие проблемы Вы видите при использовании драйверами операционной системы «больших» страниц?

Слайд 22
Описание слайда:
Трансляция виртуального адреса в системах x86 (страница 4 КБайт)

Слайд 23
Описание слайда:
Формат PTE для страницы размером 4 Кбайта Таблица страниц – это массив записей, состоящий из 210 4-байтовых элементов PTE (Page Table Entries). Каждый элемент PTE определяет состояние отдельной страницы размером 4 Кбайта. Если страница находится в оперативной памяти (бит «P» = 1), то PTE указывает адрес соответствующей страницы физической памяти.

Слайд 24
Описание слайда:
Биты PTE Global (G) – страница относится ко всем процессам Page Table Attribute Index (PAT) – используется процессором (начиная с Pentium Pro) вместе с битами PCD и PWT для определения по специальной внутренней программируемой PAT-таблице режима кэширования соответствующей страницы Dirty (D) – страница была изменена (была произведена запись) Accessed (A) – к странице был осуществлен доступ Cache disabled (PCD) – кэширование данной страницы отключено Write through (PWT) – включает режим сквозной записи при кэшировании User/Supervisor (U/S) – доступна ли страница для пользовательского кода Read/Write (R/W) – в однопроцессорных системах указывает разрешение на запись в страницу (страница для чтения и записи = 1 или только для чтения = 0)

Слайд 25
Описание слайда:
Каталог страниц и формат PDE для страниц размером 4 Кбайта Каталог страниц – это массив, состоящий из 210 4-байтовых элементов PDE (Page Directory Entries). Каждый элемент PDE определяет положение таблицы страниц, указывая адрес физической страницы памяти (бит «P» = 1). По формату PDE почти совпадает с PTE. 

Слайд 26
Описание слайда:
Трансляция виртуального адреса в системах x86 (страница 4 МБайт) 210 PDE = 1024 Pages 1024 × 4MB = 4GB Linear Address Space 2(14 + 22) = 64GB Physical Address Space

Слайд 27
Описание слайда:
Каталог страниц и формат PDE для страниц размером 4 МБайта Каталог страниц – это массив, состоящий из 210 4-байтовых элементов PDE (Page Directory Entries). Каждый элемент PDE определяет положение страницы размером 4 Мбайта, указывая адрес физической страницы памяти (бит «P» = 1).

Слайд 28
Описание слайда:
Совместное использование страниц разного размера При установленном бите PSE регистра CR4 возможно одновременное использование 4KB и 4MB страниц. Управление размером страницы осуществляется битом Page Size (PS, бит 7) элемента каталога страниц PDE: PS=1 – страница 4MB и PDE указывает на страницу; PS=0 – страница 4КB и PDE указывает на таблицу страниц.

Слайд 29
Описание слайда:
Расширение физического адресного пространства Благодаря поддержке процессором механизма расширения физического адресного пространства (PAE - Physical Address Extension), операционная система может использовать 36-разрядное пространство для организации многозадачности. При этом процессам, по прежнему, остается доступным только 32-разрядное пространство. Кроме того процессор допускает множественные ссылки на страницу (Memory Aliasing).

Слайд 30
Описание слайда:
Формат PDE в режиме PAE

Слайд 31
Описание слайда:
Реализация механизма PAE для страниц размером 4 Кбайта

Слайд 32
Описание слайда:
Формат PTE для страницы 4 КБайта

Слайд 33
Описание слайда:
Формат PDE для страницы 2 МБайта

Слайд 34
Описание слайда:
Практическое использование «больших» страниц Для пользовательского приложения – выделение виртуальной памяти с помощью вызова функции VirtualAlloc () с флагом MEM_LARGE_PAGE. Для драйверов операционной системы – задать список драйверов в реестре (параметр HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management\LargePageDrivers).

Слайд 35
Описание слайда:
Общие принципы управления виртуальной памятью в Win32 Ускорение страничных преобразований

Слайд 36
Описание слайда:
Реализация TLB-кэша в Windows Часто используемым страницам (точнее их PTE) соответствуют элементы в TLB (Translation Lookside Buffer), который обеспечивает быструю трансляцию виртуальных адресов в физические, а в результате и быстрый доступ к памяти. Если процесс обращается к странице, для которой нет записи в TLB, то для этой страницы создается элемент TLB. Если страница оказалась в страничном файле (бит «P» = 0) или если диспетчер памяти изменил его PTE, диспетчер памяти должен явно объявить соответствующий элемент TLB недействительным.

Слайд 37
Описание слайда:
Схема реализации TLB

Слайд 38
Описание слайда:
Эффективность использования больших страниц для TLB-кэша Недостатком «маленьких» страниц является неэффективное использование TLB, так для страниц размером 4 КБайт, механизм TLB содержит всего 32 записи в L1 кэше и 512 записей в L2 кэше. Так как каждая запись ссылается на 4 КБайт, то в сумме все записи «покрывают» чуть более 2 МБайт виртуальной памяти. В случае использования «больших» страниц TLB используется более эффективно. Для больших страниц TLB содержит восемь записей, так как каждая страница отображает 2 МБайт, то TLB может «покрывать» 16 МБайт виртуальной памяти. Использование «больших» страниц приводит к значительному увеличению производительности TLB-кэша и страничного преобразования в целом.

Слайд 39
Описание слайда:
Проблемы использования TLB При  переключении процессов нужно добиться того, чтобы новый процесс не видел в ассоциативной памяти информацию, относящуюся к предыдущему процессу, например, выполнять ее очистку. Для очистки TLB отдельной страницы предназначена команда INVTLB. В Windows очищаются все записи PTE, кроме тех, у которых установлен флаг Global. Для того чтобы объявить такую запись PTE недействительной, необходимо выполнить команду  INVLPG. TLB-кэши многопроцессорной системы аппаратно не синхронизируются, ядро операционной системы должно само выполнять действия по синхронизации их содержимого.

Слайд 40
Описание слайда:
Общие принципы управления виртуальной памятью в Win32 Стратегия управления виртуальной памятью и свопинг

Слайд 41
Описание слайда:
Стратегия управления виртуальной памятью Стратегия  выборки (fetch policy) Стратегия размещения (placement policy) Стратегия  замещения (replacement policy)

Слайд 42
Описание слайда:
Стратегия выборки Стратегия  выборки (fetch policy): Выборка определяет, в какой момент необходимо переписать страницу с диска в ОП. В Windows используется классическая схема выборки с упреждением: система переписывает в память не только выбранную страницу, но и несколько следующих по принципу пространственной локальности, гласящему: наиболее вероятным является обращение к тем ячейкам памяти, которые находятся в непосредственной близости от ячейки, к которой производится обращение в настоящий момент. Поэтому вероятность того, что будут востребованы последовательные страницы, достаточна высока. Их упреждающая подкачка позволяет снизить накладные расходы, связанные с обработкой прерываний. Стратегия размещения (placement policy) Стратегия  замещения (replacement policy)

Слайд 43
Описание слайда:
Стратегия размещения Стратегия  выборки (fetch policy) Стратегия размещения (placement policy): Размещение определяет, в какое место оперативной памяти необходимо поместить подгружаемую страницу. Для систем со страничной организацией данная стратегия практически не имеет никакого значения, и поэтому Windows выбирает первую попавшуюся свободную страницу. Стратегия  замещения (replacement policy)

Слайд 44
Описание слайда:
Стратегия замещения Стратегия  выборки (fetch policy) Стратегия размещения (placement policy) Стратегия  замещения (replacement policy): Замещение начинает действовать с того момента, когда в оперативной памяти компьютера не остается свободного места для размещения подгружаемой страницы. В этом случае необходимо решить, какую страницу вытеснить из физической памяти в файл подкачки (свопинг).

Слайд 45
Описание слайда:
Реализация стратегии управления виртуальной памятью

Слайд 46
Описание слайда:
Свопинг Для того, чтобы обеспечить все линейное адресное пространство процесса физическими ячейками памяти, Windows применяет свопинг (замещение страниц). Организацией свопинга занимается менеджер виртуальной памяти. При генерации системы на диске образуется специальный файл свопинга (файл подкачки), куда записываются те страницы, которым не находится места в физической памяти. Менеджер виртуальной памяти использует программную реализацию локального алгоритма LRU (Least Recently Used) – замещение дольше всех неиспользовавшихся страниц. Локальный алгоритм LRU используется для предотвращения трэшинга. Программная реализация алгоритма LRU предполагает, что каждая из страниц виртуальной памяти в каждый момент времени может иметь одно из нескольких состояний, на основании информации о состоянии страниц менеджер выполняет вытеснение страниц на файл подкачки.

Слайд 47
Описание слайда:
Состояния страниц Valid или Active – страница используется процессом. Она реально существует в ОП и помечена в PTE как присутствующая в рабочем множестве процесса (P(V)=1, D=0,1). Standby – содержимое страницы не изменялось (D=0). В PTE страница помечена как отсутствующая (P(V)=0) и переходная (T=1). Modified – содержимое страницы было изменено (D=1). В PTE страница помечена как отсутствующая (P(V)=0) и переходная (T=1). Free – страница, на которую не ссылается ни один PTE. Страница свободна, но подлежит обнулению, прежде чем будет использована. Zeroed – свободная и обнуленная страница, пригодная к непосредственному использованию любым процессом. Bad – страница, которая вызывает аппаратные ошибки и не может быть использована ни одним процессом.

Слайд 48
Описание слайда:
Формат PTE для страницы в оперативной памяти Valid (Present) = 1 – страница присутствует в ОП

Слайд 49
Описание слайда:
Формат PTE для страницы в файле подкачки Valid (Present) = 0 – страница отсутствует в ОП Transition = 0

Слайд 50
Описание слайда:
Формат PTE для «похищенной» страницы Valid (Present) = 0 – страница отсутствует в ОП Transition = 1 – страница «похищена» менеджером виртуальной памяти

Слайд 51
Описание слайда:
Таблица состояний страниц

Слайд 52
Описание слайда:
Windows-реализация алгоритма замещения LRU VMM периодически просматривает список страниц с установленным флагом Present (Valid) и пытается похитить их у процесса (1). Он помечает их как отсутствующие (P=0), но на самом деле оставляет их в оперативной памяти, только переводит в список Modified или Standby в зависимости от значения бита D из PTE. Если содержимое страницы была изменено в ОП (D=1), то VMM выполнит запись страницы на диск (4). Если похищенная страница принадлежит рабочему множеству, то к ней в ближайшее время произойдет обращение. Так как страница помечена как отсутствующая, то обращение к ней вызовет страничное прерывание («soft» page fault). Но VMM очень быстро сделает эту страницу вновь доступной процессу, поскольку она находится в оперативной памяти (2). Далее если к странице не будет обращений (страница вне рабочего множества), то она со временем перейдет в состояние Free (5) и станет доступна для замещения страниц в рамках данного процесса (6). Затем системный поток обнуляет страницу – Zeroed (7), и она станет доступна другим процессам системы (8).

Слайд 53
Описание слайда:
Граф состояний страниц (1)

Слайд 54
Описание слайда:
Граф состояний страниц (2)


Скачать презентацию на тему Общие принципы управления виртуальной памятью в Win32 можно ниже:

Похожие презентации