本地过程调用(Local Procedure Call, LPC)是为子系统通讯特别设计的。 LPC 的基础是
远程过程调用(Remote Procedure Call, RPC),RPC 是 Unix 上用于运行在两台机器上的
进程间通讯的事实上的标准。LPC 为在同一台机器上运行的进程间的通讯进行了优化。正如前面所讨论的,LPC 是子系统和其客户进程之间通讯的机制。客户
线程当需要子系统的服务时就会调用 LPC。LPC 将调用的
参数传递给服务器进程。服务器
线程执行服务并使用 LPC 将结果传回给客户端线程。
本地过程调用(LPC,Local Procedure Call,通常也被称为轻量过程调用或者本地
进程间通信) 是一种由
Windows NT内核提供的内部
进程间通信方式。通过这一方式,同一
计算机上的进程可以进行轻量的通信。在
Windows Vista中,ALPC(Advanced Local Procedure Call,高级本地进程通信)替代了LPC。ALPC提供了一个高速可度量的通信机制,这样便于实现需要在用户模式下高速通信的用户模式驱动程序框架(
UMDF,User-Mode Driver Framework)。
LPC由内核的“
端口”对象实现,这样可以确保安全(由
访问控制表规定持有特定的
安全标识符才可以访问)并可以验证链接另一端进程的身份。程序也可以对每一个信息设定安全标识符,并测试对应信息的变化,以实现每一条消息的安全性。
高级本地过程调用(ALPC)拥有比以往的本地过程调用(LPC)更优的性能。因为LPC只能通过同步请求/应答机制通信,而ALPC还可以使用
IOCP实现通信。这样,ALPC就可以在消息数量和进程数量间保持一定平衡,保证了端口的高速通信。此外,ALPC还允许信息的批量传输,减少了进程在用户模式和
内核模式之间的切换次数。
本地过程调用在Windows NT及其衍生系统中得到了广泛应用。在Win32子系统中,LPC应用于客户端和子系统服务器之间的通信(
CSRSS)。在Windows NT 3.51版本中引入了快速LPC以提高调用速度。然而由于NT4.0中将部分关键服务端移入内核模式(win32k.sys)以提高系统效能,这一方法已基本被摒弃。
本地安全认证子系统服务(LSASS),会话管理器(SMSS)以及
服务控制管理器均使用LPC端口和客户进程直接通信。
Winlogon和安全引用监视器与LSASS进程之间的通信同样使用了LPC。
正如前文提到的,当消息在同一计算机内传输时,Microsoft RPC将调用LPC进行通信。许多仅在同一计算机内进行通信的服务采用LPC作为唯一的通信方式。远程对象连接与嵌入和
分布式组件对象模型的实现也在很多地方使用了LPC作为本地通信的方式。