Поделиться через


Функция MmAllocateContiguousMemorySpecifyCache (wdm.h)

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

Синтаксис

PVOID MmAllocateContiguousMemorySpecifyCache(
  [in]           SIZE_T              NumberOfBytes,
  [in]           PHYSICAL_ADDRESS    LowestAcceptableAddress,
  [in]           PHYSICAL_ADDRESS    HighestAcceptableAddress,
  [in, optional] PHYSICAL_ADDRESS    BoundaryAddressMultiple,
  [in]           MEMORY_CACHING_TYPE CacheType
);

Параметры

[in] NumberOfBytes

Размер выделенного блока непрерывной памяти в байтах. Дополнительные сведения см. в подразделе "Примечания".

[in] LowestAcceptableAddress

Наименьший допустимый физический адрес, который может использовать вызывающий объект. Например, если устройство может обращаться только к расположениям, превышающим первые 8 мб диапазона адресов физической памяти процессора, драйвер для этого устройства должен задать для параметра LowestAcceptableAddress значение 0x0000000000800000.

[in] HighestAcceptableAddress

Максимальный допустимый физический адрес, который может использовать вызывающий объект. Например, если устройство может обращаться только к расположениям в первых 16 мегабайтах диапазона адресов физической памяти процессора, драйвер для этого устройства должен задать для параметра HighestAcceptableAddress значение 0x0000000000FFFFFF.

[in, optional] BoundaryAddressMultiple

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

[in] CacheType

Задает значение MEMORY_CACHING_TYPE , указывающее тип кэширования, разрешенного для запрошенной памяти.

Возвращаемое значение

MmAllocateContiguousMemorySpecifyCache возвращает базовый виртуальный адрес выделенной памяти. Если системе не удается выделить запрошенный буфер, подпрограмма возвращает значение NULL.

Комментарии

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

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

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

Память, выделенная MmAllocateContiguousMemorySpecifyCache , должна быть освобождена, если память больше не нужна. Вызовите подпрограмму MmFreeContiguousMemory , чтобы освободить память, выделенную MmAllocateContiguousMemorySpecifyCache.

Если указать ненулевое значение для параметра BoundaryAddressMultiple , физический диапазон адресов выделенного блока памяти не будет пересекать границу адреса, которая является целым числом, кратным этому значению. Драйвер должен задать для этого параметра нулевое значение, если для обхода аппаратного ограничения не требуется ненулевое значение. Например, если устройство не может передавать данные через физические границы 16 МЕГАБАЙТ, драйвер должен указать значение 0x1000000 для этого параметра, чтобы гарантировать, что адреса, видимые устройством, не будут обтекаться вокруг границы в 16 МЕГАБАЙТ.

Если вы используете подпрограмму MmAllocateContiguousMemorySpecifyCache на компьютерах с большим объемом памяти, производительность операционной системы может значительно снизиться, когда система попытается создать непрерывный блок памяти. Начиная с Windows Vista с пакетом обновления 1 (SP1) и Windows Server 2008, это значительно снижается, но выделение непрерывной памяти по-прежнему может быть дорогостоящим. По этой причине драйверы должны избегать повторяющихся вызовов MmAllocateContiguousMemorySpecifyCache. Вместо этого драйверы должны выделять все необходимые смежные буферы в подпрограммах DriverEntry и повторно использовать эти буферы.

Память, выделенная MmAllocateContiguousMemorySpecifyCache , не инициализирована. Драйвер режима ядра должен сначала обнулить эту память, если он собирается сделать ее видимой для программного обеспечения в пользовательском режиме (чтобы избежать утечки потенциально привилегированного содержимого).

Требования

Требование Значение
Целевая платформа Универсальное
Верхняя часть wdm.h (включая Wdm.h, Ntddk.h)
Библиотека NtosKrnl.lib
DLL NtosKrnl.exe
IRQL <= DISPATCH_LEVEL

См. также раздел

MmAllocateContiguousMemory

MmFreeContiguousMemory