IWDFInterrupt::TryToAcquireInterruptLock メソッド (wudfddi.h)
[警告: UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、Windows 10 の新しいバージョンでは UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは、UMDF 2 を使用する必要があります。 詳細については、「UMDFの概要」を参照してください。
TryToAcquireInterruptLock メソッドは、他のスレッドが割り込みロックを取得していない場合に割り込みロックを取得します。
構文
BOOLEAN TryToAcquireInterruptLock();
戻り値
割り込みロックが正常に取得された場合、このメソッドは TRUE を返します。 それ以外の場合、メソッドは FALSE を返します。
備考
IWDFInterrupt::AcquireInterruptLockとは異なり、IWDFInterrupt::TryToAcquireInterruptLock は、割り込みロックが保持されている場合に割り込みロックが使用可能になるまで待機しません。
I/O キュー コールバック メソッドなどの任意のスレッドで実行する場合、ドライバーは IWDFInterrupt::AcquireInterruptLock ではなく、IWDFInterrupt::TryToAcquireInterruptLock 呼び出す必要があります。 たとえば、ドライバーは IWDFInterrupt::TryToAcquireInterruptLock IQueueCallbackRead::OnReadから 呼び出します。 これにより、IWDFInterrupt::AcquireInterruptLock の「解説」セクションで説明されているように、デッドロックの可能性を回避できます。
ドライバーは、ロックを再帰的に取得しようとしないでください。 デバッガーに接続されている場合、フレームワークはこのシナリオでブレークポイントを導入します。
手動割り込みロックの詳細については、「割り込みコードの同期」を参照してください。
UMDF ドライバーでの割り込みの処理の詳細については、「ハードウェアへのアクセスと割り込みの処理を参照してください。
必要条件
要件 | 価値 |
---|---|
サポート終了 | UMDF 2.0 以降では使用できません。 |
ターゲット プラットフォーム の | デスクトップ |
UMDF の最小バージョン を する | 1.11 |
ヘッダー | wudfddi.h |
DLL | WUDFx.dll |