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

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

?? init.c

?? 硬盤驅動程序, 硬盤驅動程序,硬盤驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:

            if (controllerData->InterruptObject != NULL) 
            {

                IoDisconnectInterrupt(controllerData->InterruptObject);
            }

        //
        // and now free the allocated data
        //
        ExFreePool(controllerData);
    }

    return ntStatus;
}



///////////////////////////////////////////////////////////////////////////////
//
//	InitializeDisk
//
//    This routine initializes the disk
//
//	INPUTS:
//
//    ConfigData        - pointer to the configuration data
//    DriverObject      - pointer to our driver object
//    ControllerData - pointer to CONTROLLER_DATA data
//
//	OUTPUTS:
//	
//    None.
//
//	RETURNS:
//
//    STATUS_SUCCESS if the disk initializes, otherwise an error code
//
//      IRQL:
//
//    IRQL_PASSIVE_LEVEL
//
//	NOTES:
//
//    This assumes:
//
//      - controller has been initialized and/or reset
//      - interrupts have been enabled
//
//    Here we:
//      
//      - create a directory for the device object
//      - allocates and initializes device object for the disk
//      - set the drive parameters
//      - reads the partition table
//      - allocates/initializes a partition object
//
//
///////////////////////////////////////////////////////////////////////////////

static NTSTATUS
InitializeDisk(IN PDRIVER_OBJECT DriverObject,
                IN PCONFIG_DATA ConfigData,
                IN OUT PCONTROLLER_DATA ControllerData)
{
    UCHAR       partitionNameBuffer[256];       // temp Ansi buffer
    STRING      partitionNameString;            // temp Ansi string 
    UNICODE_STRING      unicodeString;          // temp UNICODE string
    PDRIVE_LAYOUT_INFORMATION partitionList;    // for the partition table
    OBJECT_ATTRIBUTES objectAttributes;         // for the directory object
    HANDLE handle = NULL;                       // handle of directory object
    PDEVICE_OBJECT deviceObject = NULL;         // ptr to part 0 device object
    PDEVICE_OBJECT partitionObject;             // ptr to a part x device object
    PDEVICE_OBJECT nextPartition;               // ptr for walking chain
    PDEVICE_OBJECT *partitionPointer;
    PIDE_DEV_EXT devExt = NULL;                 // ptr to device extension
    PPARTITION_DATA partitionData;              // ptr to partition extension
    NTSTATUS ntStatus;
    ULONG partitionNumber;

    //
    // Generate a directory object for the partition
    //
    sprintf(partitionNameBuffer,"\\Device\\Harddisk%d",*(ConfigData->HardDiskCount));

    //
    // initialize the STRING structure with the constructed 
    // partitionNamebuffer in preparation to the conversion of this
    // Ansi string to UNICODE
    //
    RtlInitString(&partitionNameString, partitionNameBuffer);

    //
    // convert the Ansi string to UNICODE
    //
    ntStatus = RtlAnsiStringToUnicodeString(&unicodeString,
                                            &partitionNameString,
                                            TRUE);

    //
    // if we couldn't convert the string, then we've failed
    //
    if (!NT_SUCCESS(ntStatus)) {

        DbgPrint("InitializeDisk: Couldn't create the unicode device name\n");

        goto InitializeDiskExit;

    }

    //
    // Initialzie the object attributes structure for a subsequent Zw 
    // call to create the directory
    //
    InitializeObjectAttributes(&objectAttributes,
                                &unicodeString,
                                OBJ_PERMANENT,
                                NULL,
                                NULL);

    //
    // Create the directory
    //
    ntStatus = ZwCreateDirectoryObject(&handle,
                                        DIRECTORY_ALL_ACCESS,
                                        &objectAttributes);

    //
    // Since we're done with the UNICODE string (no matter what the
    // results of ZwCreateDirectoryObject()), we free the structure
    // now so we don't forget later on.
    //
    RtlFreeUnicodeString(&unicodeString);

    //
    // If we fail on the ZwCreateDirectoryObject(), then we've failed
    // initialization and we need to report back
    //
    if (!NT_SUCCESS(ntStatus)) {

        DbgPrint("InitializeDisk: Couldn't create the directory object\n");

        goto InitializeDiskExit;
    }

    //
    // Alter the attributes for the directory to be temporary, so that
    // if/when the handle count on the object goes to zero, it will be
    // deleted
    //
    ZwMakeTemporaryObject(handle);

    //
    // create partition 0 object
    //
    sprintf(partitionNameBuffer,
            "\\Device\\Harddisk%d\\Partition0",
            *(ConfigData->HardDiskCount));

    //
    // setup the ansi string for the UNICODE conversion
    //
    RtlInitString(&partitionNameString, partitionNameBuffer);

    ntStatus = RtlAnsiStringToUnicodeString(&unicodeString,
                                            &partitionNameString,
                                            TRUE);

    //
    // fail initialization if we can't get the UNICODE string 
    //
    if (!NT_SUCCESS(ntStatus)) {

        DbgPrint("InitializeDisk: Couldn't create the partition unicode name\n");

        goto InitializeDiskExit;

    }

    //
    // Create our disk device
    //
    ntStatus = IoCreateDevice(DriverObject,
                            sizeof(IDE_DEV_EXT),
                            &unicodeString,
                            FILE_DEVICE_DISK,
                            0,
                            FALSE,
                            &deviceObject);

    //
    // Again, we're done with the UNICODE string no matter the success
    // of IoCreateDevice(), so free it now
    //
    RtlFreeUnicodeString(&unicodeString);

    //
    // Check on the success of IoCreateDevice()
    //
    if (!NT_SUCCESS(ntStatus))  {

        DbgPrint("InitializeDisk: Couldn't create the device object - status %x\n",
                                    ntStatus);

        goto InitializeDiskExit;
    }

    //
    // Initialize partition 0 device object and extension data.  Store pointer
    // to controller extension in partition 0's extension.
    //
    deviceObject->Flags |= DO_DIRECT_IO;
    deviceObject->AlignmentRequirement = FILE_WORD_ALIGNMENT;

    devExt = (PIDE_DEV_EXT)(deviceObject->DeviceExtension);

    devExt->DiskNumber = *ConfigData->HardDiskCount;
    devExt->ControllerData = ControllerData;
    devExt->Partition0 = devExt;
    devExt->DeviceObject = deviceObject;
    devExt->DirectoryHandle = handle;
    devExt->PacketIsBeingRetried = FALSE;

    //
    // Set the device unit.  We must examine DiskNum for the case
    // where the controller says this is drive 2, but we were unable to
    // initialize the first drive.
    //
    devExt->DeviceUnit = DRIVE_1;

    //
    // Fill in device-specific numbers from IdeGetDataConfig
    //
    devExt->PretendNumberOfCylinders = ConfigData->Disk.PretendNumberOfCylinders;
    devExt->PretendTracksPerCylinder = ConfigData->Disk.PretendTracksPerCylinder;
    devExt->PretendSectorsPerTrack = ConfigData->Disk.PretendSectorsPerTrack;
    devExt->NumberOfCylinders = ConfigData->Disk.NumberOfCylinders;
    devExt->TracksPerCylinder = ConfigData->Disk.TracksPerCylinder;
    devExt->SectorsPerTrack = ConfigData->Disk.SectorsPerTrack;
    devExt->BytesPerSector = ConfigData->Disk.BytesPerSector;
    devExt->BytesPerInterrupt = ConfigData->Disk.BytesPerInterrupt;
    devExt->WritePrecomp = ConfigData->Disk.WritePrecomp;
    devExt->ReadCommand = ConfigData->Disk.ReadCommand;
    devExt->WriteCommand = ConfigData->Disk.WriteCommand;
    devExt->VerifyCommand = ConfigData->Disk.VerifyCommand;


    DbgPrint(
        "InitializeDisk: Geometry:\n"
        "        Appa Cyl: %x\n"
        "        Appa Hea: %x\n"
        "        Appa Sec: %x\n"
        "             Cyl: %x\n"
        "             Hea: %x\n"
        "             Sec: %x\n",
        devExt->PretendNumberOfCylinders,
        devExt->PretendTracksPerCylinder,
        devExt->PretendSectorsPerTrack,
        devExt->NumberOfCylinders,
        devExt->TracksPerCylinder,
        devExt->SectorsPerTrack);

    //
    // Determine the size of partition 0 (the whole disk).
    //

    devExt->Pi.StartingOffset.QuadPart = 0;

    devExt->Pi.PartitionLength.QuadPart =
            (UInt32x32To64(devExt->SectorsPerTrack, devExt->BytesPerSector) *
                            devExt->NumberOfCylinders) *
                                        devExt->TracksPerCylinder;

    ASSERT(devExt->BytesPerSector == 512);

    //
    // Byte to sector number conversion
    //
    devExt->ByteShiftToSector = 9;

    //
    // Initialize DPC 
    //
    IoInitializeDpcRequest(deviceObject, IdeDPC);

    //
    // Give the controller some time to settle down after reset.
    //
    IdeWaitControllerReady(ControllerData, 20, 150000);

    //
    // First we'll set up the disk so that it doesn't revert to power
    // on defaults after a controller reset.  Then we'll set it up
    // so that the write cache is disabled. 
    //
    ControllerData->DeviceObject = devExt->DeviceObject;

    //
    // Select the right drive.
    //
    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + DRIVE_HEAD_REGISTER,
                    devExt->DeviceUnit);
    //
    // Disable the reverting to power on.
    //
    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + WRITE_PRECOMP_REGISTER,
                                        0x66);

    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + COMMAND_REGISTER,
                                        0xef);

    //
    // wait for the controller to catch its breath
    //
    IdeWaitControllerReady(ControllerData, 10, 15000);

    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + DRIVE_HEAD_REGISTER,
                                    devExt->DeviceUnit);

    //
    // Set the drive parameters.  Note that this will generate an
    // interrupt, but we don't have to worry about it.
    //
    ControllerData->DeviceObject = devExt->DeviceObject;

    WRITE_PORT_UCHAR( ControllerData->ControllerAddress + DRIVE_HEAD_REGISTER,
        (UCHAR)(devExt->DeviceUnit | (devExt->TracksPerCylinder - 1)));

    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + SECTOR_COUNT_REGISTER,
                (UCHAR)(devExt->SectorsPerTrack));

    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + COMMAND_REGISTER,
                SET_DRIVE_PARAMETERS_COMMAND);

    //
    // Wait for the controller to be ready before we read the table
    //
    IdeWaitControllerReady(ControllerData, 20, 150000);

    //
    // Now recalibrate the drive.
    //
    ControllerData->DeviceObject = devExt->DeviceObject;


    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + DRIVE_HEAD_REGISTER,
                (UCHAR)(devExt->DeviceUnit | (devExt->TracksPerCylinder - 1)));

    WRITE_PORT_UCHAR(ControllerData->ControllerAddress + COMMAND_REGISTER,
                 RECALIBRATE_COMMAND);

    //
    // wait for things to settle down
    //
    IdeWaitControllerReady(ControllerData, 20, 150000);

    //

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品日产卡一卡二卡麻豆| 中文字幕精品一区二区精品绿巨人| 成人免费视频一区二区| 国产成人啪午夜精品网站男同| 九色|91porny| av在线不卡电影| 欧美在线观看一区| 欧美日韩电影在线播放| 欧洲生活片亚洲生活在线观看| 丁香另类激情小说| 成人国产亚洲欧美成人综合网| 色老汉一区二区三区| 在线影视一区二区三区| 欧美精品 日韩| 中文字幕一区二区三区色视频| 久久精品欧美一区二区三区不卡| 中文字幕中文字幕在线一区| 亚洲综合偷拍欧美一区色| 麻豆成人久久精品二区三区红 | 国产一区在线不卡| eeuss影院一区二区三区| 欧美日韩亚洲丝袜制服| 国产欧美日韩综合精品一区二区| 国产精品青草综合久久久久99| 欧美韩国日本综合| 中文久久乱码一区二区| 亚洲午夜久久久久久久久电影网 | 裸体一区二区三区| 国产伦精品一区二区三区在线观看 | 国产精品亲子乱子伦xxxx裸| 青青草国产成人av片免费| 色屁屁一区二区| 国产日韩精品一区二区三区 | 成人美女在线观看| 久久午夜免费电影| 国产成人精品免费视频网站| 在线综合视频播放| 三级久久三级久久久| 99久久免费精品高清特色大片| 91影视在线播放| 久久亚洲私人国产精品va媚药| 亚洲二区在线观看| 欧美精品乱码久久久久久按摩 | 成人h精品动漫一区二区三区| 久久久久久久网| 亚洲丶国产丶欧美一区二区三区| 成人免费高清在线| 国产日韩欧美在线一区| 国产精品538一区二区在线| 日韩欧美不卡在线观看视频| 日韩av一区二区在线影视| 久久影院视频免费| 99麻豆久久久国产精品免费 | 在线观看日韩电影| 麻豆精品国产传媒mv男同 | 一区二区三区免费网站| 成人av在线观| 婷婷中文字幕一区三区| 91精品福利在线一区二区三区| 精品伊人久久久久7777人| 精品国产乱码久久久久久蜜臀| 久久精品国产999大香线蕉| 中文成人综合网| 日韩午夜中文字幕| 99在线精品免费| 三级亚洲高清视频| 国产三级一区二区三区| 欧美日韩国产高清一区| 国产精品综合av一区二区国产馆| 国产精品麻豆久久久| 91精品国产麻豆国产自产在线| 国产精品18久久久久久vr| 国产精品国产精品国产专区不片 | 日韩午夜小视频| 日本黄色一区二区| 99精品久久只有精品| 国产福利一区二区三区在线视频| 一区二区三区四区高清精品免费观看| 中文av一区二区| 日韩亚洲欧美高清| 欧美日本韩国一区二区三区视频| 免费观看在线色综合| 亚洲视频一区二区在线| 日本一区二区三区四区在线视频| 91精品欧美福利在线观看| 91成人国产精品| 91蜜桃网址入口| 欧美性色aⅴ视频一区日韩精品| 国产91富婆露脸刺激对白| 国产一区在线看| 成人毛片在线观看| 99精品桃花视频在线观看| 高潮精品一区videoshd| 成人国产精品免费观看动漫 | 99国内精品久久| 成人av免费网站| 97久久超碰国产精品| 色综合天天综合网国产成人综合天 | 国产视频911| 久久精品人人做人人爽人人| 精品国产露脸精彩对白| 亚洲精品在线三区| 亚洲人成亚洲人成在线观看图片| 亚洲高清免费观看高清完整版在线观看| 亚洲人成在线观看一区二区| 亚洲主播在线播放| 日韩欧美www| 久久女同性恋中文字幕| 久久精品二区亚洲w码| 不卡一区中文字幕| 综合色天天鬼久久鬼色| 色综合天天综合色综合av| 亚洲蜜桃精久久久久久久| 欧美日韩精品高清| 国内久久精品视频| 一区二区三区在线视频免费观看| 国产一区二区精品久久| 伊人色综合久久天天人手人婷| 欧美三级乱人伦电影| 国产成人精品免费| 亚洲高清在线视频| 欧美精品一区二区三区在线| 99精品国产视频| 午夜精品影院在线观看| 国产欧美精品在线观看| 欧美日韩国产天堂| 国产成人精品综合在线观看 | 精品久久人人做人人爱| 久久电影网站中文字幕| 一区二区三区在线观看欧美 | 日韩一级高清毛片| 色噜噜偷拍精品综合在线| 亚洲福利视频三区| 一区二区三区日韩欧美精品| 精品电影一区二区| 制服.丝袜.亚洲.另类.中文| 91美女蜜桃在线| 国产a级毛片一区| 国产综合成人久久大片91| 午夜精品久久一牛影视| 亚洲欧美日韩在线播放| 精品美女在线播放| 日韩精品一区二区三区在线| 色综合久久久久| 色网站国产精品| 91蜜桃传媒精品久久久一区二区| 成人涩涩免费视频| 国产老妇另类xxxxx| 国产一区二区按摩在线观看| 视频一区欧美精品| 日韩精品高清不卡| 亚洲1区2区3区4区| 亚洲成人av免费| 亚洲电影你懂得| 午夜一区二区三区在线观看| 亚洲一二三级电影| 亚洲成人你懂的| 午夜精品久久久久久久99樱桃 | 裸体一区二区三区| 青青草国产成人av片免费| 日韩av一二三| 久久er精品视频| 国内精品写真在线观看| 久久99精品久久久久婷婷| 久久狠狠亚洲综合| 国内精品国产成人国产三级粉色| 国内精品嫩模私拍在线| 成人综合在线观看| 成人亚洲精品久久久久软件| 国产白丝精品91爽爽久久| 国内国产精品久久| 国产成人8x视频一区二区 | 亚洲午夜三级在线| 欧美大肚乱孕交hd孕妇| 久久久久久久久久久电影| 尤物av一区二区| 日韩电影在线观看一区| 久久噜噜亚洲综合| 日韩视频永久免费| 国产精品午夜免费| 久久综合精品国产一区二区三区| 欧美电视剧免费观看| 欧美日韩国产一级| 国产无人区一区二区三区| 国产亚洲精久久久久久| 亚洲蜜臀av乱码久久精品| 亚洲天堂中文字幕| 蜜芽一区二区三区| 韩国精品在线观看| 欧美日韩黄色一区二区| 日韩一区二区免费在线观看| 欧美日韩高清在线播放| 中文欧美字幕免费| 中文字幕日韩一区二区| 日本不卡不码高清免费观看| 日本成人中文字幕| jlzzjlzz亚洲日本少妇| 91在线观看地址| 国产亚洲欧美色| 欧美在线短视频|