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

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

?? ser2410.h

?? 三星2410 Windows CE 4.2 串口驅動源碼。適合所有以S3C2410X為主芯片開發的平臺。
?? 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.
//
/*++
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:  
   SER_PDD.h
   
Abstract:  
   Holds definitions for sample 16550  serial interface.
   
Notes: 
--*/
#ifndef __SER_PDD_H__   
    #define __SER_PDD_H__

    #ifdef __cplusplus
extern "C" {
    #endif

// TODO - Define PAGE_CONTAINING_UART
    #define PAGE_CONTAINING_UART   XXXXX

/*
 * @doc HWINTERNAL
 * @struct SER_INFO | Private structure.
 */


/* 
 * S2400 UART1 register values
 */

// Line Status Register    
#define  COM2410_LSR_OE     0x1
#define  COM2410_LSR_PE     0x2
#define  COM2410_LSR_FE     0x4
#define  COM2410_LSR_BI     0x8   //Break Detect
// dummy value 
#define  COM2410_LSR_THRE   0xe
#define  COM2410_LSR_DR     0xf
// Fifo Status Register

// following two cts values are read from modem control register.
#define  COM2410_MSR_CTS    0x1
#define  COM2410_MSR_DCTS   0x4
// following two cts values are read from modem GIO port.
#define  COM2410_MSR_DSR    0x2
#define  COM2410_MSR_DDSR    0x8

typedef struct {
      PS2410_UART_REG s2410SerReg;

      volatile unsigned char *pUFTXH;  // Tx holding register for byte access.
      volatile unsigned char *pUFRXH;  // Rx holding register for byte access.
      volatile unsigned int *UART_INTMASK;
      volatile unsigned int *UART_INTSUBMASK;
      volatile unsigned int *UART_INTPND;
      volatile unsigned int *UART_INTSRCPND;
      volatile unsigned int *UART_INTSUBSRCPND;
      //volatile unsigned int *UART_INTOFFSET;
      //ULONG nTxINT;
      //ULONG nRxINT;
      ULONG bINT;
      ULONG bTxINT;
      ULONG bRxINT;
      ULONG bErrINT;
      BOOL fSW_EnTxINT;   // S/W flag of Enable Tx interrupt.
      BOOL RxDiscard;   // S/W flag of Enable Tx interrupt.
      BOOL UseIrDA;        // @field Boolean, are we running in IR mode?
      int ConSetup;
      // ULONG nRxErrINT;  // reserved for future...
      volatile unsigned int *rDTRport;
      int DtrPortNum;
      volatile unsigned int *rDSRport;
      int DsrPortNum;

      // These variable are for saving register values.
      ULONG sULCON;
      ULONG sUCON;
      ULONG sUMCON;
      ULONG sUFCON;
      ULONG sINTstat;

      ULONG vUMSTAT;
      
       // We have an event callback into the MDD
      EVENT_FUNC EventCallback; // This callback exists in MDD
      PVOID        pMddHead;  // This is the first parm to callback

       // Keep a copy of DCB since we rely on may of its parms
      DCB         dcb;        // @field Device Control Block (copy of DCB in MDD)
       // And the same thing applies for CommTimeouts
      COMMTIMEOUTS CommTimeouts;  // @field Copy of CommTimeouts structure

       // Misc fields used by ser16550 library
      ULONG OpenCount;	    // @field Count of simultaneous opens. 
      PLOOKUP_TBL pBaudTable;     // @field Pointer to Baud Table
      ULONG		DroppedBytes;	// @field Number of dropped bytes 
      HANDLE		FlushDone;		// @field Handle to flush done event.
      BOOL		CTSFlowOff;		// @field Flag - CTS flow control state. 
      BOOL		DSRFlowOff;		// @field Flag - DSR flow control state. 
      BOOL		AddTXIntr;		// @field Flag - Fake a TX intr.
      COMSTAT		Status; 		// @field Bitfield representing Win32 comm status. 
      ULONG		CommErrors;		// @field Bitfield representing Win32 comm error status. 
      ULONG		ModemStatus;	// @field Bitfield representing Win32 modem status. 
      CRITICAL_SECTION	TransmitCritSec; // @field Protects UART Registers for non-atomic accesses
      CRITICAL_SECTION	RegCritSec; // @field Protects UART 
      ULONG		ChipID;			// @field Chip identifier (CHIP_ID_16550 or CHIP_ID_16450)        

    } S2410_UART_INFO, * PS2410_UART_INFO;

    typedef struct __SER_INFO {
        // Put lib struct first so we can easily cast pointers
        //SER16550_INFO ser16550;
        S2410_UART_INFO s2410COM;   // UART H/W register
        // now hardware specific fields
        DWORD       dwIOBase;       // @field IO Base Address - unmapped
        DWORD       dwIOLen;        // @field IO Length
        DWORD       dwIRQ;          // @field Interrupt number for this peripheral
        DWORD       dwDevIndex;     // @field Index of device

        PUCHAR      pBaseAddress;   // @field Start of serial registers - mapped

        UINT8       cOpenCount;     // @field Count of concurrent opens
        COMMPROP    CommProp;       // @field Pointer to CommProp structure.
        PVOID       pMddHead;       // @field First arg to mdd callbacks.
        BOOL        fIRMode;        // @field Boolean, are we running in IR mode?
    #ifdef EXAMINE_BOOTARGS
        PBOOT_ARGS  pBootArgs;      // @field Pointer to global boot args struct
    #endif    
        PHWOBJ      pHWObj;         // @field Pointer to PDDs HWObj structure
    } SER_INFO, *PSER_INFO;


// Here are the names of the values stored in the registry
    #define PC_REG_IRQ_VAL_NAME TEXT("IRQ") 
    #define PC_REG_IRQ_VAL_LEN  sizeof( DWORD )

    #define PC_REG_IOBASE_VAL_NAME TEXT("IoBase") 
    #define PC_REG_IOBASE_VAL_LEN  sizeof( DWORD )
    #define PC_REG_IOLEN_VAL_NAME TEXT("IoLen") 
    #define PC_REG_IOLEN_VAL_LEN  sizeof( DWORD )

    #define PC_REG_CONFIGBASE_VAL_NAME TEXT("ConfigBase") 
    #define PC_REG_CONFIGBASE_VAL_LEN  sizeof( DWORD )
    #define PC_REG_CONFIGLEN_VAL_NAME TEXT("ConfigLen") 
    #define PC_REG_CONFIGLEN_VAL_LEN  sizeof( DWORD )

    #define PC_REG_DMA_VAL_NAME TEXT("DMA") 
    #define PC_REG_DMA_VAL_LEN  sizeof( DWORD )

    #define PC_REG_DEVINDEX_VAL_NAME TEXT("DeviceArrayIndex") 
    #define PC_REG_DEVINDEX_VAL_LEN  sizeof( DWORD )

    #ifdef __cplusplus
}
    #endif


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

///////++ UART CONTROL REGISTER ++
// Line control register bitvalue mask
#define SER2410_PARITY_MASK     0x38
#define SER2410_STOPBIT_MASK    0x4
#define SER2410_DATABIT_MASK    0x3
#define SER2410_IRMODE_MASK     0x40

// Fifo Status
#define SER2410_FIFOSTAT_MASK   0xf0

//
#define SER2410_FIFOFULL_TX     0x200
#define SER2410_FIFOCNT_MASK_TX 0xf0
#define SER2410_FIFO_DEPTH_TX 16

//
#define SER2410_INT_INVALID     0x5a5affff

// Modem control register
#define SER2410_AFC             (0x10)
#define SER2410_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)

/////////////////////////////////////////////////////////////////////////////////////////


#define INREG(pInfo, reg) (pInfo->s2410SerReg->reg)
#define OUTREG(pInfo, reg, value) (pInfo->s2410SerReg->reg = value)
// set register by orring..
#define SETREG(pInfo, reg, value) (pInfo->s2410SerReg->reg |= value)
#define CLEARREG(pInfo, reg, value) (pInfo->s2410SerReg->reg &= ~value)

#define DisEnINT(pInfo, value) (		*(pInfo->UART_INTMASK) |= (value))
#define DisEnSubINT(pInfo, value) (	*(pInfo->UART_INTSUBMASK) |= (value))

#define EnINT(pInfo, value) (			*(pInfo->UART_INTMASK) &= ~(value))
#define EnSubINT(pInfo, value) ( 		*(pInfo->UART_INTSUBMASK) &= ~(value))

#define GetSubINTStatus(pInfo) ((*(pInfo->UART_INTSUBMASK)) & 0x1ff)

#define ClearINTPnd(pInfo, value) (	*(pInfo->UART_INTSRCPND) = (value))
#define ClearSubINTPnd(pInfo, value) (	*(pInfo->UART_INTSUBSRCPND) = (value))
//#define GetSubINTPndStatus(pInfo) (*(pInfo->UART_INTSUBSRCPND) & 0x1ff)
#define GetSubINTPndStatus(pInfo) 1


#endif __SER_PDD_H__

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产精品中文字幕| 日韩久久久久久| 国产精品性做久久久久久| 五月婷婷色综合| 亚洲综合在线免费观看| 亚洲精品国产a久久久久久| 日韩午夜小视频| 91麻豆精品国产91久久久久 | 狠狠色综合日日| 秋霞电影一区二区| 久久 天天综合| 经典一区二区三区| 国产传媒日韩欧美成人| 成人av在线网站| 色噜噜夜夜夜综合网| 欧美在线视频不卡| 91精品黄色片免费大全| 精品久久人人做人人爰| 国产日韩精品久久久| 中文字幕av不卡| 亚洲黄色av一区| 日韩成人一级片| 国产福利精品一区二区| 91丝袜美腿高跟国产极品老师| 欧美自拍偷拍午夜视频| 欧美精品久久一区| 国产亚洲欧美色| 一区二区三区欧美视频| 久久精品免费观看| 国产成人久久精品77777最新版本| 99在线精品免费| 欧美一区欧美二区| 中文字幕亚洲一区二区av在线 | 日韩女优制服丝袜电影| 日本一区二区三区久久久久久久久不 | 午夜视频在线观看一区二区 | 欧美国产欧美亚州国产日韩mv天天看完整| 久久九九99视频| 香蕉久久一区二区不卡无毒影院| 国产一区二区三区电影在线观看 | 欧美一区二区三区日韩视频| 国产午夜精品一区二区三区四区| 亚洲综合色区另类av| 国内精品不卡在线| 欧美日韩亚洲综合在线| 国产校园另类小说区| 婷婷中文字幕一区三区| eeuss影院一区二区三区| 欧美岛国在线观看| 亚洲国产色一区| 不卡一卡二卡三乱码免费网站| 日韩欧美在线一区二区三区| 一区二区三区日韩欧美| 成人毛片视频在线观看| www国产精品av| 偷拍自拍另类欧美| 在线一区二区视频| 亚洲视频你懂的| 国产suv一区二区三区88区| 日韩视频永久免费| 天天亚洲美女在线视频| 在线视频国产一区| 综合久久国产九一剧情麻豆| 成人三级伦理片| 国产清纯美女被跳蛋高潮一区二区久久w | 9久草视频在线视频精品| 久久亚洲春色中文字幕久久久| 日韩精品成人一区二区在线| 欧美在线视频日韩| 亚洲国产成人高清精品| 色吧成人激情小说| 亚洲欧美一区二区三区孕妇| 成人美女视频在线观看18| 国产欧美一区二区精品秋霞影院 | 国产一区视频网站| 精品久久久久久无| 精品亚洲国内自在自线福利| 日韩视频不卡中文| 精品一区二区在线视频| 久久久久免费观看| 国产成人8x视频一区二区| 欧美国产禁国产网站cc| 国产成人av电影在线| 欧美激情一区二区三区蜜桃视频 | 亚洲免费电影在线| 欧美体内she精视频| 日韩国产精品久久久| 日韩精品资源二区在线| 国产剧情av麻豆香蕉精品| 国产日韩欧美高清在线| 91农村精品一区二区在线| 亚洲精品日韩综合观看成人91| 欧美在线观看你懂的| 奇米888四色在线精品| 久久嫩草精品久久久精品| 成人午夜电影久久影院| 一区二区成人在线| 日韩免费高清电影| 成人在线一区二区三区| 一级日本不卡的影视| 欧美一级免费大片| 成人动漫av在线| 亚洲国产日日夜夜| 久久中文娱乐网| 91性感美女视频| 麻豆免费看一区二区三区| 久久精品一区二区三区不卡牛牛| 99久久精品99国产精品| 日韩成人一级大片| 国产精品丝袜久久久久久app| 色噜噜久久综合| 国模冰冰炮一区二区| 日韩美女久久久| 日韩美一区二区三区| 91香蕉视频黄| 久久99久国产精品黄毛片色诱| 国产精品进线69影院| 制服视频三区第一页精品| 成人黄色综合网站| 久久国产精品99精品国产| 亚洲欧洲日韩av| 精品国产91乱码一区二区三区| 97久久超碰精品国产| 激情文学综合网| 日韩精品成人一区二区三区| 国产精品蜜臀av| 久久午夜免费电影| 91精品国产综合久久婷婷香蕉| 欧美人体做爰大胆视频| 高清shemale亚洲人妖| 久久狠狠亚洲综合| 亚洲一级在线观看| 亚洲色图色小说| 欧美韩日一区二区三区四区| 日韩美女在线视频| 欧美精品一二三区| 91国在线观看| 91在线精品秘密一区二区| 寂寞少妇一区二区三区| 日韩中文字幕麻豆| 亚洲成人在线免费| 亚洲欧美日韩国产综合在线| 亚洲国产精品黑人久久久| 日韩免费福利电影在线观看| 欧美一区二区黄色| 91.xcao| 欧美精品久久99| 欧美裸体bbwbbwbbw| 欧洲一区二区三区在线| 一本色道综合亚洲| 色欧美片视频在线观看| 一本久道中文字幕精品亚洲嫩| av不卡在线播放| 95精品视频在线| 色婷婷久久综合| 91久久国产最好的精华液| 色八戒一区二区三区| 欧美性xxxxxxxx| 欧美精品第1页| 日韩一区二区三区观看| 欧美电视剧在线观看完整版| 精品国产乱码久久久久久牛牛| 久久网站最新地址| 日本一区二区三区在线观看| 国产精品久久99| 亚洲综合色噜噜狠狠| 天堂va蜜桃一区二区三区漫画版| 日韩综合小视频| 激情偷乱视频一区二区三区| 国产99精品视频| 91麻豆精东视频| 在线91免费看| 久久精品夜色噜噜亚洲a∨| 国产精品乱人伦中文| 亚洲精品第一国产综合野| 亚洲成人动漫av| 国产资源在线一区| 91色乱码一区二区三区| 欧美狂野另类xxxxoooo| 亚洲精品一区二区三区在线观看 | 色婷婷综合久久久中文字幕| 在线观看国产日韩| 精品国产精品网麻豆系列| 国产三级久久久| 一卡二卡三卡日韩欧美| 久久狠狠亚洲综合| 成人av网站在线观看免费| 欧美日韩国产a| 国产欧美一区二区三区鸳鸯浴 | 欧美专区在线观看一区| 日韩欧美国产高清| 综合色天天鬼久久鬼色| 日韩和欧美的一区| caoporn国产精品| 日韩精品一区国产麻豆| 一区二区三区色| 国产不卡视频在线观看| 91精品国产欧美一区二区| 中文字幕欧美一| 精品制服美女久久|