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

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

?? pl010ser.c

?? 收集到的orion_ep93xx_wince_bsp_1-3-507串行通訊驅動源碼,未作測試
?? C
?? 第 1 頁 / 共 5 頁
字號:
//
// 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:  

ser16550.c

Abstract:  

    This file implements the standard device specific functions for a 16550
    based serial device.

Functions:

    SL_Init2()
    SL_PostInit()
    SL_Deinit()
    SL_Open()
    SL_Close()
    SL_ClearDTR()
    SL_SetDTR()
    SL_ClearRTS()
    SL_SetRTS()
    SL_ClearBreak()
    SL_SetBreak()
    SL_SetBaudRate()
    SL_SetByteSize()
    SL_SetParity()
    SL_SetStopBits()
    SL_GetRxBufferSize()
    SL_GetRxStart()
    SL_GetInterruptType()
    SL_RxIntr()
    SL_PutBytes()
    SL_TxIntr()
    SL_LineIntr()
    SL_OtherIntr()
    SL_GetStatus()
    SL_Reset()
    SL_GetModemStatus()
    SL_PurgeComm()
    SL_XmitComChar()
    SL_PowerOff()
    SL_PowerOn()
    SL_SetDCB()
    SL_SetCommTimeouts()
    SL_Ioctl()
    ReadRSR()
    ReadFR()
    DumpSerialRegisters()
    LookUpValue()
    DivisorOfRate()



Notes:
    The RegCritSec is there to protect against non-atomic access of
    register pairs.  On a 16550, the main such collision comes from 
    the fact that THR and IER are overloaded as the DivLatch registers
    and their mode is controlled via the LCR.  So we need the 
    critical section protection around all access of these 3 registers.
    But we also need to watch out for read/modify/write where we are
    setting/ckearing a bit.  In general, I just go ahead and acquire
    the CS around all register accesses.
--*/

#include <windows.h>
#include <types.h>
#include <memory.h>
#include <serhw.h>
#include "pl010ser.h"
#include <ser16550.h>
#include "pl010com.h"
#include <hw16550.h>
#include <serdbg.h>
#include <excpt.h>
#include <hwdefs.h>
#include <clocks.h>


// Macros to read/write serial registers.
//#define INB(pInfo, reg) (READ_PORT_UCHAR((UCHAR *)((pInfo)->reg)))
//#define OUTB(pInfo, reg, value) (WRITE_PORT_UCHAR((UCHAR *)((pInfo)->reg), (unsigned char)(value)))

#define INB(pInfo, reg)             (*((UCHAR *)((pInfo)->reg)))
#define OUTB(pInfo, reg, value)     (*(UCHAR *)((pInfo)->reg) =  (unsigned char)(value) )

BOOL SL_SetByteSize(PVOID pHead, ULONG ByteSize);
BOOL SL_SetStopBits(PVOID pHead, ULONG StopBits);
BOOL SL_SetParity(PVOID pHead, ULONG Parity);

#define EXCEPTION_ACCESS_VIOLATION STATUS_ACCESS_VIOLATION 

__inline
VOID
ReadRSR(
       PSER_INFO  pHead
       )
{
    PAMBA_UART_INFO pSerAMBA  = &(((PSER_INFO)pHead)->serAMBA);
    PSER16550_INFO  pSer16550 = &(((PSER_INFO)pHead)->ser16550);
    ULONG LineEvents = 0;

    try {
        pSerAMBA->RSR = INB(pSerAMBA, pUART_RSR);
    }
    except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ?
            EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH) {
        pSerAMBA->RSR = 0;
    }

    if ( pSerAMBA->RSR & (AMBA_UARTRSR_OE | AMBA_UARTRSR_PE | AMBA_UARTRSR_FE)) 
    {
        // Note: Its not wise to do debug msgs in here since they will
        // pretty much guarantee that the FIFO gets overrun.
        if ( pSerAMBA->RSR & AMBA_UARTRSR_OE )
        {
            // DEBUGMSG (ZONE_WARN, (TEXT("Overrun\r\n")));
            pSer16550->DroppedBytes++;
            pSer16550->CommErrors |= CE_OVERRUN;

            // Clear state.
            OUTB(pSerAMBA, pUART_ECR, AMBA_UARTRSR_OE);
        }

        if ( pSerAMBA->RSR & AMBA_UARTRSR_PE )
        {
            DEBUGMSG (ZONE_WARN, (TEXT("parity\r\n")));
            pSer16550->CommErrors |= CE_RXPARITY;

            // Clear state.
            OUTB(pSerAMBA, pUART_ECR, AMBA_UARTRSR_PE);
        }

        if ( pSerAMBA->RSR & AMBA_UARTRSR_FE )
        {
            DEBUGMSG (ZONE_WARN, (TEXT("frame\r\n")));
            pSer16550->CommErrors |= CE_FRAME;

            // Clear state.
            OUTB(pSerAMBA, pUART_ECR, AMBA_UARTRSR_FE);
        }

        LineEvents |= EV_ERR;
    }

    if ( pSerAMBA->RSR & AMBA_UARTRSR_BE )
    {
        LineEvents |= EV_BREAK;

        // Clear state.
        OUTB(pSerAMBA, pUART_ECR, AMBA_UARTRSR_BE);
    }

    // Let WaitCommEvent know about this error
    if ( LineEvents )
        pSer16550->EventCallback( pSer16550->pMddHead, LineEvents );
}

// The Integrator doesn't give us a delta bits for DCD, DSR, or CTS, so we need to
// figure out of they've changed since the last read, ourselves.
//
__inline
VOID
ReadFR(
       PSER_INFO  pHead
       )
{
    PAMBA_UART_INFO pSerAMBA  = &(((PSER_INFO)pHead)->serAMBA);
    PSER16550_INFO  pSer16550 = &(((PSER_INFO)pHead)->ser16550);
    ULONG Events = 0;
    UCHAR fr = 0;

    try {
        fr = INB(pSerAMBA, pUART_FR);
    }
    except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ?
            EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH) {
        fr = 0;
    }

    // For changes, we use callback to evaluate the event
    if ((fr & AMBA_UARTFR_CTS) != (pSerAMBA->FR & AMBA_UARTFR_CTS))
    {
        Events |= EV_CTS;
    }

    if ((fr & AMBA_UARTFR_DSR) != (pSerAMBA->FR & AMBA_UARTFR_DSR))
    {
        Events |= EV_DSR;
    }

    if ((fr & AMBA_UARTFR_DCD) != (pSerAMBA->FR & AMBA_UARTFR_DCD))
    {
        Events |= EV_RLSD;
    }

    // Save the MSR value in a shadow
    pSerAMBA->FR = fr;

    // Clear modem status interrupt.
    //
    OUTB(pSerAMBA, pUART_ICR, 1);

    if ( Events )
        pSer16550->EventCallback( pSer16550->pMddHead, Events );
}

//
// Helper routine to search through a lookup table for a designated
// key.
//
ULONG
LookUpValue(
           ULONG    Key,
           PLOOKUP_TBL pTbl,
           PULONG    pErrorCode
           )
{
    ULONG   index = 0;

    *pErrorCode = 0;

    while ( index < pTbl->Size ) {
        if ( Key == pTbl->Table[index].Key )
            return(pTbl->Table[index].AssociatedValue);

        ++index;
    }

    *pErrorCode = (ULONG)-1;

    return(0);
}



//
// Helper function.  Pass in a baudrate, and the corresponding divisor
// (from the baudtable) is returned.  If no matching baudrate is found
// in baudtable, then return 0.
//
USHORT
DivisorOfRate(
             PVOID   pHead,      // @parm PVOID returned by HWinit.
             ULONG   BaudRate    // @parm     ULONG representing decimal baud rate.    
             )
{
    ULONG   errorcode = 0;
    USHORT  divisor = 0;    

    //divisor = (USHORT)LookUpValue(BaudRate,
    //                              ((PSER_INFO)pHead)->ser16550.pBaudTable, &errorcode);

    divisor = (USHORT) UART_DIVISOR(BaudRate);
 

    return(divisor);
}

//
// This is a reverse lookup table which can be used to determine
// the FIFO trigger level from the 2 bit value stored in the FCR
//
#define HIGH_WATER_SIZE     4
static const
PAIRS    HighWaterPairs[HIGH_WATER_SIZE] = {
    {SERIAL_1_BYTE_HIGH_WATER, 0},
    {SERIAL_4_BYTE_HIGH_WATER, 4},
    {SERIAL_8_BYTE_HIGH_WATER, 8},
    {SERIAL_14_BYTE_HIGH_WATER, 14}
};
static const
LOOKUP_TBL  HighWaterTable = {HIGH_WATER_SIZE, (PAIRS *) HighWaterPairs};

#define CR_NORMAL_INTS (AMBA_UARTCR_RTIE | AMBA_UARTCR_RIE | AMBA_UARTCR_MSIE | AMBA_UARTCR_UARTEN)

// Routine to clear any pending interrupts.  Called from Init and PostInit
// to make sure we atart out in a known state.
VOID
ClearPendingInts(
       PVOID   pHead // @parm PVOID returned by HWinit.
       )
{
    PSER16550_INFO  pSer16550 = &(((PSER_INFO)pHead)->ser16550);
    PAMBA_UART_INFO pSerAMBA  = &(((PSER_INFO)pHead)->serAMBA);

    EnterCriticalSection(&(pSer16550->RegCritSec));

    try {
        pSerAMBA->IIR = INB(pSerAMBA, pUART_IIR); 
        while ((pSerAMBA->IIR & AMBA_UARTIIR_RTIS) ||
               (pSerAMBA->IIR & AMBA_UARTIIR_TIS)  ||
               (pSerAMBA->IIR & AMBA_UARTIIR_RIS)  ||
               (pSerAMBA->IIR & AMBA_UARTIIR_MIS))
        {
            DEBUGMSG (ZONE_INIT, (TEXT("!!IIR %X\r\n"), pSerAMBA->IIR));

            // Clear ints.
            //
            // Read FIFO clean to deassert RIS and RTIS.
            while(!(INB(pSerAMBA, pUART_FR) & AMBA_UARTFR_RXFE))
                INB(pSerAMBA, pUART_DR);

            // Clear modem status interrupts.
            OUTB(pSerAMBA, pUART_ICR, 1);

        }    
    }
    except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ?
            EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH) {
        DEBUGMSG (ZONE_ERROR,(TEXT("-SL_PostInit, 0x%X - ERROR\r\n"), pHead));
        // Just fall through & release CritSec
    }

    LeaveCriticalSection(&(pSer16550->RegCritSec));
}

//
/////////////////// Start of exported entrypoints ////////////////
//

//
// @doc OEM 
// @func PVOID | SL_Open | Configures 16550 for default behaviour.
//
VOID
SL_Open(
       PVOID   pHead // @parm PVOID returned by HWinit.
       )
{
    PSER16550_INFO  pSer16550 = &(((PSER_INFO)pHead)->ser16550);
    PAMBA_UART_INFO pSerAMBA  = &(((PSER_INFO)pHead)->serAMBA);

    DEBUGMSG (ZONE_OPEN,
              (TEXT("+SL_Open 0x%X\r\n"), pHead));

    // If the device is already open, all we do is increment count
    if ( pSer16550->OpenCount++ ) {
        DEBUGMSG (ZONE_OPEN,
                  (TEXT("-SL_Open 0x%X (%d opens)\r\n"),
                   pHead, pSer16550->OpenCount));
        return ;
    }

    pSerAMBA->RSR   = 0;
    pSerAMBA->LCR_H = 0;
    pSerAMBA->LCR_M = 0;
    pSerAMBA->LCR_L = 0;
    pSerAMBA->CR    = 0;
    pSerAMBA->FR    = 0;
    pSerAMBA->IIR   = 0;

    pSer16550->DroppedBytes = 0;
    pSer16550->CTSFlowOff = FALSE;  // Not flowed off yet
    pSer16550->DSRFlowOff = FALSE;  // Not flowed off yet
    pSer16550->CommErrors   = 0;
    pSer16550->ModemStatus  = 0;

    EnterCriticalSection(&(pSer16550->RegCritSec));
    try {


        DEBUGMSG (ZONE_OPEN,
                  (TEXT("SL_Open Setting DCB parameters\r\n")));

        // Get defaults from the DCB structure
        SL_SetBaudRate( pHead, pSer16550->dcb.BaudRate );
        SL_SetByteSize( pHead, pSer16550->dcb.ByteSize );
        SL_SetStopBits( pHead, pSer16550->dcb.StopBits );
        SL_SetParity(   pHead, pSer16550->dcb.Parity );

        // Set default data bits.
        pSerAMBA->LCR_H = (AMBA_UARTLCR_H_WLEN_8 | AMBA_UARTLCR_H_FEN);
        OUTB(pSerAMBA, pUART_LCR_H, pSerAMBA->LCR_H);

        // For CE 3.0, we are still supporting
        // the old style MDDs, and they don't call our PostInit, which
        // needs to happen sometime prior to this.  So for now, we go ahead
        // ahead and clear out interrupts one last time.  In 4.0, we can
        // kill the old serial MDD and assume that everyone uses the new
        // MDD and calls post init.  
        SL_PostInit(pHead);

        ReadFR((PSER_INFO)pHead);
        ReadRSR((PSER_INFO)pHead);

        // Enable ints and UART.
        pSerAMBA->CR = (CR_NORMAL_INTS | AMBA_UARTCR_TIE);
        OUTB(pSerAMBA, pUART_CR, pSerAMBA->CR);
    }
    except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ?
            EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH) {
        // Just get out of here.
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看不卡视频| 91精品国产麻豆| 91精品综合久久久久久| 久久新电视剧免费观看| 亚洲大片在线观看| 岛国一区二区三区| 日韩欧美国产一区二区三区| 日韩理论片网站| 国产精品18久久久| 欧美成人猛片aaaaaaa| 性做久久久久久免费观看| 成人免费视频一区| 国产午夜亚洲精品午夜鲁丝片| 亚洲bt欧美bt精品777| 91亚洲精品乱码久久久久久蜜桃 | 激情综合网天天干| 欧美综合在线视频| 亚洲欧美激情在线| 成人av在线观| 中文字幕欧美日韩一区| 韩国一区二区三区| 亚洲精品在线网站| 久久99精品久久久久久动态图| 5858s免费视频成人| 亚洲国产欧美日韩另类综合 | 三级成人在线视频| 日本道在线观看一区二区| 综合久久久久久| 91丨九色丨蝌蚪丨老版| 国产亚洲一二三区| 成人av网站在线| 最新欧美精品一区二区三区| www.66久久| 亚洲美女电影在线| 欧洲一区在线观看| 亚洲第一在线综合网站| 精品视频在线免费观看| 天天影视色香欲综合网老头| 88在线观看91蜜桃国自产| 亚洲成人免费视频| 欧美刺激脚交jootjob| 麻豆国产精品一区二区三区| 精品国产露脸精彩对白| 国产宾馆实践打屁股91| 国产精品你懂的在线欣赏| 91蜜桃网址入口| 五月婷婷欧美视频| 日韩女优电影在线观看| 国产福利一区二区| 亚洲婷婷综合久久一本伊一区| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 国产91色综合久久免费分享| 国产精品护士白丝一区av| 欧洲国内综合视频| 免费在线观看日韩欧美| 久久久午夜电影| 91丨九色丨尤物| 青椒成人免费视频| 中日韩免费视频中文字幕| 色婷婷激情综合| 久久国产免费看| 中文字幕一区在线观看| 欧美日韩一区二区欧美激情| 韩国毛片一区二区三区| 亚洲精品成人在线| 日韩久久久精品| 91在线视频在线| 免费欧美在线视频| 亚洲欧美日韩一区二区 | 另类小说图片综合网| 国产精品人人做人人爽人人添| 欧美亚洲综合久久| 国产传媒日韩欧美成人| 亚洲一区二区影院| 国产精品国产三级国产普通话99| 欧美丰满少妇xxxxx高潮对白| 国产精品69久久久久水密桃| 亚洲成av人影院| 国产精品久久久久久久浪潮网站| 欧美一区二区在线免费播放 | 欧美日韩二区三区| 成人免费不卡视频| 日本不卡一区二区三区| 亚洲三级视频在线观看| 精品福利在线导航| 欧美喷水一区二区| 99国产精品久久久| 国产精品自拍毛片| 久久精品国产精品亚洲精品| 夜色激情一区二区| 国产精品美女久久久久久久久久久| 91精品国产综合久久久久久漫画 | 日韩av在线发布| 亚洲男同性视频| 国产精品乱码人人做人人爱| 欧美成人官网二区| 欧美一区二区久久久| 欧美视频一区二| 色激情天天射综合网| 成人激情免费网站| 成人性色生活片免费看爆迷你毛片| 黑人精品欧美一区二区蜜桃| 五月天丁香久久| 亚洲一区二区成人在线观看| 国产精品入口麻豆九色| 国产精品天干天干在线综合| 欧美大片在线观看| 欧美成人激情免费网| 精品久久久久久久久久久久包黑料 | 欧美精品乱码久久久久久| 色综合久久天天| 色噜噜偷拍精品综合在线| 成人免费毛片片v| 丁香婷婷综合色啪| 国产一区二区三区视频在线播放| 裸体在线国模精品偷拍| 麻豆精品在线播放| 国产精品一区在线| 成人免费毛片app| 色伊人久久综合中文字幕| 91啪亚洲精品| 欧美日韩中字一区| 在线中文字幕一区| 欧美丰满嫩嫩电影| 日韩精品中午字幕| 2023国产精品视频| 国产精品日产欧美久久久久| 亚洲丝袜精品丝袜在线| 一区二区三区日韩欧美| 性感美女久久精品| 久久se精品一区精品二区| 狠狠色综合播放一区二区| 风间由美一区二区av101| 91麻豆精品视频| 欧美日韩国产成人在线免费| 精品久久人人做人人爽| 国产精品人妖ts系列视频| 一区二区三区久久| 麻豆精品在线播放| 97精品国产97久久久久久久久久久久| 91看片淫黄大片一级在线观看| 欧美日韩另类一区| 26uuu精品一区二区在线观看| 久久精品一区蜜桃臀影院| 中文字幕一区二区不卡| 天天操天天综合网| 国产成人啪免费观看软件| 91久久线看在观草草青青| 日韩视频一区二区在线观看| 欧美激情一区二区三区蜜桃视频 | 91精品国产色综合久久久蜜香臀| 欧美不卡激情三级在线观看| 综合欧美一区二区三区| 奇米影视一区二区三区小说| 粉嫩一区二区三区在线看 | 99精品热视频| 日韩欧美中文一区二区| 18成人在线观看| 黄一区二区三区| 欧美日韩一区高清| 国产精品欧美综合在线| 日本特黄久久久高潮| zzijzzij亚洲日本少妇熟睡| 欧美精品v国产精品v日韩精品| 国产精品视频免费看| 美女视频网站久久| 欧美在线视频你懂得| 国产欧美日韩视频在线观看| 午夜精品久久久久久久99水蜜桃 | 国产喷白浆一区二区三区| 亚洲va中文字幕| 91视频在线观看免费| 国产欧美精品在线观看| 日本中文在线一区| 欧美私人免费视频| 亚洲女子a中天字幕| 国产sm精品调教视频网站| 欧美日韩视频一区二区| 亚洲欧美激情小说另类| av在线不卡观看免费观看| 国产亚洲综合色| 极品美女销魂一区二区三区| 日韩视频在线你懂得| 午夜精品久久久久久久蜜桃app| 色琪琪一区二区三区亚洲区| 国产精品丝袜一区| 成人黄色网址在线观看| 欧美精品一区二区高清在线观看| 视频一区二区欧美| 欧美日韩成人综合| 亚洲国产日日夜夜| 欧美性做爰猛烈叫床潮| 夜色激情一区二区| 欧美三级韩国三级日本三斤| 亚洲男人的天堂在线观看| 91麻豆免费视频| 一区二区高清免费观看影视大全| 色久综合一二码| 亚洲国产日韩av| 日韩三级视频在线观看|