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