MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE] 루틴
MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE] 루틴은 RDBSS에서 호출되어 네트워크 미니 리트리버가 파일 개체에 보관된 여러 잠금을 제거하도록 요청합니다.
구문
PMRX_CALLDOWN MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE];
NTSTATUS MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE](
_Inout_ PRX_CONTEXT RxContext
)
{ ... }
매개 변수
RxContext [in, out]
RX_CONTEXT 구조체에 대한 포인터입니다. 이 매개 변수에는 작업을 요청하는 IRP가 포함되어 있습니다.
반환 값
MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE] 는 성공 시 STATUS_SUCCESS 반환하거나 다음 중 하나와 같은 적절한 NTSTATUS 값을 반환합니다.
반환 코드 | 설명 |
---|---|
STATUS_CONNECTION_DISCONNECTED | 연결이 끊어졌습니다. |
STATUS_INSUFFICIENT_RESOURCES | 요청을 완료할 리소스가 부족했습니다. |
STATUS_INVALID_NETWORK_RESPONSE | 원격 서버에서 잘못된 응답을 받았습니다. |
STATUS_INVALID_PARAMETER | 잘못된 매개 변수가 RxContext에 지정되었습니다. |
STATUS_LINK_FAILED | 원격 서버에 다시 연결하여 요청을 완료하지 못했습니다. |
STATUS_NOT_IMPLEMENTED | 이 루틴은 구현되지 않습니다. |
STATUS_SHARING_VIOLATION | 공유 위반이 발생했습니다. |
STATUS_UNSUCCESSFUL | 호출이 실패했습니다. |
설명
RDBSS는 IRP_MN_UNLOCK_ALL 또는 IRP_MN_UNLOCK_ALL_BY_KEY 부 코드로 IRP_MJ_LOCK_CONTROL 요청을 수신하는 응답으로 MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE]를 호출합니다.
MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE]를 호출하기 전에 RDBSS는 RxContext 매개 변수가 가리키는 RX_CONTEXT 구조에서 다음 멤버를 수정합니다.
LowIoContext.Operation 멤버가 LOWIO_OP_UNLOCK_MULTIPLE 설정됩니다.
LowIoContext.ResourceThreadId 멤버는 RDBSS에서 작업을 시작한 프로세스의 스레드로 설정됩니다.
LowIoContext.ParamsFor.Locks.LockList 멤버는 LOWIO_LOCK_LIST 요소 목록으로 설정됩니다. 각 요소는 잠금 해제할 범위를 지정합니다.
잠금 해제할 바이트 범위는 RX_CONTEXT 구조체의 LowIoContext.ParamsFor.Locks.LockList 멤버에 지정됩니다. LOWIO_LOCK_LIST 구조는 다음과 같습니다.
typedef struct _LOWIO_LOCK_LIST {
struct _LOWIO_LOCK_LIST *Next;
ULONG LockNumber;
RXVBO ByteOffset;
LONGLONG Length;
ULONG Key;
BOOLEAN ExclusiveLock;
} LOWIO_LOCK_LIST, *PLOWIO_LOCK_LIST;
RX_CONTEXT LowIoContext.Operation 멤버는 수행할 낮은 I/O 작업을 지정합니다. LowIoContext.Operation 멤버를 사용하여 요청된 낮은 I/O 작업을 구분할 수 있으므로 여러 낮은 I/O 루틴이 네트워크 미니 리다이렉터에서 동일한 루틴을 가리킬 수 있습니다. 예를 들어 파일 잠금과 관련된 모든 I/O 호출은 네트워크 미니 리 디렉터에서 동일한 낮은 I/O 루틴을 호출할 수 있으며 이 루틴은 LowIoContext.Operation 멤버를 사용하여 요청된 잠금 및 잠금 해제 작업을 구분할 수 있습니다.
MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE] 루틴을 완료하는 데 시간이 오래 걸릴 수 있는 경우 네트워크 미니 리트리버 드라이버는 네트워크 통신을 시작하기 전에 FCB 구조를 해제해야 합니다. FCB 구조는 RxReleaseFcbResourceForThreadInMRx를 호출하여 해제할 수 있습니다. MRxLowIOSubmit[LOWIO_OP_UNLOCK_MULTIPLE] 루틴이 처리되는 동안 RX_CONTEXT LowIoContext.ResourceThreadId 멤버는 RDBSS에서 작업을 시작한 프로세스의 스레드를 나타내도록 보장됩니다.
RX_CONTEXT LowIoContext.ResourceThreadId 멤버를 사용하여 다른 스레드를 대신하여 FCB 구조를 해제할 수 있습니다. 비동기 루틴이 완료되면 초기 스레드에서 가져온 FCB 구조를 해제할 수 있습니다.
요구 사항
대상 플랫폼 |
데스크톱 |
헤더 |
Mrx.h(Mrx.h 포함) |
추가 정보
MRxLowIOSubmit[LOWIO_OP_EXCLUSIVELOCK]
MRxLowIOSubmit[LOWIO_OP_FSCTL]
MRxLowIOSubmit[LOWIO_OP_IOCTL]
MRxLowIOSubmit[LOWIO_OP_NOTIFY_CHANGE_DIRECTORY]
MRxLowIOSubmit[LOWIO_OP_SHAREDLOCK]
MRxLowIOSubmit[LOWIO_OP_UNLOCK]