共用方式為


MRxLowIOSubmit[LOWIO_OP_IOCTL] 例程

RDBSS 會呼叫 MRxLowIOSubmit[LOWIO_OP_IOCTL] 例程,對網路迷你重新導向器發出 I/O 系統控制要求。

語法

PMRX_CALLDOWN MRxLowIOSubmit[LOWIO_OP_IOCTL];

NTSTATUS MRxLowIOSubmit[LOWIO_OP_IOCTL](
  _Inout_ PRX_CONTEXT RxContext
)
{ ... }

參數

RxContext [in, out]
RX_CONTEXT 結構的指標。 此參數包含要求作業的 IRP。

傳回值

MRxLowIOSubmit[LOWIO_OP_IOCTL] 會在成功或適當的 NTSTATUS 值時傳回STATUS_SUCCESS,例如下列其中一項:

傳回碼 Description
STATUS_INSUFFICIENT_RESOURCES

資源不足,無法完成要求。

STATUS_INVALID_DEVICE_REQUEST

指定了無效的裝置要求。

STATUS_INVALID_PARAMETER

在 RxContext 中指定了無效的參數。

STATUS_NOT_IMPLEMENTED

未實作此例程。

STATUS_NOT_SUPPORTED

網路迷你重新導向器不支援指定的 IOCTL。

備註

RDBSS 會呼叫 MRxLowIOSubmit[LOWIO_OP_IOCTL] 以回應接收 IRP_MJ_DEVICE_CONTROLIRP_MJ_INTERNAL_DEVICE_CONTROL 要求。

在呼叫 MRxLowIOSubmit[LOWIO_OP_IOCTL]之前,RDBSS 會修改 RxContext 參數所指向RX_CONTEXT結構中的下列成員:

LowIoContext.Operation 成員會設定為 LOWIO_OP_IOCTL。

LowIoContext.ResourceThreadId 成員會設定為在 RDBSS 中起始作業的進程線程。

LowIoContext.ParamsFor.IoCtl.IoControlCode 成員會設定為 IOCTL 控件程式代碼。

LowIoContext.ParamsFor.IoCtl.pInputBuffer 成員會設定為輸入緩衝區。

LowIoContext.ParamsFor.IoCtl.InputBufferLength 成員會設定為輸入緩衝區長度。

LowIoContext.ParamsFor.IoCtl.pOutputBuffer 成員會設定為輸出緩衝區。

LowIoContext.ParamsFor.IoCtl.OutputBufferLength 成員會設定為輸出緩衝區長度。

MRxLowIOSubmit[LOWIO_OP_IOCTL] 例程正在處理時,RX_CONTEXT 的 LowIoContext.ResourceThreadId 成員保證會指出在 RDBSS 中起始作業的進程線程。 RX_CONTEXT的 LowIoContext.ResourceThreadId 成員可用來代表另一個線程釋放輸入資源。 異步例程完成時,可以釋放從初始線程取得的輸入資源。

規格需求

目標平台

桌面

標頭

Mrx.h (包含 Mrx.h)

另請參閱

MRxLowIOSubmit[LOWIO_OP_EXCLUSIVELOCK]

MRxLowIOSubmit[LOWIO_OP_FSCTL]

MRxLowIOSubmit[LOWIO_OP_NOTIFY_CHANGE_DIRECTORY]

MRxLowIOSubmit[LOWIO_OP_READ]

MRxLowIOSubmit[LOWIO_OP_SHAREDLOCK]

MRxLowIOSubmit[LOWIO_OP_UNLOCK]

MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE]

MRxLowIOSubmit[LOWIO_OP_WRITE]