sys: IRP_MJ_CREATE

This commit is contained in:
Bill Zissimopoulos
2015-12-03 18:40:02 -08:00
parent ca8a02bd9d
commit eb07db1d29
3 changed files with 25 additions and 21 deletions

View File

@ -60,6 +60,7 @@ static NTSTATUS FspFsvolCreate(
KPROCESSOR_MODE RequestorMode = FlagOn(Flags, SL_FORCE_ACCESS_CHECK) ? UserMode : Irp->RequestorMode;
PACCESS_STATE AccessState = IrpSp->Parameters.Create.SecurityContext->AccessState;
ACCESS_MASK DesiredAccess = IrpSp->Parameters.Create.SecurityContext->DesiredAccess;
//PSECURITY_DESCRIPTOR SecurityDescriptor = AccessState->SecurityDescriptor;
USHORT ShareAccess = IrpSp->Parameters.Create.ShareAccess;
ULONG CreateDisposition = (IrpSp->Parameters.Create.Options >> 24) & 0xff;
ULONG CreateOptions = IrpSp->Parameters.Create.Options & 0xffffff;
@ -178,18 +179,18 @@ static NTSTATUS FspFsvolCreate(
Request->Req.Create.CreateDisposition = CreateDisposition;
Request->Req.Create.CreateOptions = CreateOptions;
Request->Req.Create.FileAttributes = FileAttributes;
Request->Req.Create.AllocationSize = AllocationSize.QuadPart;
Request->Req.Create.SecurityDescriptor = 0;
Request->Req.Create.EaBuffer = 0;
Request->Req.Create.EaLength = 0;
Request->Req.Create.SecurityDescriptorSize = 0;
Request->Req.Create.AllocationSize = AllocationSize.QuadPart;
Request->Req.Create.AccessToken = 0;
Request->Req.Create.DesiredAccess = DesiredAccess;
Request->Req.Create.ShareAccess = ShareAccess;
Request->Req.Create.DesiredAccess = DesiredAccess;
Request->Req.Create.Ea = 0;
Request->Req.Create.EaSize = 0;
Request->Req.Create.UserMode = UserMode == RequestorMode;
Request->Req.Create.HasTraversePrivilege = HasTraversePrivilege;
Request->Req.Create.CaseSensitive = BooleanFlagOn(Flags, SL_CASE_SENSITIVE);
Request->Req.Create.OpenTargetDirectory = BooleanFlagOn(Flags, SL_OPEN_TARGET_DIRECTORY);
Request->Req.Create.CaseSensitive = BooleanFlagOn(Flags, SL_CASE_SENSITIVE);
/*
* Post the IRP to our Ioq; we do this here instead of at FSP_LEAVE_MJ time,

View File

@ -25,18 +25,22 @@ NTSTATUS FspIopCreateRequest(
if (0 != FileName)
ExtraSize += FileName->Length + sizeof(WCHAR);
if (FSP_FSCTL_TRANSACT_REQ_SIZEMAX < sizeof *Request + ExtraSize)
return STATUS_INVALID_PARAMETER;
FSP_FSCTL_TRANSACT_REQ *Request = ExAllocatePoolWithTag(PagedPool,
sizeof *Request + ExtraSize, FSP_TAG);
if (0 == Request)
return STATUS_INSUFFICIENT_RESOURCES;
RtlZeroMemory(Request, sizeof *Request + ExtraSize);
RtlZeroMemory(Request, sizeof *Request);
Request->Size = (UINT16)(sizeof *Request + ExtraSize);
Request->Hint = (UINT_PTR)Irp;
if (0 != FileName)
{
RtlCopyMemory(Request->FileName, FileName->Buffer, FileName->Length);
Request->FileName[FileName->Length / 2] = L'\0';
RtlCopyMemory(Request->Buffer, FileName->Buffer, FileName->Length);
Request->Buffer[FileName->Length] = '\0';
Request->Buffer[FileName->Length + 1] = '\0';
}
Irp->Tail.Overlay.DriverContext[0] = Request;