首页
社区
课程
招聘
[求助]关于内核层与用户层的共享内存问题
2023-6-11 16:48 4782

[求助]关于内核层与用户层的共享内存问题

2023-6-11 16:48
4782

我在用户层创建一个文件映像,名为DataMap,在内核中我需要填什么名字,才能使ZwOpenSection成功?

 

下面是尝试更改驱动中的usMappingName(都未成功):
1、L"DataMap"
2、L"\\BaseNamedObjects\\DataMap"

 

下面是发生错误的代码:

 

用户层

1
2
3
4
5
6
7
8
9
10
11
HANDLE hRecvMap = NULL;
 
LPVOID lpData = NULL;
 
hRecvMap = CreateFileMapping(INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, 1000, L"DataMap");
 
printf("%p\n", hRecvMap); // 打印模块地址的内容
 
lpData = (LPVOID)MapViewOfFile(hRecvMap, FILE_MAP_READ, 0, 0, 0);
 
printf("%p\n", lpData); // 打印模块地址的内容

内核层

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
    UNICODE_STRING usMappingName;
    RtlInitUnicodeString(&usMappingName, L"DataMap");
// 打开命名内存对象
 
OBJECT_ATTRIBUTES objectAttributes = { 0 };
InitializeObjectAttributes(&objectAttributes, &usMappingName, OBJ_CASE_INSENSITIVE, NULL, NULL);
HANDLE hMapping;
NTSTATUS status = ZwOpenSection(&hMapping, SECTION_MAP_READ | SECTION_MAP_WRITE, &objectAttributes);
if (!NT_SUCCESS(status))
{
    KdPrint(("Failed to open section. Status: 0x%X\n", status));
    return status;
}
 
// 映射内存对象
PVOID pMappedMemory;
SIZE_T viewSize = 0;
LARGE_INTEGER offset = { 0 };
 
status = ZwMapViewOfSection(hMapping, ZwCurrentProcess(), &pMappedMemory, 0, 0, &offset, &viewSize, ViewUnmap, 0, PAGE_READWRITE);
if (!NT_SUCCESS(status))
{
    KdPrint(("Failed to map view of section. Status: 0x%X\n", status));
    ZwClose(hMapping);
    return status;
}
 
// 在这里可以通过 pMappedMemory 操作内存对象
 
// 解除映射和关闭内存对象句柄
ZwUnmapViewOfSection(ZwCurrentProcess(), pMappedMemory);
ZwClose(hMapping);

[培训]二进制漏洞攻防(第3期);满10人开班;模糊测试与工具使用二次开发;网络协议漏洞挖掘;Linux内核漏洞挖掘与利用;AOSP漏洞挖掘与利用;代码审计。

最后于 2023-6-11 16:50 被黑嘿黑编辑 ,原因: 又有点小错误
收藏
点赞0
打赏
分享
最新回复 (0)
游客
登录 | 注册 方可回帖
返回