亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fsctrl.c

?? Windows內核級文件系統訪問操作驅動程序
?? C
字號:
/*++

Copyright (c) Microsoft Corporation. All rights reserved. 

You may only use this code if you agree to the terms of the Windows Research Kernel Source Code License agreement (see License.txt).
If you do not agree to the terms, do not use the code.


Module Name:

    FsCtrl.c

Abstract:

    This module implements the File System Control routines for Raw called
    by the dispatch driver.

--*/

#include "RawProcs.h"

//
//  Local procedure prototypes
//

NTSTATUS
RawMountVolume (
    IN PIO_STACK_LOCATION IrpSp
    );

NTSTATUS
RawVerifyVolume (
    IN PIO_STACK_LOCATION IrpSp,
    IN PVCB Vcb
    );

NTSTATUS
RawUserFsCtrl (
    IN PIO_STACK_LOCATION IrpSp,
    IN PVCB Vcb
    );

#ifdef ALLOC_PRAGMA
#pragma alloc_text(PAGE, RawMountVolume)
#pragma alloc_text(PAGE, RawUserFsCtrl)
#pragma alloc_text(PAGE, RawFileSystemControl)
#endif


NTSTATUS
RawFileSystemControl (
    IN PVCB Vcb,
    IN PIRP Irp,
    IN PIO_STACK_LOCATION IrpSp
    )

/*++

Routine Description:

    This routine implements the FileSystem control operations

Arguments:

    Vcb - Supplies the volume being queried.

    Irp - Supplies the Irp being processed.

    IrpSp - Supplies parameters describing the FileSystem control operation.

Return Value:

    NTSTATUS - The status for the IRP

--*/

{
    NTSTATUS Status;

    PAGED_CODE();

    //
    //  We know this is a file system control so we'll case on the
    //  minor function, and call an internal worker routine.
    //

    switch (IrpSp->MinorFunction) {

    case IRP_MN_USER_FS_REQUEST:

        Status = RawUserFsCtrl( IrpSp, Vcb );
        break;

    case IRP_MN_MOUNT_VOLUME:

        Status = RawMountVolume( IrpSp );
        break;

    case IRP_MN_VERIFY_VOLUME:

        Status = RawVerifyVolume( IrpSp, Vcb );
        break;

    default:

        Status = STATUS_INVALID_DEVICE_REQUEST;
        break;
    }

    RawCompleteRequest( Irp, Status );

    return Status;
}


//
//  Local Support Routine
//

NTSTATUS
RawMountVolume (
    IN PIO_STACK_LOCATION IrpSp
    )

/*++

Routine Description:

    This routine performs the mount volume operation.

Arguments:

    IrpSp - Supplies the IrpSp parameters to process

Return Value:

    NTSTATUS - The return status for the operation

--*/

{
    NTSTATUS Status;
    PDEVICE_OBJECT DeviceObjectWeTalkTo;

    PVOLUME_DEVICE_OBJECT VolumeDeviceObject;

    PAGED_CODE();

    //
    //  Save some references to make our life a little easier
    //

    DeviceObjectWeTalkTo = IrpSp->Parameters.MountVolume.DeviceObject;

    //
    // A mount operation has been requested.  Create a
    // new device object to represent this volume.
    //

    Status = IoCreateDevice( IrpSp->DeviceObject->DriverObject,
                             sizeof(VOLUME_DEVICE_OBJECT) - sizeof(DEVICE_OBJECT),
                             NULL,
                             FILE_DEVICE_DISK_FILE_SYSTEM,
                             0,
                             FALSE,
                             (PDEVICE_OBJECT *)&VolumeDeviceObject );

    if ( !NT_SUCCESS( Status ) ) {

        return Status;
    }

    //
    //  Our alignment requirement is the larger of the processor alignment requirement
    //  already in the volume device object and that in the DeviceObjectWeTalkTo
    //

    if (DeviceObjectWeTalkTo->AlignmentRequirement > VolumeDeviceObject->DeviceObject.AlignmentRequirement) {

        VolumeDeviceObject->DeviceObject.AlignmentRequirement = DeviceObjectWeTalkTo->AlignmentRequirement;
    }

    //
    // Set sector size to the same value as the DeviceObjectWeTalkTo.
    //

    VolumeDeviceObject->DeviceObject.SectorSize = DeviceObjectWeTalkTo->SectorSize;

    VolumeDeviceObject->DeviceObject.Flags |= DO_DIRECT_IO;

    //
    //  Initialize the Vcb for this volume
    //

    Status = RawInitializeVcb( &VolumeDeviceObject->Vcb,
                               IrpSp->Parameters.MountVolume.DeviceObject,
                               IrpSp->Parameters.MountVolume.Vpb );


    if ( !NT_SUCCESS( Status ) ) {

        //
        //  Unlike the other points of teardown we do not need to deref the target device
        //  a iosubsys will automatically do that for a failed mount
        //  

        IoDeleteDevice( (PDEVICE_OBJECT)VolumeDeviceObject );
        return Status;
    }

    //
    //  Finally, make it look as if the volume has been
    //  mounted.  This includes storing the
    //  address of this file system's device object (the one
    //  that was created to handle this volume) in the VPB so
    //  all requests are directed to this file system from
    //  now until the volume is initialized with a real file
    //  structure.
    //

    VolumeDeviceObject->Vcb.Vpb->DeviceObject = (PDEVICE_OBJECT)VolumeDeviceObject;
    VolumeDeviceObject->Vcb.Vpb->SerialNumber = 0xFFFFFFFF;
    VolumeDeviceObject->Vcb.Vpb->VolumeLabelLength = 0;

    VolumeDeviceObject->DeviceObject.Flags &= ~DO_DEVICE_INITIALIZING;
    VolumeDeviceObject->DeviceObject.StackSize = (UCHAR) (DeviceObjectWeTalkTo->StackSize + 1);

    {
        PFILE_OBJECT VolumeFileObject = NULL;

        //
        //  We need a file object to do the notification.
        //
        
        try {
            VolumeFileObject = IoCreateStreamFileObjectLite( NULL, &VolumeDeviceObject->DeviceObject );
        } except (EXCEPTION_EXECUTE_HANDLER) {
            Status = GetExceptionCode();
        }

        if (!NT_SUCCESS(Status)) {
            IoDeleteDevice( (PDEVICE_OBJECT)VolumeDeviceObject );
            return Status;
        }

        //
        //  We need to bump the count up 2 now so that the close we do in a few lines
        //  doesn't make the Vcb go away now.
        //
        
        VolumeDeviceObject->Vcb.OpenCount += 2;
        FsRtlNotifyVolumeEvent( VolumeFileObject, FSRTL_VOLUME_MOUNT );
        ObDereferenceObject( VolumeFileObject );

        //
        //  Okay, the close is over, now we can safely decrement the open count again
       //  (back to 0) so the Vcb can go away when we're really done with it.
        //
        
        VolumeDeviceObject->Vcb.OpenCount -= 2;
    }
    
    return Status;
}


//
//  Local Support Routine
//

NTSTATUS
RawVerifyVolume (
    IN PIO_STACK_LOCATION IrpSp,
    IN PVCB Vcb
    )

/*++

Routine Description:

    This routine verifies a volume.

Arguments:

    IrpSp - Supplies the IrpSp parameters to process

Return Value:

    NTSTATUS - The return status for the operation

--*/

{
    NTSTATUS Status;
    BOOLEAN DeleteVolume = FALSE;
    KIRQL   Irql;
    PVPB    vpb;
    BOOLEAN Mounted;

    //
    //  If the volume is somehow stale, dismount.  We must synchronize
    //  our inspection of the close count so we don't rip the volume up
    //  while racing with a close, for instance.  The VPB refcount drops
    //  *before* the close comes into the filesystem.
    //

    //
    // By this time its possible that the volume has been dismounted by
    // RawClose. So check if its mounted. If so, take a reference on the VPB
    // The reference on the VPB will prevent close from deleting the device.
    //

    IoAcquireVpbSpinLock(&Irql);

    Mounted = FALSE;
    vpb = IrpSp->Parameters.VerifyVolume.Vpb;
    if (vpb->Flags & VPB_MOUNTED) {
        vpb->ReferenceCount++;
        Mounted = TRUE;
    }

    IoReleaseVpbSpinLock(Irql);

    if (!Mounted) {
        return STATUS_WRONG_VOLUME;
    }

    Status = KeWaitForSingleObject( &Vcb->Mutex,
                                   Executive,
                                   KernelMode,
                                   FALSE,
                                   (PLARGE_INTEGER) NULL );
    ASSERT( NT_SUCCESS( Status ) );

    //
    //  Since we ignore all verify errors from the disk driver itself,
    //  this request must have originated from a file system, thus
    //  since we weren't the originators, we're going to say this isn't
    //  our volume, and if the open count is zero, dismount the volume.
    //

    IoAcquireVpbSpinLock(&Irql);
    vpb->ReferenceCount--;
    IoReleaseVpbSpinLock(Irql);

    Vcb->Vpb->RealDevice->Flags &= ~DO_VERIFY_VOLUME;

    if (Vcb->OpenCount == 0) {

        DeleteVolume = RawCheckForDismount( Vcb, FALSE );
    }

    if (!DeleteVolume) {
        (VOID)KeReleaseMutex( &Vcb->Mutex, FALSE );
    }

    return STATUS_WRONG_VOLUME;
}



//
//  Local Support Routine
//

NTSTATUS
RawUserFsCtrl (
    IN PIO_STACK_LOCATION IrpSp,
    IN PVCB Vcb
    )

/*++

Routine Description:

    This is the common routine for implementing the user's requests made
    through NtFsControlFile.

Arguments:

    IrpSp - Supplies the IrpSp parameters to process

    Vcb - Supplies the volume we are working on.

Return Value:

    NTSTATUS - The return status for the operation

--*/

{
    NTSTATUS Status;
    ULONG FsControlCode;
    PFILE_OBJECT FileObject;

    PAGED_CODE();

    FsControlCode = IrpSp->Parameters.FileSystemControl.FsControlCode;
    FileObject = IrpSp->FileObject;

    //
    //  Do pre-notification before entering the volume mutex so that we
    //  can be reentered by good threads cleaning up their resources.
    //

    switch (FsControlCode) {
        case FSCTL_LOCK_VOLUME:
            
            FsRtlNotifyVolumeEvent( FileObject, FSRTL_VOLUME_LOCK );
            break;

        case FSCTL_DISMOUNT_VOLUME:

            FsRtlNotifyVolumeEvent( FileObject, FSRTL_VOLUME_DISMOUNT );
            break;

        default:
            break;
    }
    
    Status = KeWaitForSingleObject( &Vcb->Mutex,
                                   Executive,
                                   KernelMode,
                                   FALSE,
                                   (PLARGE_INTEGER) NULL );
    ASSERT( NT_SUCCESS( Status ) );

    switch ( FsControlCode ) {

    case FSCTL_REQUEST_OPLOCK_LEVEL_1:
    case FSCTL_REQUEST_OPLOCK_LEVEL_2:
    case FSCTL_OPLOCK_BREAK_ACKNOWLEDGE:
    case FSCTL_OPLOCK_BREAK_NOTIFY:

        Status = STATUS_NOT_IMPLEMENTED;
        break;

    case FSCTL_LOCK_VOLUME:

        if ( !FlagOn(Vcb->VcbState, VCB_STATE_FLAG_LOCKED) &&
             (Vcb->OpenCount == 1) ) {

            Vcb->VcbState |= VCB_STATE_FLAG_LOCKED;

            Status = STATUS_SUCCESS;

        } else {

            Status = STATUS_ACCESS_DENIED;
        }

        break;

    case FSCTL_UNLOCK_VOLUME:

        if ( !FlagOn(Vcb->VcbState, VCB_STATE_FLAG_LOCKED) ) {

            Status = STATUS_NOT_LOCKED;

        } else {

            Vcb->VcbState &= ~VCB_STATE_FLAG_LOCKED;

            Status = STATUS_SUCCESS;
        }

        break;

    case FSCTL_DISMOUNT_VOLUME:

        //
        //  Right now the logic in cleanup.c assumes that there can
        //  only be one handle on the volume if locked.  The code
        //  there needs to be fixed if forced dismounts are allowed.
        //

        if (FlagOn(Vcb->VcbState, VCB_STATE_FLAG_LOCKED)) {

            Vcb->VcbState |=  VCB_STATE_FLAG_DISMOUNTED;
            Status = STATUS_SUCCESS;

        } else {

            Status = STATUS_ACCESS_DENIED;
        }

        break;

    default:

        Status = STATUS_INVALID_PARAMETER;
        break;
    }

    (VOID)KeReleaseMutex( &Vcb->Mutex, FALSE );

    //
    //  Now perform post-notification as required.
    //

    if (NT_SUCCESS( Status )) {
    
        switch ( FsControlCode ) {
            case FSCTL_UNLOCK_VOLUME:

                FsRtlNotifyVolumeEvent( FileObject, FSRTL_VOLUME_UNLOCK );
                break;
            
            default:
                break;
        }
    
    } else {
        
        switch ( FsControlCode ) {
            case FSCTL_LOCK_VOLUME:
                
                FsRtlNotifyVolumeEvent( FileObject, FSRTL_VOLUME_LOCK_FAILED );
                break;

            case FSCTL_DISMOUNT_VOLUME:

                FsRtlNotifyVolumeEvent( FileObject, FSRTL_VOLUME_DISMOUNT_FAILED );
                break;

            default:
                break;
        }
    }

    return Status;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利视频一区二区三区| 亚洲精品久久7777| 久久 天天综合| 日韩西西人体444www| 久久精品国产亚洲高清剧情介绍| 日韩一区二区在线观看视频播放| 精品影院一区二区久久久| 欧美精品一区男女天堂| 国内国产精品久久| 国产精品久久免费看| 91在线观看视频| 性久久久久久久| 日韩精品一区国产麻豆| 国产91精品在线观看| 亚洲免费高清视频在线| 欧美视频精品在线观看| 日韩综合一区二区| 国产婷婷色一区二区三区在线| 国产suv精品一区二区三区| 亚洲激情六月丁香| 91精品国模一区二区三区| 国产真实乱子伦精品视频| 国产精品人人做人人爽人人添| 在线亚洲+欧美+日本专区| 日本不卡1234视频| 欧美激情一区二区三区不卡 | 91精品国产高清一区二区三区| 麻豆一区二区在线| 亚洲色图欧洲色图| 欧美va日韩va| 91在线播放网址| 精品一区二区久久久| 中文字幕高清不卡| 91精品国产福利| av中文一区二区三区| 日本女优在线视频一区二区| 日本一区二区三区免费乱视频| 欧美视频三区在线播放| 国产激情91久久精品导航| 亚洲1区2区3区4区| 亚洲欧美在线另类| 欧美大片一区二区三区| 欧美伊人久久久久久久久影院 | av在线一区二区三区| 日韩av午夜在线观看| 国产精品国产三级国产普通话99| 在线观看91av| 色婷婷综合久久| 国产精品羞羞答答xxdd| 日韩激情av在线| 综合在线观看色| 国产亚洲精品7777| 日韩三级高清在线| 欧美日韩中字一区| 91丨九色丨蝌蚪富婆spa| 国产精品乡下勾搭老头1| 美日韩一区二区三区| 亚洲成人资源在线| 亚洲日本va在线观看| 国产日韩欧美a| 久久综合狠狠综合久久激情| 欧美精品乱码久久久久久按摩 | 色丁香久综合在线久综合在线观看| 国内精品嫩模私拍在线| 蜜臀国产一区二区三区在线播放 | 91麻豆精品国产91久久久| 欧洲视频一区二区| 一本色道**综合亚洲精品蜜桃冫| 国产91精品久久久久久久网曝门| 另类小说欧美激情| 奇米色一区二区三区四区| 丝袜美腿一区二区三区| 亚洲午夜电影在线| 亚洲一区二区在线视频| 亚洲欧美日韩系列| 一区二区三区不卡在线观看| 亚洲欧洲另类国产综合| 国产精品美女久久久久aⅴ国产馆| 亚洲国产精品二十页| 国产视频一区在线观看 | 精品美女被调教视频大全网站| 欧美福利视频导航| 欧美一区二区三区日韩| 91精品国产综合久久久久久久久久 | 1000精品久久久久久久久| 国产亚洲1区2区3区| 国产精品天天看| 亚洲欧美一区二区三区国产精品| 一区二区三区日韩精品| 亚洲国产中文字幕| 日本不卡一区二区| 精品亚洲免费视频| 成人免费视频免费观看| 色综合天天做天天爱| 在线视频你懂得一区| 在线播放国产精品二区一二区四区| 在线成人av网站| 26uuu色噜噜精品一区| 国产精品丝袜在线| 一区二区成人在线视频| 日产国产高清一区二区三区| 狠狠色丁香久久婷婷综合_中| 国产经典欧美精品| 91久久精品日日躁夜夜躁欧美| 欧美日韩一区视频| 久久综合网色—综合色88| 国产精品视频免费| 亚洲成人先锋电影| 精品系列免费在线观看| 99精品久久只有精品| 欧美三级日韩三级国产三级| 欧美电影免费提供在线观看| 国产欧美日韩视频在线观看| 亚洲免费成人av| 久久99深爱久久99精品| 91色porny在线视频| 日韩片之四级片| 亚洲图片欧美激情| 久久99热99| 日本道精品一区二区三区| 精品精品国产高清a毛片牛牛| 国产精品精品国产色婷婷| 日韩成人av影视| a4yy欧美一区二区三区| 3d成人动漫网站| 亚洲三级电影网站| 国产精品综合一区二区三区| 欧美性做爰猛烈叫床潮| 国产蜜臀av在线一区二区三区| 亚洲va国产天堂va久久en| 国产不卡视频在线播放| 日韩欧美一区二区视频| 一区二区三区国产豹纹内裤在线| 激情成人综合网| 欧美另类z0zxhd电影| 亚洲欧美在线视频| 国产成人在线视频网址| 日韩午夜激情av| 亚洲国产精品一区二区www| 成人激情综合网站| 26uuu国产在线精品一区二区| 香蕉成人啪国产精品视频综合网| 成人av高清在线| 久久精品视频一区二区三区| 秋霞午夜鲁丝一区二区老狼| 欧洲av在线精品| 国产精品的网站| 粉嫩欧美一区二区三区高清影视 | 日本精品一级二级| 中文字幕不卡一区| 国产精品一二三四五| 精品国免费一区二区三区| 日韩国产精品91| 欧美日韩免费电影| 亚洲一二三区不卡| 91欧美一区二区| 亚洲精品一卡二卡| 色香蕉成人二区免费| 综合色天天鬼久久鬼色| 成人av网站在线| 国产精品久久三区| 成人a区在线观看| 国产精品二区一区二区aⅴ污介绍| 国产精华液一区二区三区| 国产日韩成人精品| 国产成人av一区二区| 国产欧美精品一区二区色综合朱莉| 久久99国产精品免费| 久久伊人蜜桃av一区二区| 激情久久五月天| 亚洲国产岛国毛片在线| 粉嫩在线一区二区三区视频| 国产精品美女久久久久久久久久久| 国产盗摄女厕一区二区三区| 欧美国产一区二区在线观看| 成人免费黄色在线| 亚洲美女免费视频| 欧美亚洲一区三区| 日韩中文字幕区一区有砖一区 | 久久免费偷拍视频| 国产高清成人在线| 国产精品家庭影院| 欧美性生活大片视频| 肉丝袜脚交视频一区二区| 91精品国产一区二区三区蜜臀| 麻豆精品一区二区| 国产丝袜在线精品| 色婷婷亚洲综合| 蜜桃久久av一区| 欧美激情一二三区| 色婷婷国产精品久久包臀| 日韩精品午夜视频| 久久久久97国产精华液好用吗| av不卡免费电影| 午夜国产精品影院在线观看| 精品国产乱码久久久久久牛牛| 国产suv精品一区二区6| 亚洲电影欧美电影有声小说| 精品国产一区二区三区忘忧草 | 香蕉久久一区二区不卡无毒影院|