IQueueCallbackIoStop::OnIoStop メソッド (wudfddi.h)
[警告: UMDF 2 は UMDF の最新バージョンであり、UMDF 1 よりも優先されます。 すべての新しい UMDF ドライバーは、UMDF 2 を使用して記述する必要があります。 UMDF 1 には新機能が追加されておらず、新しいバージョンのWindows 10では UMDF 1 のサポートが制限されています。 ユニバーサル Windows ドライバーでは UMDF 2 を使用する必要があります。 詳細については、「UMDF を使用したはじめに」を参照してください。
OnIoStop コールバック関数は、指定したキューからの指定された I/O 要求の処理を停止します。
構文
void OnIoStop(
[in] IWDFIoQueue *pWdfQueue,
[in] IWDFIoRequest *pWdfRequest,
[in] ULONG ActionFlags
);
パラメーター
[in] pWdfQueue
I/O 要求の処理が停止される I/O キュー オブジェクトの IWDFIoQueue インターフェイスへのポインター。
[in] pWdfRequest
処理が停止されているフレームワーク要求オブジェクトを表す IWDFIoRequest インターフェイスへのポインター。
[in] ActionFlags
停止アクション要求の状態 を識別するWDF_REQUEST_STOP_ACTION_FLAGS型指定された値の有効なビットごとの OR。
戻り値
なし
解説
ドライバーは、IWDFDevice::CreateIoQueue メソッドを呼び出して I/O キューを作成するか、既定の I/O キューを構成するときに、IQueueCallbackIoStop インターフェイスを登録します。
ドライバーが I/O キューの OnIoStop コールバック関数を登録する場合、フレームワークは、キューの基になるデバイスが動作状態 (D0) を離れると、それを呼び出します。 フレームワークは、ドライバーが所有する要求や I/O ターゲットに転送した要求など、ドライバーが完了していないすべての I/O 要求に対して OnIoStop コールバック関数を呼び出します。
OnIoStop コールバック関数は、I/O 要求の処理を完了、キャンセル、または延期する必要があります。 次の規則を使用する必要があります。
ドライバーが I/O 要求を所有している場合、要求を完了または取り消すには IWDFIoRequest::Complete を呼び出す必要があります。要求の処理をさらに延期してから 、IWDFIoRequest2::StopAcknowledge を呼び出す必要があります。
ドライバーが I/O 要求を I/O ターゲットに転送した場合は、 IWDFIoRequest::CancelSentRequest を呼び出して要求を取り消そうとするか、要求の処理をさらに延期してから StopAcknowledge を呼び出す必要があります。
ActionFlags パラメーターで WdfRequestStopRequestCancelable フラグが設定されている場合、ドライバーは IWDFIoRequest::UnmarkCancelable を呼び出してから IWDFIoRequest::Complete を呼び出して要求を完了 (またはキャンセル) するか、IWDFIoRequest2::StopAcknowledge を呼び出して要求を再キューする必要があります。
要件
要件 | 値 |
---|---|
対象プラットフォーム | Windows |
ヘッダー | wudfddi.h (Wudfddi.h を含む) |