 
        // wdm.h
PPFN_NUMBER MmGetMdlPfnArray(
  _In_ PMDL Mdl
);
View the official Windows Driver Kit DDI referenceNo description available.
The MmGetMdlPfnArray macro returns a pointer to the beginning of the array of physical page numbers that are associated with a memory descriptor list (MDL).
MdlA pointer to an MDL.
MmGetMdlPfnArray returns a pointer to the beginning of the array of physical page numbers that are associated with the MDL.
MmGetMdlPfnArray returns a pointer to the beginning of the array of physical page numbers that are associated with the MDL.
Macro definition:
#define MmGetMdlPfnArray(Mdl) ((PPFN_NUMBER)(Mdl + 1))
The number of entries in the array is ADDRESS_AND_SIZE_TO_SPAN_PAGES(MmGetMdlVirtualAddress(Mdl), MmGetMdlByteCount(Mdl)).
Each array element is an integer value of type PFN_NUMBER, which is defined in the Wdm.h header file as follows:
typedef ULONG PFN_NUMBER, *PPFN_NUMBER;
Changing the contents of the array can cause subtle system problems that are difficult to diagnose. We recommend that you do not read or change the contents of this array.
For pageable memory, the contents of the array are valid only for a buffer locked with MmProbeAndLockPages.
For nonpaged pool, the contents of the array are valid only for an MDL updated with MmBuildMdlForNonPagedPool, MmAllocatePagesForMdlEx, or MmAllocatePagesForMdl.
For more information about MDLs, see Using MDLs.
PPFN_NUMBER MmGetMdlPfnArray(
  _In_ PMDL Mdl
);