15#define IS_PAE() (g_IsPae)
17#define PTE_BASE 0xC0000000
19#define MiAddressToPteX86(x) \
20 ((PULONG)(((((ULONG)(x)) >> 12) << 2) + PTE_BASE))
21#define MiAddressToPtePAE(x) \
22 ((PULONGLONG)(((((ULONG)(x)) >> 12) << 3) + PTE_BASE))
24#define GET_PTE_VALUE_X86(Addr) (*MiAddressToPteX86(Addr))
25#define GET_PTE_VALUE_PAE(Addr) (*MiAddressToPtePAE(Addr))
26#define GET_PTE_VALUE(Addr) (IS_PAE() ? GET_PTE_VALUE_PAE(Addr) : GET_PTE_VALUE_X86(Addr))
28#define PTE_IS_VALID(PteValue) ((PteValue) & 1)
30#define PTE_GET_PFN_X86(PteValue) (((PteValue) >> PAGE_SHIFT) & 0x0fffffULL)
31#define PTE_GET_PFN_PAE(PteValue) (((PteValue) >> PAGE_SHIFT) & 0xffffffULL)
32#define PTE_GET_PFN(PteValue) (IS_PAE() ? PTE_GET_PFN_PAE(PteValue) : PTE_GET_PFN_X86(PteValue))
34#elif defined(_M_AMD64)
37#define PTE_BASE 0xFFFFF68000000000ULL
43 Offset &= 0xFFFFFFFFFULL << 3;
46#define MiAddressToPte(x) _MiAddressToPte((PVOID)(x))
48#define GET_PTE_VALUE(Addr) (*_MiAddressToPte((PVOID)(Addr)))
49#define PTE_IS_VALID(PteValue) ((PteValue) & 1)
50#define PTE_GET_PFN(PteValue) (((PteValue) >> PAGE_SHIFT) & 0xFffffffffULL)
59*pMmAllocatePagesForMdlEx)(
77#if defined(_M_IX86) || defined(_M_AMD64)
82 for (
i = 0;
i < ValidPtes;
i++)
85 PteValue = GET_PTE_VALUE(CurrentAddress);
87 ok(PTE_IS_VALID(PteValue),
88 "[%lu] PTE for %p is not valid (0x%I64x)\n",
89 i, CurrentAddress, PteValue);
92 ok(PTE_GET_PFN(PteValue) == Pfns[
i],
93 "[%lu] PTE for %p has PFN %Ix, expected %Ix\n",
94 i, CurrentAddress, PTE_GET_PFN(PteValue), Pfns[
i]);
96 for (;
i < TotalPtes;
i++)
99 PteValue = GET_PTE_VALUE(CurrentAddress);
102 "[%lu] PTE for %p is nonzero (0x%I64x)\n",
103 i, CurrentAddress, PteValue);
106 PteValue = GET_PTE_VALUE(CurrentAddress);
109 "PTE for %p contains 0x%I64x, expected %x\n",
110 CurrentAddress, PteValue,
PoolTag & ~1);
112 PteValue = GET_PTE_VALUE(CurrentAddress);
114 ok(PteValue == (TotalPtes + 2) * 2,
115 "PTE for %p contains 0x%I64x, expected %x\n",
116 CurrentAddress, PteValue, (TotalPtes + 2) * 2);
136 if (
skip(pMmAllocatePagesForMdlEx !=
NULL,
"MmAllocatePagesForMdlEx unavailable\n"))
142 MaxPhysical.
QuadPart = 0xffffffffffffffffLL;
145 Mdl = pMmAllocatePagesForMdlEx(ZeroPhysical,
168 "ValidateMapping returned");
179 "ValidateMapping returned");
193 "ValidateMapping returned");
204 "ValidateMapping returned");
210 Mdl = pMmAllocatePagesForMdlEx(ZeroPhysical,
233 "ValidateMapping returned");
235 for (
i = 0;
i < TotalPtes;
i++)
247 "ValidateMapping returned");
253 Mdl = pMmAllocatePagesForMdlEx(ZeroPhysical,
293 "ValidateMapping returned");
304 "ValidateMapping returned");
331 "ValidateMapping returned");
344 "ValidateMapping returned");
#define ok_eq_pointer(value, expected)
#define _IRQL_requires_max_(irql)
static PVOID Mapping[EMS_PHYSICAL_PAGES]
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
#define ok_bool_true(value, desc)
#define KmtEndSeh(ExpectedStatus)
PVOID KmtGetSystemRoutineAddress(IN PCWSTR RoutineName)
VOID NTAPI MmFreePagesFromMdl(IN PMDL Mdl)
VOID NTAPI MmUnmapReservedMapping(IN PVOID BaseAddress, IN ULONG PoolTag, IN PMDL MemoryDescriptorList)
PVOID NTAPI MmMapLockedPagesWithReservedMapping(IN PVOID MappingAddress, IN ULONG PoolTag, IN PMDL MemoryDescriptorList, IN MEMORY_CACHING_TYPE CacheType)
#define _Must_inspect_result_
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
__GNU_EXTENSION typedef unsigned __int64 * PULONGLONG
_In_ ULONG _In_ ULONG Offset
BOOLEAN NTAPI ExIsProcessorFeaturePresent(IN ULONG ProcessorFeature)
FORCEINLINE PMMPTE _MiAddressToPte(PVOID Address)
VOID NTAPI MmFreeMappingAddress(IN PVOID BaseAddress, IN ULONG PoolTag)
PVOID NTAPI MmAllocateMappingAddress(IN SIZE_T NumberOfBytes, IN ULONG PoolTag)
EH_STD::__hash_map__< TestClass, TestClass, ThrowHash, ThrowEqual, eh_allocator(TestClass) > TestMap
_In_ WDFDEVICE _In_ PVOID _In_opt_ PMDL Mdl
_Must_inspect_result_ _In_opt_ PWDF_OBJECT_ATTRIBUTES _In_ _Strict_type_match_ POOL_TYPE _In_opt_ ULONG PoolTag
_Must_inspect_result_ _In_ ULONG Flags
_Must_inspect_result_ _In_ PHYSICAL_ADDRESS HighAddress
_Must_inspect_result_ _In_ PHYSICAL_ADDRESS _In_ PHYSICAL_ADDRESS SkipBytes
_Must_inspect_result_ _In_ PHYSICAL_ADDRESS _In_ PHYSICAL_ADDRESS _In_opt_ PHYSICAL_ADDRESS _In_ MEMORY_CACHING_TYPE CacheType
_Must_inspect_result_ _In_ PHYSICAL_ADDRESS _In_ PHYSICAL_ADDRESS _In_ SIZE_T TotalBytes
enum _MEMORY_CACHING_TYPE MEMORY_CACHING_TYPE