我很震惊,在我的应用程序通过 DeviceIoControl() Win32 API 向我的内核驱动程序 (WDM) 发出的 IOCTL 请求中,我在用户模式和内核模式之间获得了相同的 PID。
据我所知,驱动程序在内核模式下有自己的PID;应用程序在用户模式下拥有自己的PID,它们是分开的,可以通过IOCTL进行通信。但是今天,我在 IOCTL 请求中的用户/内核模式之间获得了相同的 PID。我GetCurrentProcessId()
在用户模式下通过函数获得了 PID;并在内核模式下通过PsGetCurrentProcessId()
函数获得PID,在用户模式应用程序中显示结果,这两个PID是相同的。
有谁知道为什么?