次の方法で共有


MRxQueryQuotaInfo ルーチン

MRxQueryQuotaInfo ルーチンは、ネットワーク ミニ リダイレクターがファイル システム オブジェクトにクォータ情報をクエリするように要求するために RDBSS によって呼び出されます。

構文

PMRX_CALLDOWN MRxQueryQuotaInfo;

NTSTATUS MRxQueryQuotaInfo(
  _Inout_ PRX_CONTEXT RxContext
)
{ ... }

パラメーター

RxContext [in, out]
RX_CONTEXT 構造体へのポインター。 このパラメーターには、操作を要求している IRP が含まれています。

戻り値

MRxQueryQuotaInfo は、成功した場合に STATUS_SUCCESS を返すか、次のような適切な NTSTATUS 値を返します。

リターン コード 説明
STATUS_ACCESS_DENIED

呼び出し元には、この操作に対する適切なセキュリティが不足しています。

STATUS_BUFFER_OVERFLOW

クォータ情報を受信するバッファーが小さすぎました。

この戻り値は成功と見なす必要があり、RxContext パラメーターが指す RX_CONTEXT 構造体の Info.Buffer メンバーにできるだけ有効なデータを返す必要があります。

STATUS_BUFFER_TOO_SMALL

バッファーが小さすぎて、要求されたデータを受信できません。

この値が返された場合、RxContext パラメーターによって指される RX_CONTEXT 構造体の InformationToReturn メンバーは、呼び出しが成功するために予想されるバッファーの最小サイズに設定する必要があります。

STATUS_CONNECTION_DISCONNECTED

接続が切断されました。 これはエラー コードです。

STATUS_INSUFFICIENT_RESOURCES

クエリを完了するためのリソースが不足していました。 これはエラー コードです。

STATUS_INVALID_PARAMETER

無効なパラメーターが指定されました。 これはエラー コードです。

STATUS_NOT_SUPPORTED

クォータはサポートされません。

解説

RDBSS は、IRP_MJ_QUERY_QUOTA 要求の受信に応答して MRxQueryQuotaInfo の呼び出しを発行します。

MRxQueryQuotaInfo を呼び出す前に、RDBSS は RxContext パラメーターが指す RX_CONTEXT 構造体の次のメンバーを変更します。

Info.Buffer メンバーは、I/O 要求パケットからユーザー バッファーに設定されます。 このバッファーは、必要に応じて RDBSS によって既にロックされています。

Info.LengthRemaining メンバーは IrpSp->Parameters.QueryQuota.Length に設定されます。

QueryQuota.SidList メンバーは IrpSp->Parameters.QueryQuota.SidList に設定されます。

QueryQuota.SidListLength メンバーは IrpSp->Parameters.QueryQuota.SidListLength に設定されます。

QueryQuota.StartSid メンバーは IrpSp->Parameters.QueryQuota.StartSid に設定されています。

QueryQuota.Length メンバーは IrpSp->Parameters.QueryQuota.Length に設定されます。

IrpSp->Flagsに SL_RESTART_SCAN ビットが設定されている場合、QueryQuota.RestartScan メンバーは 0 以外に設定されます。

IrpSp->Flags に SL_RETURN_SINGLE_ENTRY ビットが設定されている場合、QueryQuota.ReturnSingleEntry メンバーは 0 以外に設定されます。

IrpSp->Flags に SL_INDEX_SPECIFIED ビットが設定されている場合、QueryQuota.IndexSpecified メンバーは 0 以外に設定されます。

成功した場合、ネットワーク ミニ リダイレクターは、RX_CONTEXT 構造体の Info.LengthRemaining メンバーを、返すクォータ情報の長さに設定する必要があります。 MRxQueryQuotaInfo の呼び出しが成功した場合、RDBSS は IRP の IoStatus.Information メンバーを RX_CONTEXT の Info.LengthRemaining メンバーに設定します。

MRxQueryQuotaInfo の呼び出しが成功した場合、RX_CONTEXT 構造体の InformationToReturn メンバーは、返されるクォータ情報の長さに設定する必要があります。 呼び出しが失敗した場合は、 RX_CONTEXT の InformationToReturn メンバーを 0 に設定する必要があります。

要件

対象プラットフォーム

デスクトップ

ヘッダー

Mrx.h (Mrx.h を含む)

関連項目

MRxIsValidDirectory

MRxQueryDirectory

MRxQueryEaInfo

MRxQueryFileInfo

MRxQuerySdInfo

MRxQueryVolumeInfo

MRxSetEaInfo

MRxSetFileInfo

MRxSetFileInfoAtCleanup

MRxSetQuotaInfo

MRxSetSdInfo

MRxSetVolumeInfo