WUDF_INTERRUPT_DISABLE コールバック関数 (wudfinterrupt.h)

警告

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
Header wudfinterrupt.h

こちらもご覧ください