如何取消 oid 请求。谁能告诉我详细的流程?假设 NDIS 向微型端口驱动程序发送任何请求。驱动程序如何取消请求并将其发送到微型端口驱动程序。
1 回答
这里有一些关于 OID 处理的信息。每个 OID 在 中都有一个取消 ID NDIS_OID_REQEST::RequestId
。如果 NDIS 想要取消 OID 请求,NDIS 将调用您的微型端口的MiniportCancelOidRequest
处理程序,并传递一个RequestId
. 您的微型端口应将 与RequestId
当前 OID 请求的请求 ID 进行比较。如果RequestId
匹配,您的微型端口应该加快 OID 请求的完成,因为更高层不再需要该操作来完成。
但是,您的微型端口驱动程序没有义务取消任何请求,特别是,您不应该浪费时间尝试“撤消”请求。NDIS 知道取消可能“为时已晚”,如果需要,NDIS 准备发布额外的 OID 以正确回滚操作。
因此,对于微型端口,这些都是处理取消请求的有效方法:
- 忽略取消,并继续处理请求。
NDIS_STATUS_SUCCESS
使用(或失败代码,如果操作失败)完成请求。 - 尝试取消操作(例如,通过调用
IoCancelIrp
或类似方式)。- 如果操作实际上被取消(例如,您的 IRP 的完成处理程序得到了
STATUS_CANCELLED
),则返回NDIS_STATUS_REQUEST_ABORTED
。 - 如果操作仍然成功(例如,您的 IRP 的完成处理程序得到了
STATUS_SUCCESS
),则 returnNDIS_STATUS_SUCCESS
,即使您试图取消。
- 如果操作实际上被取消(例如,您的 IRP 的完成处理程序得到了
对于“微不足道”的 OID,不必费心实施取消。例如,如果您OID_GEN_STATISTICS
只需将数据复制到 OID 的缓冲区即可满足,而无需使用硬件,那么请不要费心尝试为该 OID 实现取消。取消只会增加一堆开销而没有真正有用。
URB
当 OID 请求导致对硬件的阻塞调用(例如,向USB 小工具发送向下消息)时,取消更有用。
确保,如果 OID 需要多次调用,并且您在第一次调用后取消,则将硬件恢复到已知状态。例如,如果处理OID_PNP_SET_POWER
要求您对硬件进行 10 次调用,并且您决定为此 OID 实施取消,那么如果在第 3 次硬件调用后取消 OID,您应该安全地将硬件恢复到之前的电源状态。