NdisAcquireRWLockWrite 函数 (ndis.h)

NdisAcquireRWLockWrite 函数获取一个写入锁,调用方使用该锁对驱动程序线程之间共享的资源进行写入访问。

语法

void NdisAcquireRWLockWrite(
  [in]  PNDIS_RW_LOCK_EX Lock,
  [out] PLOCK_STATE_EX   LockState,
  [in]  UCHAR            Flags
);

参数

[in] Lock

指向表示锁的不透明 NDIS_RW_LOCK_EX 变量的指针。 调用方可以使用此锁来获取对非 ISR 驱动程序线程之间共享的资源的写入或读取访问权限。

[out] LockState

指向跟踪锁状态的不透明 LOCK_STATE_EX 变量的指针。 此变量存在于调用方获取和释放锁之间的时间间隔内。 调用方必须对从同一非 ISR 驱动程序线程获取锁的每次尝试使用 LOCK_STATE_EX 类型的不同变量。

[in] Flags

包含锁标志的 ULONG 值。 如果 调用方DISPATCH_LEVEL 当前 IRQL,请将此参数设置为 NDIS_RWL_AT_DISPATCH_LEVEL。 否则,请将此参数设置为零。 有关调度 IRQL 跟踪的详细信息,请参阅 调度 IRQL 跟踪

注意 如果调用方知道当前 IRQL 是 DISPATCH_LEVEL,请将此参数设置为 NDIS_RWL_AT_DISPATCH_LEVEL。 此标志使锁省略当前 IRQL 的检查,从而使锁更加高效。 如果当前 IRQL 未知,请勿仅为了确定是否设置此标志而使用 KeGetCurrentIrql 测试当前 IRQL,因为允许 NdisAcquireRWLockWrite 函数测试 IRQL 本身会更有效。
 

返回值

备注

NDIS 驱动程序调用 NdisAcquireRWLockWrite 函数来修改驱动程序线程之间共享的资源。

驱动程序必须使用 NdisAllocateRWLock 函数分配类型为 NDIS_RW_LOCK_EX 的变量,然后驱动程序才能调用 NdisAcquireRWLockWrite 函数。 驱动程序必须为它使用的锁的常驻存储提供 NdisAllocateRWLock 的句柄。

驱动程序调用 NdisAllocateRWLock 后,可以调用 NdisAcquireRWLockWriteNdisAcquireRWLockRead 以获取对资源的写入或读取访问权限。 一次只能有一个非 ISR 驱动程序线程获取对资源的写入访问权限。 当一个非 ISR 线程具有写入访问权限时,其他非 ISR 线程的所有读取和写入访问权限都必须等待,直到写入访问持有者释放锁。 但是,如果非 ISR 线程具有读取访问权限,则其他非 ISR 线程可以同时获取读取访问权限。

NDIS_RW_LOCK_EX锁不支持从读取到写入的升级。 处理器通过调用 NdisAcquireRWLockRead) 获取 (读取访问权限NDIS_RW_LOCK_EX后,在释放以前的读取访问权限之前,同一处理器不得尝试通过调用 NdisAcquireRWLockWrite) 来尝试获取写入访问权限 (。

可以在同一处理器上以递归方式获取 NDIS_RW_LOCK_EX 写锁。 对于对 NdisAcquireRWLockWrite 的每次调用,必须有对 NdisReleaseRWLock 的相应调用。 锁仅在上次调用 NdisReleaseRWLock 后释放。

驱动程序线程的写入锁不应超过几微秒。 长时间保留写入锁会降低操作系统和驱动程序的性能。

驱动程序不能使用锁来保护资源免受其其他函数与 MiniportInterrupt 共享的读取或写入访问权限或 MiniportDisableInterruptEx 函数或两者。 相反,驱动程序必须调用 NdisMSynchronizeWithInterruptEx ,使其 MiniportSynchronizeInterrupt 函数在其 MiniportInterrupt 或 相同的 DIRQL 上访问此类共享资源 MiniportDisableInterruptEx 函数或两者都有。

NdisAcquireRWLockWrite 通过获取旋转锁将 IRQL 提升为 DISPATCH_LEVEL

要求

要求
最低受支持的客户端 在 NDIS 6.20 及更高版本中受支持。
目标平台 通用
标头 ndis.h (包括 Ndis.h)
Library Ndis.lib
IRQL <= DISPATCH_LEVEL

另请参阅

LOCK_STATE_EX

MiniportDisableInterruptEx

MiniportInterrupt

MiniportSynchronizeInterrupt

NDIS_RW_LOCK_EX

NdisAcquireRWLockRead

NdisAllocateRWLock

NdisMSynchronizeWithInterruptEx

NdisReleaseRWLock