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


Функция MmAllocateContiguousMemorySpecifyCacheNode (ntddk.h)

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

Синтаксис

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

Параметры

[in] NumberOfBytes

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

[in] LowestAcceptableAddress

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

[in] HighestAcceptableAddress

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

[in, optional] BoundaryAddressMultiple

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

[in] CacheType

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

[in] PreferredNode

Номер предпочтительного узла. Если многопроцессорная система содержит N узлов, узлы нумеруются от 0 до N-1. Если указан MM_ANY_NODE_OK или компьютер имеет только один узел, выделение будет выполнено с любого узла. В противном случае выделение выполняется из предпочтительного узла или если на предпочтительном узле не удается найти удовлетворительный диапазон, возвращается значение NULL .

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

MmAllocateContiguousMemorySpecifyCacheNode возвращает базовый виртуальный адрес выделенной памяти. Если запрос не может быть выполнен, подпрограмма возвращает ЗНАЧЕНИЕ NULL.

Комментарии

Драйвер устройства в режиме ядра вызывает эту подпрограмму для выделения непрерывного блока физической памяти. В многопроцессорной системе с неоднородным доступом к памяти (NUMA) вызывающий объект может указать предпочтительный узел для выделения памяти. Узел — это коллекция процессоров, которые совместно используют быстрый доступ к области памяти. В многопроцессорной или однопроцессорной системе, отличной от NUMA, MmAllocateContiguousMemorySpecifyCacheNode рассматривает всю память как принадлежащая одному узлу и выделяет память из этого узла.

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

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

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

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

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

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

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

Требования

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

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

DriverEntry

MEMORY_CACHING_TYPE

MmFreeContiguousMemory