IWDFDevice::CreateDeviceInterface メソッド (wudfddi.h)

[警告: UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、新しいバージョンのWindows 10では UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは、UMDF 2 を使用する必要があります。 詳細については、「UMDF を使用したはじめに」を参照してください。

CreateDeviceInterface メソッドは、デバイス インターフェイス クラスのインスタンスを作成します。

構文

HRESULT CreateDeviceInterface(
  [in]           LPCGUID pDeviceInterfaceGuid,
  [in, optional] PCWSTR  pReferenceString
);

パラメーター

[in] pDeviceInterfaceGuid

デバイス インターフェイス クラスの GUID へのポインター。

[in, optional] pReferenceString

デバイス インターフェイスのインスタンスの名前を含む NULL で終わる文字列へのポインター。 このパラメーターは省略可能です。 ドライバーが名前を指定する必要がない場合、ドライバーは NULL を 渡すことができます。 ドライバーが名前を指定する必要がある場合、ドライバーが渡す文字列にパス区切り文字 ("/" または "\") を含めてはなりません。

戻り値

CreateDeviceInterface は、操作が成功した場合S_OKを返します。 それ以外の場合、このメソッドは Winerror.h で定義されているエラー コードのいずれかを返します。

注釈

ドライバーは 、pReferenceString パラメーターを使用して、1 つのインターフェイスのさまざまなインスタンスを区別できます。 つまり、ドライバーが同じデバイス インターフェイス クラスに対して CreateDeviceInterface を 2 回呼び出す場合、ドライバーは 毎回 pReferenceString に異なる文字列を指定できます。 インターフェイスのインスタンスを開くと、フレームワークはインスタンスの参照文字列をドライバーに渡します。 参照文字列は、インターフェイス インスタンスの名前のパス コンポーネントに追加されます。 ドライバーは、参照文字列を使用して、開いているデバイス インターフェイス クラスのインスタンスを決定できます。

CreateDeviceInterface が成功した場合、インターフェイスの初期状態は無効になります。 作成が成功した場合、フレームワークはデバイスの PnP 状態に基づいてインターフェイスを自動的に有効および無効にします。 さらに、ドライバーは、 IWDFDevice::AssignDeviceInterfaceState を呼び出すことによって、必要に応じてデバイス インターフェイスを無効にして再度有効にすることができます。

デバイス インターフェイスの詳細については、「 UMDF ベースのドライバーでのデバイス インターフェイスの使用」を参照してください。

次のコード例は、デバイス インターフェイス インスタンスを作成する方法を示しています。 この例では、ドライバーは IWDFDevice::AssignDeviceInterfaceState を明示的に呼び出してインターフェイスを有効にします。

    //
    // Create the device interface.
    //
    HRESULT hr;
    if (S_OK == hr) {
        hr = m_FxDevice->CreateDeviceInterface(
                         &GUID_DEVINTERFACE_OSRUSBFX2,
                         NULL);
    }
    if (S_OK == hr) {
        hr = m_FxDevice->AssignDeviceInterfaceState(
                        &GUID_DEVINTERFACE_OSRUSBFX2,
                        NULL,
                        TRUE);
    }

要件

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

こちらもご覧ください

IWDFDevice

IWDFDevice::AssignDeviceInterfaceState