次の方法で共有


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 を呼び出す必要があります。 たとえば、ドライバーは IQueueCallbackRead::OnRead から IWDFInterrupt::TryToAcquireInterruptLock を呼び出します。 これにより、 IWDFInterrupt::AcquireInterruptLock の「解説」セクションで説明されているように、デッドロックの可能性を回避できます。

ドライバーは、ロックを再帰的に取得しようとしないでください。 デバッガーに接続されている場合、フレームワークはこのシナリオでブレークポイントを導入します。

手動割り込みロックの詳細については、「 割り込みコードの同期」を参照してください。

UMDF ドライバーでの割り込みの処理の詳細については、「 ハードウェアへのアクセス」および「割り込みの処理」を参照してください。

要件

要件
サポート終了 UMDF 2.0 以降では使用できません。
対象プラットフォーム デスクトップ
最小 UMDF バージョン 1.11
Header wudfddi.h
[DLL] WUDFx.dll

こちらもご覧ください

IWDFInterrupt

IWDFInterrupt::AcquireInterruptLock

WdfInterruptTryToAcquireLock