⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 atamx31.h

📁 Freescale ARM11系列CPU MX31的WINCE 5.0下的BSP
💻 H
字号:
//------------------------------------------------------------------------------
//
//  Copyright (C) 2004-2006, Freescale Semiconductor, Inc. All Rights Reserved.
//  THIS SOURCE CODE, AND ITS USE AND DISTRIBUTION, IS SUBJECT TO THE TERMS
//  AND CONDITIONS OF THE APPLICABLE LICENSE AGREEMENT
//
//------------------------------------------------------------------------------

/*++

Module Name:
    ATAMX31.h

Abstract:
    ATA MX31 device abstraction.

Revision History:

--*/

#ifndef _ATAMX31_H_
#define _ATAMX31_H_

#ifdef ZONE_INIT
#undef ZONE_INIT
#endif //ZONE_INIT
#ifdef ZONE_WARNING
#undef ZONE_WARNING
#endif //ZONE_WARNING

#include <atamain.h>

// TODO: Rationalize this
#define ZONEID_FUNC       7
#define ZONE_FUNC         DEBUGZONE(ZONEID_FUNC)
#define ZONE_MX31         0

// MX31_ registry value set
typedef struct _MX31REG {
    DWORD dwIORDYEnable;
} MX31REG, *PMX31REG;


#define CLOCK_PERIOD   15
#define PIO_MODE  			1
#define MDMA_MODE  			2
#define UDMA_MODE  			3

#define USE_SDMA
#define USE_SDMA_SG_LIST

#define ATA_SDMA_BUFFER_SIZE   (MAX_SECT_PER_COMMAND_DMA*512)
#define ATA_CHANNEL_PRIORITY    BSP_SDMA_CHNPRI_ATA // SDMA channel priority 
#define ATA_DMA_WATERMARK	32 	  // ATA DMA watermark in bytes

#define ATA_MAX_SECTOR          512
#define ATA_MAX_TRANSFER        (MAX_SECT_PER_COMMAND * ATA_MAX_SECTOR)
#define ATA_MAX_DESC_COUNT      ((ATA_MAX_TRANSFER / 4096) * 2)

#define CACHE_LINE_SIZE_MASK    (32 - 1)    // L1 & L2 cache lines are 32 bytes

class CMX31Disk : public CDisk {
  public:

    // member variables
    static LONG  m_lDeviceCount;

    PCSP_ATA_REG 	g_pVAtaReg;
    PCSP_PBC_REGS 	g_pPBC;

	  BYTE    bIntrPending;
    
    // (SDMA support)
    PHYSICAL_ADDRESS 	PhysDMABufferAddr;
    PBYTE 		pVirtDMABufferAddr;
    UINT8 		DmaChanATARx, DmaChanATATx; 
    DDK_DMA_REQ 	CurrentDmaChanRx, CurrentDmaChanTx;
    DDK_DMA_REQ		DmaReqTx ; 
    DDK_DMA_REQ		DmaReqRx ; 
    
    DWORD m_dwTransferSize;

    MX31REG 		m_Mx31Reg;
    
    // constructors/destructors
    CMX31Disk(HKEY hKey);
    virtual ~CMX31Disk();

    // member functions
    virtual VOID ConfigureRegisterBlock(DWORD dwStride);
    virtual BOOL Init(HKEY hActiveKey);
    virtual DWORD MainIoctl(PIOREQ pIOReq);
    virtual BOOL WaitForInterrupt(DWORD dwTimeOut);
    virtual void EnableInterrupt();
    virtual BOOL ConfigPort();
    
    virtual BOOL SetupDMA(PSG_BUF pSgBuf, DWORD dwSgCount, BOOL fRead);
    virtual BOOL BeginDMA(BOOL fRead);
    virtual BOOL EndDMA();
    virtual BOOL AbortDMA();
    virtual BOOL CompleteDMA(PSG_BUF pSgBuf, DWORD dwSgCount, BOOL fRead);
    
    void CopyDiskInfoFromPort();
    void SetTimingRegisters(int speed, int mode, int ClkSpd);
    BOOL ConfigureIOMUXPad(int muxmode);
    BOOL InitializePort(void);
    void ShowRegisters(UCHAR usel);
    inline virtual void CMX31Disk::TakeCS() {
        m_pPort->TakeCS();
    }
    inline virtual void CMX31Disk::ReleaseCS() {
        m_pPort->ReleaseCS();
    }
    inline BOOL CMX31Disk::DoesDeviceAlreadyExist() {
        return FALSE;
    }

    // DMA support
    PSG_BUF m_pDMASgBuf;
    DWORD   m_dwAlignedSgCount;
    DWORD   m_dwAlignedDescCount;
    DWORD   m_dwAlignedSgBytes;
    UINT8   m_DMAChan;
	  DWORD   dwDoubleBufferPos;
	  BOOL    fSDMAIntrEnable;
	  
    BOOL MapDMABuffers(void);
    BOOL UnmapDMABuffers(void);
    BOOL DeinitChannelDMA(void);
    BOOL InitChannelDMA(void);
    BOOL InitDMA(void) ;
    BOOL DeInitDMA(void); 
    DWORD MoveDMABuffer(PSG_BUF pSgBuf, DWORD dwSgIndex, DWORD dwSgCount, BOOL fRead);

#if 0
	void RunTest(void);
	void TestSDMAReadWrite(BOOL fRead, int mode, int sector, int num_sec);
	void TestDMARead(void);
#endif
	
};

EXTERN_C
CDisk *
CreateMX31(
    HKEY hDevKey
    );

#endif //_ATAMX31_H_

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -