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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pdds3c2440_ser.h

?? 三星2440 cpu WINCE 5.00板級(jí)支持包
?? H
字號(hào):
//
// 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.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:  

Abstract:

    Platform dependent Serial definitions for 16550  controller.

Notes: 
--*/
#ifndef __PDDS3C2440_SER_H_
#define __PDDS3C2440_SER_H_

#include <cserpdd.h>
#include <cmthread.h>
#include <S3c2440x_intr.h>
#define DEFAULT_S3C2440X_PCLK (203000000 / 4)

/////////////////////////////////////////////////////////////////////////////////////////
//// S3C2400 UART Register

///////++ UART CONTROL REGISTER ++
// Line control register bitvalue mask
#define SER2440_PARITY_MASK     0x38
#define SER2440_STOPBIT_MASK    0x4
#define SER2440_DATABIT_MASK    0x3
#define SER2440_IRMODE_MASK     0x40

// Fifo Status
#define SER2440_FIFOSTAT_MASK   0xf0

//
#define SER2440_FIFOFULL_TX     0x200
#define SER2440_FIFOCNT_MASK_TX 0xf0
#define SER2440_FIFO_DEPTH_TX 16
#define SER2440_FIFO_DEPTH_RX 16

//
#define SER2440_INT_INVALID     0x5a5affff

// Modem control register
#define SER2440_AFC             (0x10)
#define SER2440_RTS             0x1
//Receive Mode
#define RX_MODE_MASK          (0x11)
#define RX_DISABLE            (0x00)
#define RX_INTPOLL            (0x01)
#define RX_DMA0               (0x10)
#define RX_DMA1               (0x11)
//Transmit Mode
#define TX_MODE_MASK          (0x11 << 2)
#define TX_DISABLE            (0x00 << 2)
#define TX_INTPOLL            (0x01 << 2)
#define TX_DMA0               (0x10 << 2)
#define TX_DMA1               (0x11 << 2)
//Send Break Signal
#define BS_MASK               (0x01 << 4)
#define BS_NORM               (0x00 << 4)
#define BS_SEND               (0x01 << 4)
//Loop-back Mode
#define LB_MASK               (0x01 << 5)
#define LB_NORM               (0x00 << 5)
#define LB_MODE               (0x01 << 5)
//Rx Error Status Interrupt Enable
#define RX_EINT_MASK          (0x01 << 6)
#define RX_EINTGEN_OFF        (0x00 << 6)
#define RX_EINTGEN_ON         (0x01 << 6)
//Rx Time Out Enable
#define RX_TIMEOUT_MASK       (0x01 << 7)
#define RX_TIMEOUT_DIS        (0x00 << 7)
#define RX_TIMEOUT_EN         (0x01 << 7)
//Rx Interrupt Type
#define RX_INTTYPE_MASK       (0x01 << 8)
#define RX_INTTYPE_PUSE       (0x00 << 8)
#define RX_INTTYPE_LEVEL      (0x01 << 8)
//Tx Interrupt Type
#define TX_INTTYPE_MASK       (0x01 << 9)
#define TX_INTTYPE_PUSE       (0x00 << 9)
#define TX_INTTYPE_LEVEL      (0x01 << 9)
// Clock selection
#define CS_MASK	(0x01 << 10)
#define CS_PCLK (0x00 << 10)
#define CS_UCLK	(0x01 << 10)
// UER State Error Bit.
#define UERSTATE_BREAK_DETECT 0x8
#define UERSTATE_FRAME_ERROR  0x4
#define UERSTATE_PARITY_ERROR 0x2
#define UERSTATE_OVERRUN_ERROR 0x1

/////////////////////////////////////////////////////////////////////////////////////////
// Required Registry Setting.
#define PC_REG_2440UART_INTBIT_VAL_NAME TEXT("InterruptBitsShift")
#define PC_REG_2440UART_INTBIT_VAL_LEN sizeof(DWORD)
#define PC_REG_2440UART_IST_TIMEOUTS_VAL_NAME TEXT("ISTTimeouts")
#define PC_REG_2440UART_IST_TIMEOUTS_VAL_LEN sizeof(DWORD)
/////////////////////////////////////////////////////////////////////////////////////////
#define S2440UART_INT_RXD 1
#define S2440UART_INT_TXD 2
#define S2440UART_INT_ERR 4
////////////////////////////////////////////////////////////////////////////////////////
// WaterMarker Pairs.
typedef struct  __PAIRS {
    ULONG   Key;
    ULONG   AssociatedValue;
} PAIRS, *PPAIRS;


 class CReg2440Uart {
public:
    CReg2440Uart(PULONG pRegAddr);
    virtual ~CReg2440Uart() { ; };
    virtual BOOL    Init() ;
    // We do not virtual Read & Write data because of Performance Concern.
    void    Write_ULCON(ULONG uData) { WRITE_REGISTER_ULONG( m_pReg, (uData)); };
    ULONG   Read_ULCON() { return (READ_REGISTER_ULONG(m_pReg)); } ;
    void    Write_UCON (ULONG uData) { WRITE_REGISTER_ULONG(m_pReg+1 , uData); };
    ULONG   Read_UCON() { return READ_REGISTER_ULONG(m_pReg+1 ); };
    void    Write_UFCON(ULONG uData) { WRITE_REGISTER_ULONG( m_pReg+2, uData);};
    ULONG   Read_UFCON() { return READ_REGISTER_ULONG(m_pReg + 2); };
    void    Write_UMCON(ULONG uData) { WRITE_REGISTER_ULONG(m_pReg + 3, uData);};
    ULONG   Read_UMCON() { return READ_REGISTER_ULONG(m_pReg + 3);};
    ULONG   Read_UTRSTAT() { return READ_REGISTER_ULONG(m_pReg + 4);};
    ULONG   Read_UERSTAT() { return READ_REGISTER_ULONG(m_pReg + 5);};
    ULONG   Read_UFSTAT() { return READ_REGISTER_ULONG(m_pReg + 6);};
    ULONG   Read_UMSTAT() { return READ_REGISTER_ULONG(m_pReg + 7);};
    void    Write_UTXH (UINT8 uData) { WRITE_REGISTER_ULONG( (m_pReg + 8), uData) ; };
    UINT8   Read_URXH() { return (UINT8) READ_REGISTER_ULONG(m_pReg + 9); };
    void    Write_UBRDIV(ULONG uData) { WRITE_REGISTER_ULONG( m_pReg + 10, uData );};
    ULONG   Read_UBRDIV() { return READ_REGISTER_ULONG(m_pReg + 10); };

    virtual BOOL    Write_BaudRate(ULONG uData);
    PULONG  GetRegisterVirtualAddr() { return m_pReg; };
    virtual void    Backup();
    virtual void    Restore();
#ifdef DEBUG
    virtual void    DumpRegister();
#endif
protected:
    volatile PULONG const  m_pReg;
    BOOL    m_fIsBackedUp;
private:
    ULONG    m_ULCONBackup;
    ULONG    m_UCONBackup;
    ULONG    m_UFCONBackup;
    ULONG    m_UMCOMBackup;
    ULONG    m_UBRDIVBackup;
    
    ULONG    m_BaudRate;
    ULONG    m_s3c2440_pclk;
};
class CPdd2440Uart: public CSerialPDD, public CMiniThread  {
public:
    CPdd2440Uart (LPTSTR lpActivePath, PVOID pMdd, PHWOBJ pHwObj);
    virtual ~CPdd2440Uart();
    virtual BOOL Init();
    virtual void PostInit();
    virtual BOOL MapHardware();
    virtual BOOL CreateHardwareAccess();
//  Power Manager Required Function.
    virtual void    SerialRegisterBackup() { m_pReg2440Uart->Backup(); };
    virtual void    SerialRegisterRestore() { m_pReg2440Uart->Restore(); };

// Implement CPddSerial Function.
// Interrupt
    virtual BOOL    InitialEnableInterrupt(BOOL bEnable ) ; // Enable All the interrupt may include Xmit Interrupt.
private:
    virtual DWORD ThreadRun();   // IST
//  Tx Function.
public:
    virtual BOOL    InitXmit(BOOL bInit);
    virtual void    XmitInterruptHandler(PUCHAR pTxBuffer, ULONG *pBuffLen);
    virtual void    XmitComChar(UCHAR ComChar);
    virtual BOOL    EnableXmitInterrupt(BOOL bEnable);
    virtual BOOL    CancelXmit();
    virtual DWORD   GetWriteableSize();
protected:
    BOOL    m_XmitFifoEnable;
    HANDLE  m_XmitFlushDone;

//
//  Rx Function.
public:
    virtual BOOL    InitReceive(BOOL bInit);
    virtual ULONG   ReceiveInterruptHandler(PUCHAR pRxBuffer,ULONG *pBufflen);
    virtual ULONG   CancelReceive();
    virtual DWORD   GetWaterMark();
    virtual BYTE    GetWaterMarkBit();
protected:
    BOOL    m_bReceivedCanceled;
    DWORD   m_dwWaterMark;
//
//  Modem
public:
    virtual BOOL    InitModem(BOOL bInit);
    virtual void    ModemInterruptHandler() { GetModemStatus();};
    virtual ULONG   GetModemStatus();
    virtual void    SetDTR(BOOL bSet) {;};
    virtual void    SetRTS(BOOL bSet);
//
// Line Function.
    virtual BOOL    InitLine(BOOL bInit) ;
    virtual void    LineInterruptHandler() { GetLineStatus();};
    virtual void    SetBreak(BOOL bSet) ;
    virtual BOOL    SetBaudRate(ULONG BaudRate,BOOL bIrModule) ;
    virtual BOOL    SetByteSize(ULONG ByteSize);
    virtual BOOL    SetParity(ULONG Parity);
    virtual BOOL    SetStopBits(ULONG StopBits);
//
// Line Internal Function
    BYTE            GetLineStatus();
    virtual void    SetOutputMode(BOOL UseIR, BOOL Use9Pin) ;

protected:
    CReg2440Uart *  m_pReg2440Uart;
    PVOID           m_pRegVirtualAddr;

    volatile S3C2440X_INTR_REG   * m_pINTregs;    
    DWORD           m_dwIntShift;
public:
    void    DisableInterrupt(DWORD dwInt) { 
        m_pINTregs->INTSUBMSK |= (dwInt<<m_dwIntShift);
    }
    void    EnableInterrupt(DWORD dwInt) { 
        m_pINTregs->INTSUBMSK &= ~(dwInt<<m_dwIntShift);
    }
    void    ClearInterrupt(DWORD dwInt) {
        m_pINTregs->SUBSRCPND = (dwInt<<m_dwIntShift);
    }
    DWORD   GetInterruptStatus() { return ((m_pINTregs->SUBSRCPND) >> m_dwIntShift);};
    DWORD   GetIntrruptMask () { return ((~(m_pINTregs->INTSUBMSK) )>> m_dwIntShift); };
    
protected:
    CRegistryEdit m_ActiveReg;
//  Interrupt Handler
    DWORD       m_dwSysIntr;
    HANDLE      m_hISTEvent;
// Optional Parameter
    DWORD m_dwDevIndex;
    DWORD m_dwISTTimeout;

};

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品夜色噜噜亚洲aⅴ| 六月丁香婷婷久久| 95精品视频在线| 亚洲欧美自拍偷拍| 成人aaaa免费全部观看| 久久美女艺术照精彩视频福利播放| 国产在线看一区| 国产精品欧美综合在线| 国产精品一色哟哟哟| 欧美在线免费播放| 国产精品国产三级国产aⅴ无密码| 奇米综合一区二区三区精品视频| 色婷婷亚洲精品| xvideos.蜜桃一区二区| 亚洲精品中文在线观看| 韩国一区二区三区| 欧美精品一区二区三区四区| 欧美精品乱码久久久久久按摩| 亚洲国产毛片aaaaa无费看| 国产精品888| 欧美变态凌虐bdsm| 亚洲综合色区另类av| 成人美女视频在线观看| 久久精品免视看| 蜜桃在线一区二区三区| 日本韩国一区二区三区视频| 国产精品蜜臀av| 久久99精品国产.久久久久久| 97se狠狠狠综合亚洲狠狠| 国产精品久久久一区麻豆最新章节| 奇米精品一区二区三区在线观看一 | 日韩高清在线电影| 99精品久久免费看蜜臀剧情介绍| 中文字幕欧美激情一区| 久久精品99久久久| 欧美区一区二区三区| 亚州成人在线电影| 欧美亚洲动漫精品| 91精品国产91综合久久蜜臀| 成人av小说网| 天堂一区二区在线免费观看| 国产精品亚洲午夜一区二区三区| 欧美日韩一卡二卡三卡| 精品一区二区免费在线观看| 欧美mv日韩mv国产| 国产欧美精品一区二区三区四区 | 国产精品成人免费精品自在线观看| 精品捆绑美女sm三区| 正在播放亚洲一区| 在线电影一区二区三区| 欧美日韩高清一区二区| 欧美午夜一区二区| 成人中文字幕在线| 日韩精品91亚洲二区在线观看| 精品国产一区二区三区av性色| 高清不卡一区二区| 日韩精品亚洲专区| 国产精品高潮久久久久无| 欧美久久婷婷综合色| 国产综合久久久久久鬼色| www久久精品| 粉嫩av一区二区三区| av在线不卡网| 欧美精品三级日韩久久| 免费欧美高清视频| 日韩欧美www| 精久久久久久久久久久| 日韩欧美电影一二三| 久久国产精品免费| 欧美精品一区二区三区蜜桃视频 | 97久久人人超碰| 亚洲综合小说图片| 欧美日韩一级片网站| 日韩成人免费在线| 26uuu另类欧美亚洲曰本| 国产成人精品一区二| 国产精品久久久久婷婷二区次| av一区二区三区在线| 亚洲综合在线视频| 制服丝袜在线91| 国产精品久久精品日日| 亚洲激情六月丁香| 亚洲高清免费一级二级三级| 精品久久久影院| 欧美视频中文一区二区三区在线观看| 国产福利精品一区二区| 国产不卡视频一区| 久久精品国产精品青草| 在线观看欧美精品| 欧美性大战久久久久久久| 欧美国产日韩a欧美在线观看| 自拍av一区二区三区| 久久99国产精品久久99果冻传媒| 91视频在线看| 国产精品区一区二区三区| 久久精品国产77777蜜臀| 波多野结衣91| 国产欧美一区二区三区沐欲| 亚洲精品日产精品乱码不卡| 亚洲一区二区av在线| 日韩1区2区3区| 亚洲成在人线在线播放| 婷婷国产在线综合| 日韩不卡一二三区| 成人一区二区三区| 国产91精品入口| 国产麻豆精品视频| 成人av电影在线播放| 国产91露脸合集magnet| 99re热这里只有精品视频| 国产精品福利影院| 成人黄色小视频在线观看| 自拍偷拍国产精品| 久久久久久亚洲综合| 91国内精品野花午夜精品| 日本美女视频一区二区| 亚洲精品欧美激情| 精品国产一二三区| 欧美视频一区二区三区| 国产一区二区91| 亚洲国产中文字幕| 国产精品成人午夜| 欧美一级久久久| 91视频观看免费| 国产乱码字幕精品高清av| 亚洲成a人片在线不卡一二三区 | 精品视频一区三区九区| 久久综合999| 亚洲aⅴ怡春院| 狠狠v欧美v日韩v亚洲ⅴ| 欧美视频在线一区二区三区| 亚洲第一搞黄网站| 精品亚洲国产成人av制服丝袜| 成人精品gif动图一区| 欧美视频一区二区在线观看| 中文字幕一区不卡| 不卡一区二区中文字幕| 国产精品每日更新| 久久蜜桃香蕉精品一区二区三区| 亚洲成人tv网| 日韩欧美www| 风间由美一区二区av101 | 免费观看一级欧美片| 欧美国产成人在线| 日韩一区二区高清| 成人v精品蜜桃久久一区| 樱桃国产成人精品视频| 日韩精品一区二区三区中文不卡| 亚洲欧美偷拍卡通变态| 一区二区三区四区av| 99久久精品国产精品久久| 久久网站热最新地址| 九一九一国产精品| 91啪亚洲精品| 亚洲综合免费观看高清完整版在线 | 精品对白一区国产伦| 亚洲美女视频在线观看| 91麻豆精品视频| 欧美视频在线一区二区三区| 国产一区二区三区蝌蚪| 蜜臀久久99精品久久久久宅男 | 亚洲欧美国产高清| 最新欧美精品一区二区三区| 国产精品视频你懂的| 91精品麻豆日日躁夜夜躁| 色八戒一区二区三区| 成人午夜av影视| 免费成人深夜小野草| 18成人在线观看| 欧美日韩综合一区| 91网站视频在线观看| 麻豆精品视频在线| 午夜亚洲国产au精品一区二区| 国产女同性恋一区二区| 久久综合久久综合九色| 日韩一区二区麻豆国产| 久久精品亚洲精品国产欧美| 日韩女优制服丝袜电影| 精品国产乱子伦一区| 日韩欧美亚洲一区二区| 久久综合久久综合久久综合| 国产精品毛片久久久久久久| 亚洲韩国精品一区| 狠狠色丁香婷婷综合久久片| 国产在线不卡视频| 色成年激情久久综合| 日韩视频一区在线观看| 久久精品视频在线看| 中文字幕一区二区三| 无吗不卡中文字幕| 亚洲午夜一区二区三区| 中文字幕日韩欧美一区二区三区| 久久久一区二区| 精品88久久久久88久久久| 日韩精品一区在线观看| 精品捆绑美女sm三区| 久久精品在线免费观看| 久久久久久久久免费| 1000精品久久久久久久久| 久久女同精品一区二区|