警告
UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、Windows 10 の新しいバージョンでは UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは、UMDF 2 を使用する必要があります。 詳細については、「UMDFの概要」を参照してください。
ドライバーの OnInterruptDisable イベント コールバック関数は、指定されたハードウェア割り込みを無効にします。
構文
WUDF_INTERRUPT_DISABLE WudfInterruptDisable;
HRESULT WudfInterruptDisable(
[in] IWDFInterrupt *Interrupt,
[in] IWDFDevice *AssociatedDevice
)
{...}
パラメーター
[in] Interrupt
IWDFInterrupt インターフェイスへのポインター。
[in] AssociatedDevice
ドライバーが CreateInterrupt の呼び出しに使用した IWDFDevice インターフェイスポインター。
戻り値
OnInterruptDisable 、操作が成功した場合はS_OKを返す必要があります。 それ以外の場合、コールバックは Winerror.h で定義されているエラー コードのいずれかを返す必要があります。
備考
OnInterruptDisable コールバック関数を登録するには、ドライバーは、IWDFDevice::CreateInterruptを呼び出す前に、コールバック関数のアドレスを WUDF_INTERRUPT_CONFIG 構造体に配置する必要があります。
フレームワークは、デバイスが動作 (D0) 状態を離れるたびに、ドライバーの OnInterruptDisable コールバック関数を呼び出します。 さらに、ドライバーは、IWDFInterrupt::D isable を呼び出すことによって、OnInterruptDisable コールバック関数呼び出すことができます。
OnInterruptDisable コールバック関数を呼び出す前に、フレームワークはドライバーの OnD0ExitPreInterruptsDisabled イベント コールバック関数を呼び出し、ユーザー モード割り込みロックを取得します。
UMDF ドライバーでの割り込みの処理の詳細については、「ハードウェアへのアクセスと割り込みの処理を参照してください。
例
関数型は、次のように、Wudfinterrupt.hで宣言されています。
typedef
__drv_functionClass(WUDF_INTERRUPT_DISABLE)
HRESULT
WUDF_INTERRUPT_DISABLE(
_In_
IWDFInterrupt* Interrupt,
_In_
IWDFDevice* AssociatedDevice
);
typedef WUDF_INTERRUPT_DISABLE *PFN_WUDF_INTERRUPT_DISABLE;
MyInterruptDisable という名前の OnInterruptDisable コールバック関数を定義するには、まず、SDV およびその他の検証ツールで必要な関数宣言を次のように指定する必要があります。
WUDF_INTERRUPT_DISABLE MyInterruptDisable;
次に、次のようにコールバック関数を実装します。
HRESULT
MyInterruptDisable (
IN IWDFInterrupt* pInterrupt,
IN IWDFDevice* pAssociatedDevice
)
{…}
必要条件
要件 | 価値 |
---|---|
サポート終了 | UMDF 2.0 以降では使用できません。 |
ターゲット プラットフォーム の | デスクトップ |
UMDF の最小バージョン を する | 1.11 |
ヘッダー | wudfinterrupt.h |