次の方法で共有


WDF HID ミニドライバーの作成

このトピックでは、Windows Driver Frameworks (WDF) を使用してヒューマン インターフェイス デバイス (HID) ミニドライバーを作成する方法について説明します。

KMDF または UMDF を使用して HID ミニドライバーを作成できます。 vhidmini2 ミニドライバーのサンプルから始めることをお勧めします。 このサンプル ドライバーは、KMDF または UMDF 2.x を使用してコンパイルできます。

提供する内容

  1. MsHidUmdf.sys (UMDF の場合) または MsHidKmdf.sys (KMDF の場合) の下に下位フィルター ドライバーを記述します。これらはどちらもオペレーティング システムの一部として含まれます。

  2. vhidmini2 sample をダウンロードして確認します。

  3. ドライバーの EvtDriverDeviceAdd コールバック関数から WdfFdoInitSetFilter を呼び出します。

  4. MsHidUmdf.sys または MsHidKmdf.sysがクラス ドライバーからドライバーに渡す I/O 要求を受け取るための I/O キューを作成します。

  5. IOCTL 固有の メソッド ハンドラーに分岐する EvtIoDeviceControl コールバック関数を提供します。 WDF HID ミニドライバー IOCTL で 説明されている IOCTL を確認し、ドライバーがデバイスに関連するものを処理することを確認します。

  6. UMDF の場合、ドライバーが ACPI によって列挙されている場合は、必要に応じてセレクティブ サスペンドを有効にします。 デバイスのハードウェア キーで、EnableDefaultIdleNotificationHandler サブキーを追加し、1 に設定します。

  7. UMDF の場合は、INF ファイルの WDF 固有の DDInstall セクションで次の INF ディレクティブを設定します。

    • カーネルモード パススルー ドライバーをスタックに読み込むことができるようにするため UmdfKernelModeClientPolicyAllowKernelModeClients
    • UMDF が METHOD_NEITHER 型の IOCTL を処理できるように、UmdfMethodNeitherActionCopy
    • UmdfFileObjectPolicyAllowNullAndUnknownFileObjects
    • UmdfFsContextUsePolicyCanUseFsContext2

    次に例を示します。

    [hidumdf.NT.Wdf]
    UmdfKernelModeClientPolicy = AllowKernelModeClients
    UmdfMethodNeitherAction=Copy
    UmdfFileObjectPolicy=AllowNullAndUnknownFileObjects
    UmdfFsContextUsePolicy = CanUseFsContext2
    

Windows 7 用 UMDF HID ミニドライバーを作成している場合は、Windows Driver Kit (WDK) 8.1 をダウンロードして、HidUmdf.sys のソース コードを取得します。 次に、UMDF 1.11 ドライバーを記述し、HidUmdf.sys と UMDF 1.11 をドライバー パッケージに含めます。

Architecture

HID クラス ドライバー (HidClass.sys) とフレームワークは、ミニドライバーの一部の I/O 要求 (プラグ アンド プレイや電源管理要求など) を処理するための競合する WDM ディスパッチ ルーチンを提供します。 その結果、HID ミニドライバーは、クラス ドライバーとフレームワークの両方にはリンクできません。 そのため、Microsoft は、クラス ドライバーとミニドライバーの間に存在する WDM ドライバーである MsHidUmdf.sysMsHidKmdf.sys を提供します。

MsHidUmdf.sysMsHidKmdf.sys は両方、HID クラス ドライバーの HidRegisterMinidriver ルーチンを呼び出して、実際の HID ミニドライバーとして登録します。 これらのドライバーはデバイスのファンクション ドライバーとして機能しますが、クラス ドライバーからドライバーに I/O 要求を渡すだけです (そのためパススルー ドライバーと呼ばれることもあります)。 KMDF と UMDF の両方で、指定する唯一のコンポーネントは HID ミニドライバーです。これは、パススルー ドライバーの下にある下位フィルター ドライバーです。

UMDF アーキテクチャ: KMDF アーキテクチャ

Diagram showing the location of hidumdf.sys in the driver stack.

Diagram showing the location of mshidkmdf.sys in driver stack.