能力值:
( LV8,RANK:130 )
|
-
-
2 楼
在目标驱动上分配内存问题?这是什么鬼
|
能力值:
( LV2,RANK:10 )
|
-
-
3 楼
相当于 在win32k.sys调用ExAllocatePoolWithTag函数的效果,实际上并不是调用这个函数。
//这个函数可以在其它进程空间分配内存,想讨论下有没有什么内核函数或者方法可以在其它驱动空间里分配内存,希望渺茫。
LPVOID WINAPI VirtualAllocEx(
_In_ HANDLE hProcess,
_In_opt_ LPVOID lpAddress,
_In_ SIZE_T dwSize,
_In_ DWORD flAllocationType,
_In_ DWORD flProtect
);
|
能力值:
( LV2,RANK:10 )
|
-
-
4 楼
所有驱动模块用的一个页目录吧
|
能力值:
( LV2,RANK:10 )
|
-
-
5 楼
分析win32k.sys加载的时候系统是怎么分配内存的,在这个时候做处理
|
能力值:
( LV2,RANK:10 )
|
-
-
6 楼
另外,不管是什么模块,win32k.sys也好
调用ExAllocatePoolWithTag所分配的内存都是Pool,不属于任何模块地址空间
|
能力值:
( LV8,RANK:130 )
|
-
-
7 楼
在win32k.sys调用ExAllocatePoolWithTag函数这句话什么意思?想把分配的内存放在win32k加载的地址范围内?如果楼主是这个意思,那就是常识性的错误。。。
|
能力值:
( LV2,RANK:10 )
|
-
-
8 楼
我的意思是相当于win32k.sys自己调用ExAllocatePoolWithTag,然后我引用这个内存,往里面放些玩意。
实际上并不是调用这个函数。
|
能力值:
( LV2,RANK:10 )
|
-
-
9 楼
这问题可把大牛们弄糊涂了
|
能力值:
( LV2,RANK:10 )
|
-
-
10 楼
你应该先和大家讲明白,在您心中:
"win32k.sys自己调用ExAllocatePoolWithTag"
和
"非win32k.sys自己调用ExAllocatePoolWithTag"
的区别是什么!
|
能力值:
( LV2,RANK:10 )
|
-
-
11 楼
//这个函数可以在其它进程空间分配内存,想讨论下有没有什么内核函数或者方法可以在其它驱动里分配内存,希望渺茫。
LPVOID WINAPI VirtualAllocEx(
_In_ HANDLE hProcess,
_In_opt_ LPVOID lpAddress,
_In_ SIZE_T dwSize,
_In_ DWORD flAllocationType,
_In_ DWORD flProtect
);
|
能力值:
( LV2,RANK:10 )
|
-
-
12 楼
VirtualAllocEx是可以在其它进程空间分配内存
分配的内存块属于该进程空间,但是不属于该进程的任何模块地址空间
驱动里面分配的内存,不属于任何进程空间,也不属于任何模块地址空间
在win32k.sys模块地址范围内调用ExAllocatePoolWithTag
分配的内存也只是一个Pool,不属于任何进程空间,也不属于任何模块地址空间
|
能力值:
( LV2,RANK:10 )
|
-
-
13 楼
任何模块,无论是Ring3还是Ring0
在加载之后,模块Base和模块大小是固定的,模块的地址空间范围也就固定了
任何分配内存的方式,都不可能把某个模块地址空间的范围扩大或缩小
分配的内存只是某个地址范围块,这个地址范围块不可能分配在任何模块地址范围之内
|
能力值:
( LV2,RANK:10 )
|
-
-
14 楼
LZ的问题犯了很低级的错误
|
能力值:
( LV2,RANK:10 )
|
-
-
15 楼
嗯,看来是找不到了,本来是想在看雪上找下办法的。
|
能力值:
( LV2,RANK:10 )
|
-
-
16 楼
或许是我表达不对,我是想在目标驱动上分配它自己的内存,然后往里面写一些东西,看有没有办法。
与访问SSSDT,写SSSDT全局变量类似。怎么就不能理解我的话呢?我举的那个例子只是说明我的大概意思。
内核空间不同于进程空间。
不好意思,令大家误解,打搅大家了。
|
能力值:
( LV2,RANK:10 )
|
-
-
17 楼
MiCopyPage
|
能力值:
( LV7,RANK:110 )
|
-
-
18 楼
你的意思是,要自己在驱动中实现VirtualAllocEx,然后通过VirtualAllocEx在别的进程申请内存?还是当别的驱动申请内存时替换掉申请的内存?
|
能力值:
( LV7,RANK:110 )
|
-
-
19 楼
你还是表达不对,没有目标驱动这个概念!在驱动程序中,所有驱动均为一个整体,只要调用内存申请函数,都会被视为在所有驱动中申请了一个公共的内存!
|
能力值:
( LV2,RANK:10 )
|
-
-
20 楼
还是那句话,楼主
|
能力值:
( LV2,RANK:10 )
|
-
-
21 楼
楼主你把大牛们都弄糊涂了
|
|
|