2011-04-26 413 views

回答

5

看一看这里:

http://channel9.msdn.com/Shows/Going+Deep/Arun-Kishan-Process-Management-in-Windows-Vista

EPROCESS是内核模式相当于PEB从用户模式。有关更多详细信息,请参阅Alex Ionescu网站上的this document以及the book by Schreiber和其他关于NT内部的书籍。

在WinDbg中使用dt来了解它们的外观。

+0

非常感谢你 – 2011-04-27 01:57:07

+0

@Eknath艾尔:不客气。看看你对Jason的回答的评论。即使你不能接受两个答案,你仍然可以上调他的答案。 – 0xC0000022L 2011-04-27 19:55:04

1

EPROCESS在用户模式下不可用。 KPROCESS也不是。

KPROCESS是EPROCESS的一个子集。如果您查看调试器中的字段,您会看到KPROCESS包含的字段与进程的调度和簿记更密切相关,而EPROCESS在其中包含更高级别的进程上下文。名称,据我所知,来自与这些结构(执行具有结构和功能往往与防爆前缀,而内核结构和功能经常与柯前缀)

你可以看到这个交互不同的子系统在不同的文件功能。考虑KeStackAttachProcess的原型(http://msdn.microsoft.com/en-us/library/ff549659(v=vs.85).aspx),它是一个Ke函数并且需要一个KPROCESS。没有任何接受EPROCESS(或KPROCESS)的导出和记录的Ex函数,但是Ps函数完全在EPROCESSES中处理。

线程与KTHREAD和ETHREAD存在类似的鸿沟。

8

这是简化的,但Windows O/S的内核模式部分分为三部分:HAL,内核和执行子系统。执行子系统处理一般的操作系统策略和操作。内核处理低级操作(例如自旋锁,线程切换)以及调度的进程体系结构特定细节。 HAL处理在处理器体系结构的特定实现中出现的差异(例如,中断在这个x86实现上的路由方式)。这在Windows内部的书中有更详细的解释。

当您创建新的Win32进程时,内核和执行子系统都要跟踪它。例如,内核想知道进程中线程的优先级和亲和性,因为这将影响调度。执行子系统希望跟踪该过程,因为例如安全执行子系统想要将令牌与过程相关联,以便稍后进行安全检查。

内核用来跟踪进程的结构是KPROCESS。执行子系统用来跟踪它的结构是EPROCESS。作为一个实现细节,KPROCESS是EPROCESS的第一个字段,所以执行子系统分配EPROCESS结构,然后调用Kernel来初始化它的KPROCESS部分。最后,这两个结构都是表示用户进程实例的Process Object的一部分。这也应该都包含在Windows内部的书中。

-scott

相关问题