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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? diskmain.cpp

?? 6410BSP3
?? CPP
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this sample source code is subject to the terms of the Microsoft
// license agreement under which you licensed this sample source code. If
// you did not accept the terms of the license agreement, you are not
// authorized to use this sample source code. For the terms of the license,
// please see the license agreement between you and Microsoft or, if applicable,
// see the LICENSE.RTF on your install media or the root of your tools installation.
// THE SAMPLE SOURCE CODE IS PROVIDED "AS IS", WITH NO WARRANTIES.
//
#include <diskmain.h>
#include "csgreq.h"

/*++

Module Name:
    diskmain.cpp

Abstract:
    Base ATA/ATAPI device abstraction.

Revision History:

--*/

static HANDLE g_hTestUnitReadyThread = NULL;

// ----------------------------------------------------------------------------
// Function: CDisk
//     Constructor
//
// Parameters:
//     None
// ----------------------------------------------------------------------------

CDisk::CDisk(
    )
{
    // empty
}

// ----------------------------------------------------------------------------
// Function: CDisk
//     Constructor
//
// Parameters:
//     hKey -
// ----------------------------------------------------------------------------

CDisk::CDisk(
    HKEY hKey
    )
{
    m_dwDeviceFlags = 0;
    m_pNextDisk = NULL;
    m_pATAReg = NULL;
    m_pATARegAlt = NULL;
    m_dwDevice = 0;
    m_hDevKey = hKey;
    m_dwDeviceId = 0;
    m_dwPort = 0;
    m_f16Bit = FALSE;
    m_fUseLBA48 = FALSE;
    m_fAtapiDevice = FALSE;
    m_fInterruptSupported = FALSE;
    m_szDiskName = NULL;
    m_fDMAActive = FALSE;
    m_dwOpenCount = 0;
    m_dwUnitReadyTime = 0;
    m_dwStateFlag = 0;
    m_dwLastCheckTime = 0;
    m_dwStride = 1;
    m_pDiskPower = NULL;
    m_rgbDoubleBuffer = NULL;
    m_wNextByte = 0xFFFF;

    m_pPort = NULL;

    // init generic structures
    InitializeCriticalSection(&m_csDisk);
    memset(&m_Id, 0, sizeof(IDENTIFY_DATA));
    memset(&m_DiskInfo, 0, sizeof(DISK_INFO));
    memset(&m_InqData, 0, sizeof(INQUIRY_DATA));
    m_dwCurrentUDMAMode = 0;
    m_pDMAVirtualAddress = NULL;
    
}

// ----------------------------------------------------------------------------
// Function: ~CDisk
//     Destructor
//
// Parameters:
//     None
// ----------------------------------------------------------------------------

CDisk::~CDisk(
    )
{
    if (m_hDevKey) {
        RegCloseKey(m_hDevKey);
    }

    if(m_pDiskPower != NULL) {
        delete m_pDiskPower;
    }

    DeleteCriticalSection(&m_csDisk);

    // deallocate double buffer, if present
    if (NULL != m_rgbDoubleBuffer) {
        LocalFree((HLOCAL)m_rgbDoubleBuffer);
    }

    // deallocate sterile I/O request, if present
    if (NULL != m_pSterileIoRequest) {
        LocalFree((HLOCAL)m_pSterileIoRequest);
    }
    if (m_pPort->m_pDskReg[m_dwDeviceId]->dwEnablePDMA)
    {
        HalFreeCommonBuffer( NULL, 0, m_DMAPhyaddress, m_pDMAVirtualAddress, FALSE );    
    }

}

// ----------------------------------------------------------------------------
// Function: StallExecution
//     Stall execution for the specified period of time
//
// Parameters:
//     dwTime -
// ----------------------------------------------------------------------------

void
CDisk::StallExecution(
    DWORD dwTime
    )
{
    if ((dwTime >= 100) && (m_dwDeviceFlags & DFLAGS_DEVICE_CDROM)) {
        Sleep (dwTime / 100);
    }
    else {
        ::StallExecution(dwTime * 10);
    }
}

#define HELPER_

// These functions should be inlined or converted to macros
void CDisk::TakeCS()                    { EnterCriticalSection(&m_csDisk); }
void CDisk::ReleaseCS()                 { LeaveCriticalSection(&m_csDisk); }
void CDisk::Open()                      { InterlockedIncrement((LONG *)&m_dwOpenCount); }
void CDisk::Close()                     { InterlockedDecrement((LONG *)&m_dwOpenCount); }
BOOL CDisk::IsAtapiDevice()             { return m_fAtapiDevice; }
BOOL CDisk::IsCDRomDevice()             { return (((m_Id.GeneralConfiguration >> 8) & 0x1f) == ATA_IDDEVICE_CDROM); }
BOOL CDisk::IsDVDROMDevice()            { return TRUE; }
BOOL CDisk::IsDiskDevice()              { return (((m_Id.GeneralConfiguration >> 8) & 0x1f) == ATA_IDDEVICE_DISK); }
BOOL CDisk::IsRemoveableDevice()        { return (m_Id.GeneralConfiguration & IDE_IDDATA_REMOVABLE); }
BOOL CDisk::IsDMASupported()            { return ((m_Id.Capabilities & IDENTIFY_CAPABILITIES_DMA_SUPPORTED) && m_fDMAActive); }
BOOL CDisk::IsDRQTypeIRQ()              { return ((m_Id.GeneralConfiguration >> 5) & 0x0003) == ATA_DRQTYPE_INTRQ; }
WORD CDisk::GetPacketSize()             { return m_Id.GeneralConfiguration & 0x0003 ? 16 : 12; }
BOOL CDisk::IsValidCommandSupportInfo() { return ((m_Id.CommandSetSupported2 & (1 << 14)) && !(m_Id.CommandSetSupported2 & (1 << 15))); }
BOOL CDisk::IsWriteCacheSupported()     { return ((m_Id.CommandSetSupported1 & COMMAND_SET_WRITE_CACHE_SUPPORTED) && IsValidCommandSupportInfo()); }
BOOL CDisk::IsPMSupported()             { return (m_Id.CommandSetSupported1 & COMMAND_SET_POWER_MANAGEMENT_SUPPORTED && IsValidCommandSupportInfo()); }
BOOL CDisk::IsPMEnabled()               { return (IsPMSupported() && (m_Id.CommandSetFeatureEnabled1 & COMMAND_SET_POWER_MANAGEMENT_ENABLED)); }

// These functions are called (1x) in atamain and should be inlined
void CDisk::SetActiveKey(TCHAR *szActiveKey)
{
    wcsncpy(m_szActiveKey, szActiveKey, MAX_PATH - 1);
    m_szActiveKey[MAX_PATH - 1] = 0;
}

void CDisk::SetDeviceKey(TCHAR *szDeviceKey)
{
    wcsncpy(m_szDeviceKey, szDeviceKey, MAX_PATH - 1);
    m_szDeviceKey[MAX_PATH - 1] = 0;
}

#define _HELPER

// ----------------------------------------------------------------------------
// Function: InitController
//     Reset the controller and determine whether a device is present on the
//     channel; if a device is present, then query and store its capabilities
//
// Parameters:
//     fForce -
// ----------------------------------------------------------------------------

BOOL
CDisk::InitController(
    BOOL fForce
    )
{
    BOOL bRet = TRUE;

    // if the controller has not already been reset, then perform a soft-reset
    // to enable the channel

    if (!(m_dwDeviceFlags & DFLAGS_DEVICE_INITIALIZED)) {

        // perform a soft-reset on the controller; if we don't do this, then
        // we won't be able to detect whether or not devices are present on the
        // channel

        bRet = ResetController(FALSE);
        if (!bRet) {
            goto exit;
        }

        // if interrupt is supported, enable interrupt

        if (m_fInterruptSupported) {
            SelectDevice();
            WriteAltDriveController(ATA_CTRL_ENABLE_INTR);
            EnableInterrupt();
        }
    }

    // issue IDENTIFY DEVICE and/or IDENTIFY PACKET DEVICE
    bRet = Identify();
    if (!bRet) {
        DEBUGMSG(ZONE_INIT|ZONE_ERROR, (_T(
            "Atapi!CDisk::InitController> Device did not respond to identify\r\n"
            )));
        goto exit;
    }
    else {
        DEBUGMSG(ZONE_INIT|ZONE_ERROR, (_T(
            "Atapi!CDisk::InitController> Device responded to identify\r\n"
            )));
        m_dwDeviceFlags |= DFLAGS_DEVICE_INITIALIZED;
    }

exit:;
    return bRet;
}

// ----------------------------------------------------------------------------
// Function: ConfigureRegisterBlock
//     This function is called by DSK_Init before any other CDisk function to
//     set up the register block.
//
// Parameters:
//     dwStride -
// ----------------------------------------------------------------------------

VOID
CDisk::ConfigureRegisterBlock(
    DWORD dwStride
    )
{
    m_dwStride = dwStride;
    m_dwDataDrvCtrlOffset = ATA_REG_DATA * dwStride;
    m_dwFeatureErrorOffset = ATA_REG_FEATURE * dwStride;
    m_dwSectCntReasonOffset = ATA_REG_SECT_CNT * dwStride;
    m_dwSectNumOffset = ATA_REG_SECT_NUM * dwStride;
    m_dwDrvHeadOffset = ATA_REG_DRV_HEAD * dwStride;
    m_dwCommandStatusOffset = ATA_REG_COMMAND * dwStride;
    m_dwByteCountLowOffset = ATA_REG_BYTECOUNTLOW * dwStride;
    m_dwByteCountHighOffset = ATA_REG_BYTECOUNTHIGH * dwStride;
    m_dwAltStatusOffset = ATA_REG_ALT_STATUS_CS1 * dwStride;
    m_dwAltDrvCtrl = ATA_REG_DRV_CTRL_CS1 * dwStride;
}

// ----------------------------------------------------------------------------
// Function: Init
//     This function is called by the IDE/ATA controller enumerator to trigger
//     the initialization of a device
//
// Parameters:
//     hActiveKey -
// ----------------------------------------------------------------------------

BOOL
CDisk::Init(
    HKEY hActiveKey
    )
{
    BOOL fRet = FALSE;
    // replicate CDisk::ReadRegistry

    m_dwWaitCheckIter = m_pPort->m_pController->m_pIdeReg->dwStatusPollCycles;
    m_dwWaitSampleTimes = m_pPort->m_pController->m_pIdeReg->dwStatusPollsPerCycle;
    m_dwWaitStallTime = m_pPort->m_pController->m_pIdeReg->dwStatusPollCyclePause;

    m_dwDiskIoTimeOut = DEFAULT_DISK_IO_TIME_OUT;

    // replicate CDisk::ReadSettings

    m_dwUnitReadyTime = DEFAULT_MEDIA_CHECK_TIME;

    // if DMA=2 and this is not an ATAPI device, then we'll set m_fDMAActive in Identify
    if (1 == m_pPort->m_pDskReg[m_dwDeviceId]->dwDMA) { // 0=PIO, 1=DMA, 2=ATA DMA only
        m_fDMAActive = TRUE;
    }
    m_dwDMAAlign = m_pPort->m_pController->m_pIdeReg->dwDMAAlignment;

    // m_dwDeviceFlags |= DFLAGS_DEVICE_ISDVD; this is ignored

    if (m_pPort->m_pDskReg[m_dwDeviceId]->dwInterruptDriven) {
        m_fInterruptSupported = TRUE;
    }

    // initialize controller

    if (!InitController(TRUE)) {
        goto exit;
    }

    if (m_Id.CommandSetSupported1 & 0x20) {
        if (SetWriteCacheMode(m_pPort->m_pDskReg[m_dwDeviceId]->dwWriteCache)) {
            if (m_pPort->m_pDskReg[m_dwDeviceId]->dwWriteCache) {
                m_dwDeviceFlags |= DFLAGS_USE_WRITE_CACHE;
                DEBUGMSG(ZONE_INIT, (_T(
                    "Atapi!CDisk::Init> Enabled write cache\r\n"
                    )));
            }
            else {
                m_dwDeviceFlags &= ~DFLAGS_USE_WRITE_CACHE;
                DEBUGMSG(ZONE_INIT, (_T(
                    "Atapi!CDisk::Init> Disabled on device write cache\r\n"
                    )));
            }
        }
        else {
            DEBUGMSG(ZONE_INIT, (_T(
                "Atapi!CDisk::Init> Failed to set write cache mode\r\n"
                )));
        }
    }

    // set read look-ahead, if read look-ahead supported

    if ((m_Id.CommandSetSupported1 & 0x40) && m_pPort->m_pDskReg[m_dwDeviceId]->dwLookAhead) {
        if (SetLookAhead()) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Enabled look-ahead\r\n")));
        }
        else {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Failed to enable look-ahead\r\n")));
        }
    }

    // set transfer mode, if a specific transfer mode was specified in the
    // device's instance key

    BYTE bTransferMode = (BYTE)m_pPort->m_pDskReg[m_dwDeviceId]->dwTransferMode;
    if (0xFF != bTransferMode) {
        if (0x00 == bTransferMode) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating PIO default mode (0x%x)\r\n"), bTransferMode));
        }
        else if (0x01 == bTransferMode) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating PIO default mode (0x%x) with IORDY disabled\r\n"), bTransferMode));
        }
        else if ((bTransferMode & 0xF8) == 0x08) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating PIO flow control mode %d (0x%x)\r\n"), (bTransferMode & 0x07), bTransferMode));
        }
        else if ((bTransferMode & 0xF0) == 0x20) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating multiword DMA mode %d (0x%x)\r\n"), (bTransferMode & 0x07), bTransferMode));
        }
        else if ((bTransferMode & 0xF0) == 0x40) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating ultra DMA mode %d (0x%x)\r\n"), (bTransferMode & 0x07), bTransferMode));
        }
        else {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Activating unknown transfer mode (0x%x)\r\n"), bTransferMode));
        }
        // bTransferMode is a valid transfer mode
        if (!SetTransferMode(bTransferMode)) {
            DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Failed to set transfer mode\r\n")));
        }
    }

    if (IsDMASupported()) {
        DEBUGMSG(ZONE_INIT, (_T("Atapi!CDisk::Init> Enabled DMA\r\n")));
    }

    fRet = TRUE;

exit:;
    return fRet;
}

// ----------------------------------------------------------------------------
// Function: ResetController
//     Implement ATA/ATAPI-6 R3B 9.2 (Software reset protocol)
//
// Parameters:

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲摸摸操操av| 亚洲一区二区综合| 在线视频你懂得一区二区三区| 日韩va亚洲va欧美va久久| 中文字幕欧美区| 日韩色在线观看| 94色蜜桃网一区二区三区| 日韩在线一区二区三区| 亚洲欧美另类在线| 精品国产一区二区三区av性色| 日本二三区不卡| 国产成人综合精品三级| 麻豆视频观看网址久久| 亚洲成人第一页| 亚洲欧美色综合| 中文字幕乱码亚洲精品一区| 精品国产成人在线影院| 欧美精品色综合| 在线观看av不卡| 91在线观看一区二区| 国产精品99久久久久久久女警| 蜜臀久久99精品久久久久宅男| 亚洲成在人线免费| 亚洲精品国产精品乱码不99| 中文字幕高清一区| 国产亚洲一区二区三区在线观看| 日韩欧美国产成人一区二区| 这里是久久伊人| 6080国产精品一区二区| 欧美日韩国产高清一区二区三区| 色婷婷亚洲一区二区三区| 成人av免费观看| 成人av网站在线观看免费| 成人综合日日夜夜| 国产传媒一区在线| 国产一区二区按摩在线观看| 精品写真视频在线观看| 激情六月婷婷久久| 极品少妇一区二区三区精品视频| 全国精品久久少妇| 久久99日本精品| 国产一区二区三区不卡在线观看| 极品少妇xxxx精品少妇偷拍| 激情综合色综合久久综合| 国产一本一道久久香蕉| 国产精品99久久久久久久vr| 国产高清精品网站| 成人禁用看黄a在线| 懂色av一区二区三区蜜臀| 成人听书哪个软件好| 成人av在线资源网站| 97se亚洲国产综合自在线观| 在线视频中文字幕一区二区| 欧美色男人天堂| 欧美一区二区三区在线观看视频| 日韩欧美一区二区在线视频| 精品久久久三级丝袜| 国产亚洲精品资源在线26u| 国产精品女主播av| 亚洲午夜视频在线| 日本视频在线一区| 国产成人在线观看| 91久久久免费一区二区| 3751色影院一区二区三区| 精品国内片67194| 欧美激情一区不卡| 亚洲午夜激情网站| 久久99国产精品久久| caoporm超碰国产精品| 在线观看亚洲一区| 日韩欧美成人激情| 国产精品高潮呻吟| 秋霞影院一区二区| 大桥未久av一区二区三区中文| 色婷婷综合久久久| 日韩精品一区二区三区swag| 中文幕一区二区三区久久蜜桃| 一区二区三区日韩精品| 看电视剧不卡顿的网站| 99久久精品99国产精品| 欧美一级片免费看| 中文字幕高清不卡| 日韩中文字幕不卡| av高清不卡在线| 91精品国产91热久久久做人人| 欧美高清在线精品一区| 日日骚欧美日韩| 成人99免费视频| 精品国产免费人成电影在线观看四季 | 天天综合色天天综合| 国产精品一二三区| 欧美色视频在线观看| 国产欧美视频在线观看| 视频一区二区中文字幕| 成人99免费视频| 欧美tickling挠脚心丨vk| 亚洲精品国产精品乱码不99| 国产精品小仙女| 欧美一区在线视频| 亚洲精品国产视频| 粉嫩一区二区三区在线看 | 中文字幕第一区| 蜜桃视频一区二区| 欧美三级蜜桃2在线观看| 欧美zozozo| 日本美女一区二区三区| 91亚洲永久精品| 久热成人在线视频| 成a人片亚洲日本久久| 欧美猛男gaygay网站| 久久久久国产精品免费免费搜索| 亚洲国产精品天堂| www.欧美精品一二区| 亚洲丰满少妇videoshd| jlzzjlzz亚洲女人18| 欧美不卡激情三级在线观看| 亚洲综合成人在线| 亚洲国产aⅴ成人精品无吗| 国产精品白丝jk黑袜喷水| 日韩一区二区免费在线电影| 亚洲精选免费视频| 国产精品一区二区三区99| 欧美高清hd18日本| 一区二区三区电影在线播| 波多野结衣的一区二区三区| 2020日本不卡一区二区视频| 日韩高清不卡一区二区| 欧美亚洲一区二区在线观看| 亚洲视频一二区| 成人午夜av电影| 精品人在线二区三区| 麻豆精品一区二区三区| 日韩欧美中文字幕公布| 老司机精品视频导航| 91麻豆精品国产91| 日韩av一区二区三区四区| 制服丝袜一区二区三区| 青娱乐精品视频| 91精品国产一区二区三区蜜臀| 亚洲自拍与偷拍| 欧洲亚洲国产日韩| 亚洲一区在线视频| 欧美日韩精品一区二区三区| 婷婷久久综合九色综合绿巨人 | 2019国产精品| 久久99精品网久久| 国产婷婷色一区二区三区| 国产一区二区三区在线看麻豆| 久久久久一区二区三区四区| 国产成人午夜精品影院观看视频| 国产欧美精品一区二区三区四区| 国产91高潮流白浆在线麻豆| 国产精品二区一区二区aⅴ污介绍| 91视频在线观看免费| 亚洲成av人片| 欧美mv日韩mv国产| 国产成a人亚洲精| 亚洲精品欧美激情| 欧美一区二区三区四区高清| 极品销魂美女一区二区三区| 欧美极品xxx| 色哟哟在线观看一区二区三区| 亚洲国产精品久久一线不卡| 欧美老肥妇做.爰bbww| 香蕉久久一区二区不卡无毒影院| 欧美一区二区三区四区高清| 国产成人一区在线| 一区二区三区四区亚洲| 欧美美女黄视频| 国产一区啦啦啦在线观看| 中文字幕一区二区三区精华液| 欧美日韩精品系列| 精品一区二区免费视频| 亚洲欧美自拍偷拍| 欧美日韩aaaaaa| 麻豆91小视频| 日本一区二区成人在线| 欧美三片在线视频观看| 国内外精品视频| 亚洲综合久久av| 精品久久久久久久久久久久包黑料 | 亚洲国产精品黑人久久久| 91女神在线视频| 看片的网站亚洲| 亚洲视频每日更新| 精品国产一区二区在线观看| 91一区二区三区在线观看| 免费观看在线综合| 成人免费一区二区三区在线观看| 欧美一区二区久久| 菠萝蜜视频在线观看一区| 日本少妇一区二区| 亚洲欧美电影院| 欧美xxxxx牲另类人与| 欧美综合一区二区| 国产盗摄女厕一区二区三区| 成人av综合在线| 欧美精品自拍偷拍| 亚洲婷婷在线视频| 麻豆成人免费电影|