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

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

?? atamain.h

?? 三星2410,WinCE5.0下的硬盤IDE驅動.
?? H
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//

/*++

Module Name:
    atamain.h

Abstract:
    ATA/ATAPI device driver definitions.

Revision History:

--*/

#ifndef _ATAMAIN_H_
#define _ATAMAIN_H_

#include <windows.h>
#include <ceddk.h>
#include <devload.h>
#include <ddkreg.h>
#include <nkintr.h>
#include <celog.h>
#include <diskio.h>
#include <atapi2.h>
#include <cdioctl.h>
#include <dvdioctl.h>
#include <atapiio.h>
#include <helper.h>
#include <debug.h>
#include <diskmain.h>
#include <storemgr.h>

#define MAX_RESET_ATTEMPTS                256
#define MAX_SECT_PER_COMMAND              256
#define MAX_CD_SECT_PER_COMMAND           32

// IDE/ATA controller subkey names for device enumeration
#define REG_KEY_PRIMARY_MASTER            (_T("Device0"))
#define REG_KEY_PRIMARY_SLAVE             (_T("Device1"))
#define REG_KEY_SECONDARY_MASTER          (_T("Device2"))
#define REG_KEY_SECONDARY_SLAVE           (_T("Device3"))

// IDE/ATA controller registry value definitions
#define REG_VAL_IDE_LEGACY                (_T("Legacy"))                // {0, 1}; 1 => use legacy IRQ settings, i.e., primary 14, secondary 15
#define REG_VAL_IDE_IRQ                   (_T("Irq"))                   // IDE/ATA channel's IRQ
#define REG_VAL_IDE_SYSINTR               (_T("SysIntr"))               // IDE/ATA channel's SysIntr
#define REG_VAL_IDE_VENDORID              (_T("VendorID"))              // vendor id; identify controller; is this needed?
#define REG_VAL_IDE_DMAALIGNMENT          (_T("DMAAlignment"))          // DMA alignment
#define REG_VAL_IDE_SOFTRESETTIMEOUT      (_T("SoftResetTimeout"))      // seconds; ATA/ATAPI specification default is 31 seconds (too long)
#define REG_VAL_IDE_STATUSPOLLCYCLES      (_T("StatusPollCycles"))      // number of Status register poll cycles
#define REG_VAL_IDE_STATUSPOLLSPERCYCLE   (_T("StatusPollsPerCycle"))   // number of Status registers polls per cycle
#define REG_VAL_IDE_STATUSPOLLCYCLEPAUSE  (_T("StatusPollCyclePause"))  // number of milliseconds to wait between between poll cycles
#define REG_VAL_IDE_SPAWNFUNCTION         (_T("SpawnFunction"))         // name of function to create controller-specific CDisk instance
#define REG_VAL_IDE_ISRDLL                (_T("IsrDll"))                // name of installable ISR DLL
#define REG_VAL_IDE_ISRHANDLER            (_T("IsrHandler"))            // name of ISR handler in ISR DLL
#define REG_VAL_IDE_DEVICECONTROLOFFSET   (_T("DeviceControlOffset"))   // base ATA register offset of device control I/O port
#define REG_VAL_IDE_ALTERNATESTATUSOFFSET (_T("AlternateStatusOffset")) // base ATA register offset of alternate status I/O port
#define REG_VAL_IDE_REGISTERSTRIDE        (_T("RegisterStride"))        // number of bytes between ATA registers

// IDE_ registry value set
typedef struct _IDEREG {
    DWORD dwLegacy;
    DWORD dwIrq;
    DWORD dwSysIntr;
    DWORD dwVendorId;
    DWORD dwDMAAlignment;
    DWORD dwSoftResetTimeout;
    DWORD dwStatusPollCycles;
    DWORD dwStatusPollsPerCycle;
    DWORD dwStatusPollCyclePause;
    PTSTR pszSpawnFunction;
    PTSTR pszIsrDll;
    PTSTR pszIsrHandler;
    DWORD dwDeviceControlOffset;
    DWORD dwAlternateStatusOffset;
    DWORD dwRegisterStride;
} IDEREG, *PIDEREG;

// Populate IDE_ registry value set from registry
BOOL
GetIDERegistryValueSet(
    HKEY hIDEInstanceKey,
    PIDEREG pIdeReg
    );

// ATA/ATAPI device registry value definitions
#define REG_VAL_DSK_PORT             (_T("Port"))             // heap address of associated CPort instance
#define REG_VAL_DSK_INTERRUPTDRIVEN  (_T("InterruptDriven"))  // {0, 1}; 0 => polled I/O, 1 => interrupt I/O
#define REG_VAL_DSK_DMA              (_T("DMA"))              // {0, 1}; 0 => PIO, 1 => DMA, 2 => ATA DMA only
#define REG_VAL_DSK_DOUBLEBUFFERSIZE (_T("DoubleBufferSize")) // {512, ..., 131072}; scatter/gather processing
#define REG_VAL_DSK_DRQDATABLOCKSIZE (_T("DrqDataBlockSize")) // {512}; when we support R/W multiple, increase
#define REG_VAL_DSK_WRITECACHE       (_T("WriteCache"))       // {0, 1}; 0 => disable write cache; 1 => enable write cache
#define REG_VAL_DSK_LOOKAHEAD        (_T("LookAhead"))        // {0, 1}; 0 => disable look-ahead; 1 => enable look-ahead
#define REG_VAL_DSK_DEVICEID         (_T("DeviceId"))         // initially (0, 1, 2, 3), then resolve re-written as (0, 1); 0 => master, 1 => slave
#define REG_VAL_DSK_TRANSFERMODE     (_T("TransferMode"))     // 1 byte transfer mode encoding; see ATA/ATAPI 8.46.11; 0xFF is default mode

#define REG_VAL_DSK_DOUBLEBUFFERSIZE_MAX 131072
#define REG_VAL_DSK_DOUBLEBUFFERSIZE_MIN 512

// DSK_ registry value set
typedef struct _DSKREG {
    DWORD dwInterruptDriven;
    DWORD dwDMA;
    DWORD dwDoubleBufferSize;
    DWORD dwDrqDataBlockSize;
    DWORD dwWriteCache;
    DWORD dwLookAhead;
    DWORD dwDeviceId;
    DWORD dwTransferMode;
} DSKREG, *PDSKREG;

// Populate DSK_ registry value set from registry
BOOL
GetDSKRegistryValueSet(
    HKEY hDSKInstanceKey,
    PDSKREG pDskReg
    );

// Registry configuration value names
#define REG_VALUE_IOBASEADDRESS     TEXT("IOBaseAddress")    // not used
#define REG_VALUE_BMR               TEXT("BMR")              // not used
#define REG_VALUE_INTERRUPT         TEXT("Interrupt")        // not used
#define REG_VALUE_IRQ               TEXT("IRQ")              // not used
#define REG_VALUE_DVD               TEXT("DVD")              // read in diskmain.cpp!ReadSettings; not used
#define REG_VALUE_CHS               TEXT("CHSMode")          // read in diskmain.cpp!Identify
#define REG_VALUE_SYSINTR           TEXT("SysIntr")          // not used, but should be used in atamain.cpp
#define REG_VALUE_INTENABLE         TEXT("IntEnable")        // read in diskmain.cpp!ReadSettings; should be read in atamain.cpp
#define REG_VALUE_HDPROFILE         TEXT("HDProfile")        // read in diskmain.cpp!GetDeviceInfo; why can't this just be "StorageManagerProfile"?
#define REG_VALUE_CDPROFILE         TEXT("CDProfile")        // read in diskmain.cpp!GetDeviceInfo; why can't this just be "StorageManagerProfile"?
#define REG_VALUE_PCMCIAPROFILE     TEXT("PCMCIA")           // not used
#define REG_VALUE_ENABLE_WRITECACHE TEXT("EnableWriteCache") // read in diskmain.cpp!ReadSettings

// Registry configurable DMA alignment
#define REG_VALUE_DMA_ALIGN         TEXT("DMAAlignment")     // read in diskmain.cpp!ReadSettings; should be read in atamain.cpp
#define DEFAULT_DMA_ALIGN_VALUE     4

// Registry configurable timeout values
#define REG_VALUE_MEDIACHECKTIME    TEXT("MediaCheckTime")      // read in diskmain.cpp!ReadSettings
#define REG_VALUE_WAIT_CHECK_ITER   TEXT("WaitCheckIterations") // read in diskmain.cpp!ReadRegistry; why?
#define REG_VALUE_WAIT_SAMPLE_TIMES TEXT("WaitSampleTimes")     // read in diskmain.cpp!ReadRegistry; why?
#define REG_VALUE_WAIT_STALL_TIME   TEXT("WaitStallTime")       // read in diskmain.cpp!ReadRegistry; why?
#define REG_VALUE_DISK_IO_TIME_OUT  TEXT("DiskIOTimeOut")       // read in diskmain.cpp!ReadRegistry; why?

#define DEFAULT_MEDIA_CHECK_TIME    5000
#define DEFAULT_WAIT_CHECK_ITER     2000
#define DEFAULT_WAIT_SAMPLE_TIMES   100
#define DEFAULT_WAIT_STALL_TIME     400
#define DEFAULT_DISK_IO_TIME_OUT    20000

// "Settings" registry value
#define REG_VALUE_SETTINGS          TEXT("Settings")
#define REG_VALUE_DMA               TEXT("DMA")
#define ATA_SETTINGS_HDDMA          0x1 // Hard disk DMA enabled
#define ATA_SETTINGS_CDDMA          0x4 // CD-ROM/DVD DMA enabled
#define ATA_SETTINGS_HDINT          0x2 // Hard disk interrupt enabled
#define ATA_SETTINGS_CDINT          0x8 // CD-ROM/DVD interrupt enabled

#define REG_VALUE_PORT              (_T("Port"))

// Helper function prototype
BOOL
AtaIsValidDisk(
    CDisk *pDisk
    );

// IDE/ATA bus abstraction; Not needed

#define MAX_ATA_CNTRL              8
#define MAX_ATA_PORT               (MAX_ATA_CNTRL*2)
#define MAX_ATA_DEV                (MAX_ATA_PORT*2)
#define MAX_ATA_DEVICES            16
#define MAX_DEVICES_PER_CONTROLLER 4

class CIDEBUS {
  public:
    // member variables
    HANDLE         m_hDevice[MAX_DEVICES_PER_CONTROLLER];  // device activation handles
    LPWSTR         m_szDevice[MAX_DEVICES_PER_CONTROLLER]; // device key paths
    DDKWINDOWINFO  m_dwi;                                  // resource information for devices attached to the controller
    PIDEREG        m_pIdeReg;                              // IDE_ registry value set
    CPort         *m_pPrimaryPort;                         // I/O port of primary channel
    CPort         *m_pSecondaryPort;                       // I/O port of secondary channel
    // constructors/destructors
    CIDEBUS();
    ~CIDEBUS();
};

// Bus master definitions
#define BM_STATUS_SIMPLEX 0x80
#define BM_STATUS_D1_DMA  0x40
#define BM_STATUS_D0_DMA  0x20
#define BM_STATUS_INTR    0x04
#define BM_STATUS_ERROR   0x02
#define BM_STATUS_ACTIVE  0x01

// DMA support structures

typedef struct {
    LPBYTE pDstAddress;
    LPBYTE pSrcAddress;
    DWORD dwSize;
} SGCopyTable, *PSGCopyTable;

typedef struct {
    DWORD dwVirtualAddress;
    DWORD dwPhysicalAddress;
    DWORD dwFlags;
    DWORD dwSize;
} MEMTable, *PMEMTable;

typedef struct {
    DWORD physAddr;
    USHORT size;
    USHORT EOTpad;
} DMATable, *PDMATable;

#define MIN_PHYS_PAGES 4

typedef struct _PhysTable {
    LPBYTE pVirtualAddress;
    LPBYTE pPhysicalAddress;
} PhysTable, *PPhysTable;

// IDE/ATA channel abstraction
class CPort {
  public:
    // member variables
    CIDEBUS          *m_pController;   // parent
    CRITICAL_SECTION  m_csPort;        // protect access to I/O ports
    DWORD             m_fInitialized;  // whether port has been initialized by IDE driver
    DWORD             m_dwFlag;        // m_dwFlag
    DWORD             m_dwRegBase;     // base virtual address of command I/O port
    DWORD             m_dwRegAlt;      // base virtual address of status I/O port
    DWORD             m_dwBMR;         // base virtual address of bus master I/O port
    DWORD             m_dwBMRStatic;   // base physical address of bus master I/O port
    HANDLE            m_hIRQEvent;     // IRQ event handle
    PDSKREG           m_pDskReg[2];    // DSK_ registry value set for master, slave
    DWORD             m_dwSysIntr;     // SysIntr associated with ATA channel
    DWORD             m_dwIrq;         // IRQ associated with ATA channel
    // not used
    HANDLE            m_hThread;       // not used; IST handle
    HANDLE            m_pDisk[2];      // only used by Promise; store handle?
    // constructors/destructors
    CPort(CIDEBUS *pParent);
    ~CPort();
    // member functions
    void TakeCS();
    void ReleaseCS();
    void PrintInfo();
};

#endif _ATAMAIN_H_

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品国产| 一区二区视频在线看| 麻豆国产精品777777在线| 欧美日韩精品综合在线| 一区二区三区日韩欧美| 欧美区一区二区三区| 麻豆一区二区在线| 久久久久久亚洲综合影院红桃| 国产高清精品网站| 日韩一区欧美小说| 欧美最新大片在线看| 日韩精品欧美成人高清一区二区| 欧美一级理论片| 国产激情视频一区二区三区欧美| 国产精品久久久久久久久免费丝袜 | 99久久婷婷国产综合精品| 国产精品久久国产精麻豆99网站| 色婷婷av一区二区三区软件 | 亚洲高清在线精品| 日韩一区二区视频在线观看| 国内久久精品视频| 中文字幕在线免费不卡| 欧美美女直播网站| 国产一区视频在线看| 日韩理论片网站| 制服丝袜国产精品| 高清shemale亚洲人妖| 亚洲大片精品永久免费| 精品日韩欧美一区二区| 色综合久久综合| 激情综合网av| 悠悠色在线精品| 337p粉嫩大胆噜噜噜噜噜91av| 成人av网站免费| 日韩福利视频网| 亚洲视频免费在线观看| 日韩精品一区二区三区中文精品| 99视频一区二区| 老司机午夜精品| 亚洲精品久久7777| 久久久亚洲午夜电影| 欧美三级日韩三级国产三级| 国产精品99久久久久久似苏梦涵 | 欧美日韩激情在线| 国产久卡久卡久卡久卡视频精品| 亚洲电影你懂得| 国产精品五月天| 日韩欧美在线观看一区二区三区| 色偷偷久久一区二区三区| 精品亚洲aⅴ乱码一区二区三区| 亚洲精品视频自拍| 中文子幕无线码一区tr| 欧美成人国产一区二区| 欧美日韩成人一区| 色综合久久九月婷婷色综合| 国产精品一区久久久久| 日产精品久久久久久久性色| 亚洲精品菠萝久久久久久久| 久久久久久99久久久精品网站| 欧美日本视频在线| 欧美性一二三区| 色综合天天综合狠狠| 国产成人精品影院| 国产精品99久久久久久久女警| 久久精品国产色蜜蜜麻豆| 日韩精品乱码av一区二区| 一区二区三区成人| 亚洲美女视频在线| 亚洲色图色小说| 一区在线观看免费| 国产精品私人影院| 国产亚洲福利社区一区| 久久综合色之久久综合| 日韩欧美一区二区三区在线| 91麻豆精品国产91久久久更新时间 | 麻豆精品一区二区av白丝在线| 一卡二卡欧美日韩| 一区二区不卡在线播放| 亚洲在线视频网站| 亚洲国产日产av| 亚洲午夜精品在线| 午夜精品久久久久久久蜜桃app | 亚洲成av人片在www色猫咪| 亚洲欧美欧美一区二区三区| 中文字幕中文字幕一区| 成人欧美一区二区三区白人 | 亚洲精品国产视频| 一区二区三区国产豹纹内裤在线| 亚洲综合图片区| 亚洲成人www| 日本不卡视频在线观看| 美国十次了思思久久精品导航| 美女高潮久久久| 国产成人亚洲精品狼色在线| av亚洲精华国产精华精华| 99久久久国产精品| 欧美又粗又大又爽| 这里只有精品99re| 精品美女在线播放| 国产精品免费久久| 一区二区三区丝袜| 免费人成精品欧美精品| 国产专区欧美精品| 成人精品视频.| 欧美日韩在线免费视频| 欧美大胆人体bbbb| 国产精品沙发午睡系列990531| 亚洲女厕所小便bbb| 亚洲va欧美va人人爽| 久久99精品国产.久久久久久| 国产精品伊人色| 91视频91自| 777精品伊人久久久久大香线蕉| 欧美va在线播放| 中文字幕人成不卡一区| 视频在线在亚洲| 懂色一区二区三区免费观看| 欧洲中文字幕精品| 精品国产乱码久久久久久老虎| 日韩一区中文字幕| 日韩成人一区二区| 99麻豆久久久国产精品免费| 欧美撒尿777hd撒尿| 国产午夜一区二区三区| 亚洲小少妇裸体bbw| 国产精品综合一区二区三区| 欧美系列亚洲系列| 久久久青草青青国产亚洲免观| 一区二区三区视频在线观看| 国产美女精品在线| 欧美美女bb生活片| 中文字幕亚洲成人| 激情欧美一区二区三区在线观看| 色婷婷综合在线| 国产丝袜欧美中文另类| 午夜精品福利一区二区三区av| 成人在线视频一区二区| 日韩欧美在线网站| 亚洲国产精品麻豆| 99视频有精品| 久久精品日产第一区二区三区高清版| 亚洲成av人片| 91免费版在线看| 国产精品免费视频观看| 国产精品一区二区三区乱码| 91精品国产91久久综合桃花| 一区二区三区色| 91一区一区三区| 国产精品乱码久久久久久| 日本一不卡视频| 91久久一区二区| 国产精品卡一卡二| 国产精品亚洲专一区二区三区| 欧美高清激情brazzers| 亚洲综合小说图片| 色婷婷综合视频在线观看| 国产精品欧美久久久久无广告| 久久精品国产成人一区二区三区 | 亚洲视频在线一区| 国产不卡高清在线观看视频| 久久综合色天天久久综合图片| 日韩vs国产vs欧美| 欧美日韩美少妇| 亚洲福利一二三区| 欧美日韩三级一区| 亚洲大片一区二区三区| 在线观看视频一区| 亚洲夂夂婷婷色拍ww47| 欧洲国产伦久久久久久久| 亚洲综合色丁香婷婷六月图片| 99久久伊人精品| 亚洲免费色视频| 欧美午夜精品免费| 亚洲第一在线综合网站| 欧美老年两性高潮| 免费在线观看成人| 精品日产卡一卡二卡麻豆| 韩国精品一区二区| 国产亚洲成aⅴ人片在线观看| 成人午夜短视频| 亚洲人吸女人奶水| 91国偷自产一区二区三区观看| 五月婷婷激情综合| 精品捆绑美女sm三区| 国产精品中文字幕一区二区三区| 欧美国产日韩一二三区| 91亚洲精华国产精华精华液| 亚洲精品成人少妇| 日韩一区二区在线看| 国产米奇在线777精品观看| 精品第一国产综合精品aⅴ| 成人免费看片app下载| 国产91精品露脸国语对白| 日韩一区在线看| 欧美丰满一区二区免费视频| 久久99国产精品免费网站| 国产精品久久久99| 欧美人牲a欧美精品| 国产美女在线观看一区| 成人精品免费视频|