驱动完成例程中为何要调用IoMarkIrpPending?

FORCEINLINE VOID IoMarkIrpPending( __inout PIRP Irp)
{
    IoGetCurrentIrpStackLocation( (Irp) )->Control |= SL_PENDING_RETURNED;
}

IoMarkIrpPending也可以认为是IoMarkIrpPendingReturn,意思是把一个IRP标记为PENDING_RETURNED,
所以完成例程里的IoMarkIrpPending并非挂起IRP,而是想向上传递SL_PENGDING_RETURNED标记。

IRP完成的时候,需要在IRP原始发起线程里做一些事情,此时IO管理器会判断IRP->flag,和IrpSp->Control,如果此时Control有SL_PENDING_RETURNED,那么他会插入一个APC到发起线程里,如果没有这个标记,他就以为当前线程就是发起线程,就不插入APC了,所以你的完成例程必须要按规定传递PENDING_RETURNED标记,否则系统可能会误判的。

你可能感兴趣的:(windows,驱动开发)