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 で定義されているエラー コードの 1 つを返します。
備考
ドライバーは、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 |
ヘッダー | wudfddi.h (Wudfddi.h を含む) |
DLL | WUDFx.dll |
関連項目
IWDFDevice の