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

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

?? filedisk.c

?? filedisk 開發 如何創建虛擬磁盤 建立一個虛擬磁盤方法
?? C
?? 第 1 頁 / 共 3 頁
字號:
            }

            cdrom_toc = (PCDROM_TOC) Irp->AssociatedIrp.SystemBuffer;

            RtlZeroMemory(cdrom_toc, sizeof(CDROM_TOC));

            cdrom_toc->FirstTrack = 1;
            cdrom_toc->LastTrack = 1;
            cdrom_toc->TrackData[0].Control = TOC_DATA_TRACK;

            status = STATUS_SUCCESS;
            Irp->IoStatus.Information = sizeof(CDROM_TOC);

            break;
        }

    case IOCTL_DISK_SET_PARTITION_INFO:
        {
            if (device_extension->read_only)
            {
                status = STATUS_MEDIA_WRITE_PROTECTED;
                Irp->IoStatus.Information = 0;
                break;
            }

            if (io_stack->Parameters.DeviceIoControl.InputBufferLength <
                sizeof(SET_PARTITION_INFORMATION))
            {
                status = STATUS_INVALID_PARAMETER;
                Irp->IoStatus.Information = 0;
                break;
            }

            status = STATUS_SUCCESS;
            Irp->IoStatus.Information = 0;

            break;
        }

    case IOCTL_DISK_VERIFY:
        {
            PVERIFY_INFORMATION verify_information;

            if (io_stack->Parameters.DeviceIoControl.InputBufferLength <
                sizeof(VERIFY_INFORMATION))
            {
                status = STATUS_INVALID_PARAMETER;
                Irp->IoStatus.Information = 0;
                break;
            }

            verify_information = (PVERIFY_INFORMATION) Irp->AssociatedIrp.SystemBuffer;

            status = STATUS_SUCCESS;
            Irp->IoStatus.Information = verify_information->Length;

            break;
        }

    default:
        {
            KdPrint((
                "FileDisk: Unknown IoControlCode %#x\n",
                io_stack->Parameters.DeviceIoControl.IoControlCode
                ));

            status = STATUS_INVALID_DEVICE_REQUEST;
            Irp->IoStatus.Information = 0;
        }
    }

    if (status != STATUS_PENDING)
    {
        Irp->IoStatus.Status = status;

        IoCompleteRequest(Irp, IO_NO_INCREMENT);
    }

    return status;
}

VOID
FileDiskThread (
    IN PVOID Context
    )
{
    PDEVICE_OBJECT      device_object;
    PDEVICE_EXTENSION   device_extension;
    PLIST_ENTRY         request;
    PIRP                irp;
    PIO_STACK_LOCATION  io_stack;
    PUCHAR              system_buffer;
    PUCHAR              buffer;

    ASSERT(Context != NULL);

    device_object = (PDEVICE_OBJECT) Context;

    device_extension = (PDEVICE_EXTENSION) device_object->DeviceExtension;

    KeSetPriorityThread(KeGetCurrentThread(), LOW_REALTIME_PRIORITY);

    for (;;)
    {
        KeWaitForSingleObject(
            &device_extension->request_event,
            Executive,
            KernelMode,
            FALSE,
            NULL
            );

        if (device_extension->terminate_thread)
        {
            PsTerminateSystemThread(STATUS_SUCCESS);
        }

        while (request = ExInterlockedRemoveHeadList(
            &device_extension->list_head,
            &device_extension->list_lock
            ))
        {
            irp = CONTAINING_RECORD(request, IRP, Tail.Overlay.ListEntry);

            io_stack = IoGetCurrentIrpStackLocation(irp);

            switch (io_stack->MajorFunction)
            {
            case IRP_MJ_READ:
                system_buffer = (PUCHAR) MmGetSystemAddressForMdlSafe(irp->MdlAddress, NormalPagePriority);
                if (system_buffer == NULL)
                {
                    irp->IoStatus.Status = STATUS_INSUFFICIENT_RESOURCES;
                    irp->IoStatus.Information = 0;
                    break;
                }
                buffer = (PUCHAR) ExAllocatePool(PagedPool, io_stack->Parameters.Read.Length);
                if (buffer == NULL)
                {
                    irp->IoStatus.Status = STATUS_INSUFFICIENT_RESOURCES;
                    irp->IoStatus.Information = 0;
                    break;
                }
                ZwReadFile(
                    device_extension->file_handle,
                    NULL,
                    NULL,
                    NULL,
                    &irp->IoStatus,
                    buffer,
                    io_stack->Parameters.Read.Length,
                    &io_stack->Parameters.Read.ByteOffset,
                    NULL
                    );
                RtlCopyMemory(system_buffer, buffer, io_stack->Parameters.Read.Length);
                ExFreePool(buffer);
                break;

            case IRP_MJ_WRITE:
                if ((io_stack->Parameters.Write.ByteOffset.QuadPart +
                     io_stack->Parameters.Write.Length) >
                     device_extension->file_size.QuadPart)
                {
                    irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
                    irp->IoStatus.Information = 0;
                }
                ZwWriteFile(
                    device_extension->file_handle,
                    NULL,
                    NULL,
                    NULL,
                    &irp->IoStatus,
                    MmGetSystemAddressForMdlSafe(irp->MdlAddress, NormalPagePriority),
                    io_stack->Parameters.Write.Length,
                    &io_stack->Parameters.Write.ByteOffset,
                    NULL
                    );
                break;

            case IRP_MJ_DEVICE_CONTROL:
                switch (io_stack->Parameters.DeviceIoControl.IoControlCode)
                {
                case IOCTL_FILE_DISK_OPEN_FILE:

                    SeImpersonateClient(device_extension->security_client_context, NULL);

                    irp->IoStatus.Status = FileDiskOpenFile(device_object, irp);

                    PsRevertToSelf();

                    break;

                case IOCTL_FILE_DISK_CLOSE_FILE:
                    irp->IoStatus.Status = FileDiskCloseFile(device_object, irp);
                    break;

                default:
                    irp->IoStatus.Status = STATUS_DRIVER_INTERNAL_ERROR;
                }
                break;

            default:
                irp->IoStatus.Status = STATUS_DRIVER_INTERNAL_ERROR;
            }

            IoCompleteRequest(
                irp,
                (CCHAR) (NT_SUCCESS(irp->IoStatus.Status) ?
                IO_DISK_INCREMENT : IO_NO_INCREMENT)
                );
        }
    }
}

#pragma code_seg("PAGE")

NTSTATUS
FileDiskOpenFile (
    IN PDEVICE_OBJECT   DeviceObject,
    IN PIRP             Irp
    )
{
    PDEVICE_EXTENSION               device_extension;
    POPEN_FILE_INFORMATION          open_file_information;
    UNICODE_STRING                  ufile_name;
    NTSTATUS                        status;
    OBJECT_ATTRIBUTES               object_attributes;
    FILE_END_OF_FILE_INFORMATION    file_eof;
    FILE_BASIC_INFORMATION          file_basic;
    FILE_STANDARD_INFORMATION       file_standard;
    FILE_ALIGNMENT_INFORMATION      file_alignment;

    PAGED_CODE();

    ASSERT(DeviceObject != NULL);
    ASSERT(Irp != NULL);

    device_extension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;

    open_file_information = (POPEN_FILE_INFORMATION) Irp->AssociatedIrp.SystemBuffer;

    if (DeviceObject->DeviceType != FILE_DEVICE_CD_ROM)
    {
        device_extension->read_only = open_file_information->ReadOnly;
    }

    device_extension->file_name.Length = open_file_information->FileNameLength;
    device_extension->file_name.MaximumLength = open_file_information->FileNameLength;
    device_extension->file_name.Buffer = ExAllocatePool(NonPagedPool, open_file_information->FileNameLength);

    RtlCopyMemory(
        device_extension->file_name.Buffer,
        open_file_information->FileName,
        open_file_information->FileNameLength
        );

    status = RtlAnsiStringToUnicodeString(
        &ufile_name,
        &device_extension->file_name,
        TRUE
        );

    if (!NT_SUCCESS(status))
    {
        ExFreePool(device_extension->file_name.Buffer);
        Irp->IoStatus.Status = status;
        Irp->IoStatus.Information = 0;
        return status;
    }

    InitializeObjectAttributes(
        &object_attributes,
        &ufile_name,
        OBJ_CASE_INSENSITIVE,
        NULL,
        NULL
        );

    status = ZwCreateFile(
        &device_extension->file_handle,
        device_extension->read_only ? GENERIC_READ : GENERIC_READ | GENERIC_WRITE,
        &object_attributes,
        &Irp->IoStatus,
        NULL,
        FILE_ATTRIBUTE_NORMAL,
        device_extension->read_only ? FILE_SHARE_READ : 0,
        FILE_OPEN,
        FILE_NON_DIRECTORY_FILE |
        FILE_RANDOM_ACCESS |
        FILE_NO_INTERMEDIATE_BUFFERING |
        FILE_SYNCHRONOUS_IO_NONALERT,
        NULL,
        0
        );

    if (status == STATUS_OBJECT_NAME_NOT_FOUND || status == STATUS_NO_SUCH_FILE)
    {
        if (device_extension->read_only || open_file_information->FileSize.QuadPart == 0)
        {
            ExFreePool(device_extension->file_name.Buffer);
            RtlFreeUnicodeString(&ufile_name);

            Irp->IoStatus.Status = STATUS_NO_SUCH_FILE;
            Irp->IoStatus.Information = 0;

            return STATUS_NO_SUCH_FILE;
        }
        else
        {
            status = ZwCreateFile(
                &device_extension->file_handle,
                GENERIC_READ | GENERIC_WRITE,
                &object_attributes,
                &Irp->IoStatus,
                &open_file_information->FileSize,
                FILE_ATTRIBUTE_NORMAL,
                0,
                FILE_OPEN_IF,
                FILE_NON_DIRECTORY_FILE |
                FILE_RANDOM_ACCESS |
                FILE_NO_INTERMEDIATE_BUFFERING |
                FILE_SYNCHRONOUS_IO_NONALERT,
                NULL,
                0
                );

            if (!NT_SUCCESS(status))
            {
                ExFreePool(device_extension->file_name.Buffer);
                RtlFreeUnicodeString(&ufile_name);
                return status;
            }

            if (Irp->IoStatus.Information == FILE_CREATED)
            {
                file_eof.EndOfFile.QuadPart = open_file_information->FileSize.QuadPart;

                status = ZwSetInformationFile(
                    device_extension->file_handle,
                    &Irp->IoStatus,
                    &file_eof,
                    sizeof(FILE_END_OF_FILE_INFORMATION),
                    FileEndOfFileInformation
                    );

                if (!NT_SUCCESS(status))
                {
                    ExFreePool(device_extension->file_name.Buffer);
                    RtlFreeUnicodeString(&ufile_name);
                    ZwClose(device_extension->file_handle);
                    return status;
                }
            }
        }
    }
    else if (!NT_SUCCESS(status))
    {
        ExFreePool(device_extension->file_name.Buffer);
        RtlFreeUnicodeString(&ufile_name);
        return status;
    }

    RtlFreeUnicodeString(&ufile_name);

    status = ZwQueryInformationFile(
        device_extension->file_handle,
        &Irp->IoStatus,
        &file_basic,
        sizeof(FILE_BASIC_INFORMATION),
        FileBasicInformation
        );

    if (!NT_SUCCESS(status))
    {
        ExFreePool(device_extension->file_name.Buffer);
        ZwClose(device_extension->file_handle);
        return status;
    }

/*
    //
    // The NT cache manager can deadlock if a filesystem that is using the cache
    // manager is used in a virtual disk that stores its file on a filesystem
    // that is also using the cache manager, this is why we open the file with
    // FILE_NO_INTERMEDIATE_BUFFERING above, however if the file is compressed
    // or encrypted NT will not honor this request and cache it anyway since it
    // need to store the decompressed/unencrypted data somewhere, therefor we put
    // an extra check here and don't alow disk images to be compressed/encrypted.
    //
    if (file_basic.FileAttributes & (FILE_ATTRIBUTE_COMPRESSED | FILE_ATTRIBUTE_ENCRYPTED))
    {
        ExFreePool(device_extension->file_name.Buffer);
        ZwClose(device_extension->file_handle);
        Irp->IoStatus.Status = STATUS_ACCESS_DENIED;
        Irp->IoStatus.Information = 0;
        return STATUS_ACCESS_DENIED;
    }
*/

    status = ZwQueryInformationFile(
        device_extension->file_handle,
        &Irp->IoStatus,
        &file_standard,
        sizeof(FILE_STANDARD_INFORMATION),
        FileStandardInformation
        );

    if (!NT_SUCCESS(status))
    {
        ExFreePool(device_extension->file_name.Buffer);
        ZwClose(device_extension->file_handle);
        return status;
    }

    device_extension->file_size.QuadPart = file_standard.EndOfFile.QuadPart;

    status = ZwQueryInformationFile(
        device_extension->file_handle,
        &Irp->IoStatus,
        &file_alignment,
        sizeof(FILE_ALIGNMENT_INFORMATION),
        FileAlignmentInformation
        );

    if (!NT_SUCCESS(status))
    {
        ExFreePool(device_extension->file_name.Buffer);
        ZwClose(device_extension->file_handle);
        return status;
    }

    DeviceObject->AlignmentRequirement = file_alignment.AlignmentRequirement;

    if (device_extension->read_only)
    {
        DeviceObject->Characteristics |= FILE_READ_ONLY_DEVICE;
    }
    else
    {
        DeviceObject->Characteristics &= ~FILE_READ_ONLY_DEVICE;
    }

    device_extension->media_in_device = TRUE;

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;     

    return STATUS_SUCCESS;
}

NTSTATUS
FileDiskCloseFile (
    IN PDEVICE_OBJECT   DeviceObject,
    IN PIRP             Irp
    )
{
    PDEVICE_EXTENSION device_extension;

    PAGED_CODE();

    ASSERT(DeviceObject != NULL);
    ASSERT(Irp != NULL);

    device_extension = (PDEVICE_EXTENSION) DeviceObject->DeviceExtension;

    ExFreePool(device_extension->file_name.Buffer);

    ZwClose(device_extension->file_handle);

    device_extension->media_in_device = FALSE;

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    return STATUS_SUCCESS;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91国产成人在线| 欧美日本视频在线| 日韩高清欧美激情| 欧美美女直播网站| 色综合久久综合网| 99re8在线精品视频免费播放| 成人午夜短视频| 99久久夜色精品国产网站| av成人老司机| 91久久奴性调教| 欧美视频第二页| 91精品国产高清一区二区三区| 538在线一区二区精品国产| 欧美精品在线观看播放| 日韩精品一区二区在线| 日韩免费观看高清完整版| 精品黑人一区二区三区久久| 久久久久国产一区二区三区四区 | 国产欧美视频一区二区| 日韩va欧美va亚洲va久久| 日韩电影一区二区三区| 韩国女主播成人在线观看| 成人黄色网址在线观看| 色婷婷国产精品综合在线观看| 欧美乱妇15p| 欧美精品一区二区久久婷婷| 国产欧美精品一区| 亚洲香蕉伊在人在线观| 久久国产精品第一页| 波多野结衣中文字幕一区二区三区| 在线观看日韩毛片| 精品国产一区久久| 亚洲人亚洲人成电影网站色| 亚洲国产欧美另类丝袜| 国模套图日韩精品一区二区| 9l国产精品久久久久麻豆| 在线不卡欧美精品一区二区三区| 久久午夜色播影院免费高清| 亚洲夂夂婷婷色拍ww47| 国内久久精品视频| 欧美做爰猛烈大尺度电影无法无天| 欧美浪妇xxxx高跟鞋交| 国产精品国产自产拍在线| 天使萌一区二区三区免费观看| 国产91丝袜在线观看| 欧美色爱综合网| 国产欧美日韩精品一区| 麻豆91小视频| 在线一区二区三区四区| 久久九九影视网| 欧美bbbbb| 欧美日韩小视频| 亚洲三级在线播放| 粉嫩高潮美女一区二区三区| 日韩精品中文字幕在线一区| 久久精品一区二区三区不卡牛牛| 国产精品乱码久久久久久| 五月激情综合婷婷| 91福利精品第一导航| 中文字幕制服丝袜一区二区三区| 奇米影视一区二区三区小说| 欧美中文字幕一区二区三区亚洲| 国产精品久久网站| 久草这里只有精品视频| 日韩一区二区中文字幕| 日韩精品免费专区| 欧美性猛交xxxx乱大交退制版| 中文字幕av一区 二区| 国产精品综合视频| 精品国产一区二区亚洲人成毛片| 日韩电影免费一区| 91精品国产综合久久福利软件| 亚洲一区二区三区中文字幕| 91福利在线观看| 日本va欧美va精品发布| 色八戒一区二区三区| 综合电影一区二区三区 | 五月激情综合色| 欧美日韩在线播| 五月天一区二区| 欧美一区二区播放| 久久爱www久久做| 久久久久97国产精华液好用吗| 韩国女主播成人在线| 国产午夜亚洲精品羞羞网站| 国产主播一区二区| 国产色91在线| 97成人超碰视| 亚洲国产一区二区视频| 欧美一区二区观看视频| 久久国产日韩欧美精品| 欧美激情一区在线| 91丨porny丨蝌蚪视频| 亚洲观看高清完整版在线观看| 51精品国自产在线| 国产乱对白刺激视频不卡| 国产目拍亚洲精品99久久精品| 高清成人免费视频| 亚洲国产你懂的| 精品欧美一区二区在线观看| 国产电影精品久久禁18| 亚洲视频中文字幕| 日韩亚洲欧美综合| 风间由美中文字幕在线看视频国产欧美 | 欧洲亚洲国产日韩| 看电视剧不卡顿的网站| 中文字幕一区二区三区在线播放| 欧美影院一区二区| 国内精品伊人久久久久av影院| 国产精品―色哟哟| 51久久夜色精品国产麻豆| 国产成人午夜精品影院观看视频| 亚洲免费在线播放| 日韩免费高清视频| 91国偷自产一区二区开放时间 | av爱爱亚洲一区| 蜜臀91精品一区二区三区| 国产精品美女久久久久aⅴ | 国产精品毛片高清在线完整版| 欧美吞精做爰啪啪高潮| 国产成人免费视频一区| 日韩av中文在线观看| 亚洲色欲色欲www| 2020国产成人综合网| 欧美影视一区二区三区| 成人免费视频免费观看| 捆绑紧缚一区二区三区视频| 亚洲电影一区二区| 中文乱码免费一区二区| 精品少妇一区二区三区视频免付费 | 国产电影精品久久禁18| 日韩高清一区在线| 亚洲影视在线播放| 国产精品激情偷乱一区二区∴| 欧美一区二视频| 欧美丝袜丝交足nylons图片| 成人综合在线网站| 狠狠网亚洲精品| 麻豆精品视频在线观看视频| 亚洲高清不卡在线| 亚洲色图第一区| 国产精品福利在线播放| 国产人久久人人人人爽| 久久久噜噜噜久噜久久综合| 精品免费视频.| 精品日韩在线一区| 日韩一区二区三区在线视频| 欧美电影一区二区| 911国产精品| 欧美一卡二卡在线观看| 69堂国产成人免费视频| 欧美日韩高清影院| 欧美乱妇20p| 日韩区在线观看| 91精品久久久久久蜜臀| 欧美一区二区三区思思人| 制服丝袜av成人在线看| 欧美日本不卡视频| 欧美一区二区精美| 久久久无码精品亚洲日韩按摩| 亚洲精品在线三区| 国产性天天综合网| 国产精品视频yy9299一区| 亚洲婷婷综合色高清在线| 亚洲精品免费在线| 亚洲成a天堂v人片| 免费不卡在线观看| 国产不卡在线视频| 在线精品视频免费观看| 欧美精品v国产精品v日韩精品| 日韩午夜在线影院| 国产欧美日韩在线看| 中文字幕在线观看一区| 亚洲一二三区在线观看| 日本成人在线网站| 国产a精品视频| 在线观看日韩av先锋影音电影院| 欧美日韩久久久一区| 欧美精品一区二区在线播放| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲精品欧美激情| 蜜桃av噜噜一区| 成人午夜精品在线| 欧美高清一级片在线| 久久久国产精品不卡| 亚洲成人在线观看视频| 国产成人一区二区精品非洲| 色噜噜狠狠成人中文综合| 欧美一区二区三级| 中文字幕色av一区二区三区| 日韩在线卡一卡二| 97久久精品人人做人人爽| 欧美一区二视频| 亚洲欧美怡红院| 国产原创一区二区| 欧美日韩日日摸| 中文字幕在线播放不卡一区| 九九久久精品视频| 欧美专区亚洲专区| 国产精品久久久久毛片软件|