Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Функционирование менеджера памяти Лекция10.doc
Скачиваний:
0
Добавлен:
01.04.2025
Размер:
434.18 Кб
Скачать

Эксперимент. Наблюдение за ошибками страниц

Количество ошибок страниц, генерируемых процессом, можно наблюдать при помощи счетчика "Ошибок страницы". На рис. приведены графики поведения счетчиков "Ошибок страниц" и "Рабочее множество" для процесса DempPageFaults. (см. программу, описанную выше)

Рис. 10.6. Наблюдение за размером рабочего набора процесса и количеством страничных ошибок

Графики, приведенные на рис. 10.6, показывают, что увеличение рабочего набора коррелирует с интенсивностью процессов подкачки внешней памяти.

При помощи утилиты Pfmon.exe из ресурсов Windows можно не только "увидеть" общее количество страничных нарушений, но и определить виртуальные адреса, обращения к которым эти нарушения спровоцировали. На примере 10.1 приведен фрагмент результатов работы данной утилиты для процесса DemoPageFaults.

SOFT: RtlFillMemoryUlong+0x10 : 0x00232000

SOFT: RtlFillMemoryUlong+0x10 : 0x00233000

SOFT: GetConsoleInputWaitHandle+0x11a : GetConsoleInputWaitHandle+0x119

SOFT: FindFirstFileExA+0x285 : FindFirstFileExA+0x285

SOFT: main+0xe4 : 0x00440000

SOFT: main+0xe4 : 0x00441000

SOFT: main+0xe4 : 0x00442000

SOFT: main+0xe4 : 0x00443000

SOFT: main+0xe4 : 0x00444000

SOFT: main+0xe4 : 0x00445000

SOFT: main+0xe4 : 0x00446000

SOFT: main+0xe4 : 0x00447000

SOFT: main+0xe4 : 0x00448000

SOFT: main+0xe4 : 0x00449000

SOFT: main+0xe4 : 0x0044a000

SOFT: main+0xe4 : 0x0044b000

SOFT: main+0xe4 : 0x0044c000

SOFT: main+0xe4 : 0x0044d000

SOFT: main+0xe4 : 0x0044e000

SOFT: main+0xe4 : 0x0044f000

SOFT: main+0xe4 : 0x00450000

SOFT: main+0xe4 : 0x00451000

SOFT: main+0xe4 : 0x00452000

SOFT: main+0xe4 : 0x00453000

SOFT: main+0xe4 : 0x00454000

SOFT: main+0xe4 : 0x00455000

Пример 10.3. Часть результатов работы утилиты Pfmon.exe по отношению к процессу DemoPageFaults (html, txt)

Отдельные аспекты функционирования менеджера памяти

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

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

Локализация страниц в памяти

По умолчанию, процессу разрешается блокировать максимум 30 страниц памяти. Если увеличить рабочее множество процесса при помощи функции SetProcessWorkingSetSize, то, согласно документации, максимальное число страниц, которое процесс может блокировать, равно минимальному размеру его рабочего набора за вычетом 8 страниц.

Локализация страниц в памяти осуществляется при помощи Win32 функции VirtualLock, а освобождение страниц - при помощи VirtualUnlock. Учет локализованных страниц ведется в страничной базе PFN.

Прогон программы, демонстрирующей блокировку страниц в памяти

Приведенный листинг является примером такой программы.

#include <windows.h>

#include <stdio.h>

void main(void)

{

PVOID pMem = NULL;

int nPageSize = 4096;

int nPages = 400;

int nPageLock = 100;

long SizeCommit = 0;

int i;

char * Ptr;

int nMinPages = 200, nMaxPages = 500;

long dwMinimumWorkingSetSize = 0, dwMaximumWorkingSetSize = 0;

HANDLE hProcess;

hProcess = GetCurrentProcess();

dwMinimumWorkingSetSize = nMinPages * nPageSize;

dwMaximumWorkingSetSize = nMaxPages * nPageSize;

i = SetProcessWorkingSetSize(hProcess, dwMinimumWorkingSetSize, dwMaximumWorkingSetSize);

if(i==0) printf("SetProcessWorkingSetSize Error\n");

SizeCommit = nPages * nPageSize;

pMem = VirtualAlloc(0, SizeCommit, MEM_RESERVE| MEM_COMMIT, PAGE_READWRITE);

if(pMem == NULL) printf("VirtualAlloc Error\n");

Ptr = (char *)pMem;

for(i=0; i<nPages; i++) Ptr[i*nPageSize] = '0';

i = VirtualLock(pMem, nPageLock * nPageSize);

if(i==0) printf("VirtualLock Error\n");

for(i=0; i<nPages; i++) Ptr[i*nPageSize] = '0';

VirtualUnlock(pMem, nPageLock * nPageSize);

VirtualFree(pMem, 0, MEM_RELEASE);

}