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

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

?? pdds3c2440_ser.cpp

?? 三星2440 cpu WINCE 5.00板級支持包
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
    if (*pBuffLen == 0) { 
        EnableXmitInterrupt(FALSE);
    }
    else {
        DEBUGCHK(pTxBuffer);
        PulseEvent(m_XmitFlushDone);
        DWORD dwDataAvaiable = *pBuffLen;
        *pBuffLen = 0;
        if ((m_DCB.fOutxCtsFlow && IsCTSOff()) ||(m_DCB.fOutxDsrFlow && IsDSROff())) { // We are in flow off
            DEBUGMSG(ZONE_THREAD|ZONE_WRITE,(TEXT("CPdd16550::XmitInterruptHandler! Flow Off, Data Discard.\r\n")));
            EnableXmitInterrupt(FALSE);
        }
        else  {
            DWORD dwWriteSize = GetWriteableSize();
            DEBUGMSG(ZONE_THREAD|ZONE_WRITE,(TEXT("CPdd16550::XmitInterruptHandler! WriteableSize=%x to FIFO,dwDataAvaiable=%x\r\n"),
                    dwWriteSize,dwDataAvaiable));
            for (DWORD dwByteWrite=0; dwByteWrite<dwWriteSize && dwDataAvaiable!=0;dwByteWrite++) {
                m_pReg2440Uart->Write_UTXH(*pTxBuffer);
                pTxBuffer ++;
                dwDataAvaiable--;
            }
            DEBUGMSG(ZONE_THREAD|ZONE_WRITE,(TEXT("CPdd16550::XmitInterruptHandler! Write %d byte to FIFO\r\n"),dwByteWrite));
            *pBuffLen = dwByteWrite;
            EnableXmitInterrupt(TRUE);        
        }
        ClearInterrupt(S2440UART_INT_TXD);
    }
    m_HardwareLock.Unlock();
}
void    CPdd2440Uart::XmitComChar(UCHAR ComChar)
{
    // This function has to poll until the Data can be sent out.
    BOOL bDone = FALSE;
    do {
        m_HardwareLock.Lock(); 
        if ( GetWriteableSize()!=0 ) {  // If not full 
            m_pReg2440Uart->Write_UTXH(ComChar);
            bDone = TRUE;
        }
        else {
            EnableXmitInterrupt(TRUE);
        }
        m_HardwareLock.Unlock();
        if (!bDone)
           WaitForSingleObject(m_XmitFlushDone, (ULONG)1000); 
    }
    while (!bDone);
}
BOOL    CPdd2440Uart::EnableXmitInterrupt(BOOL fEnable)
{
    m_HardwareLock.Lock();
    if (fEnable)
        EnableInterrupt(S2440UART_INT_TXD);
    else
        DisableInterrupt(S2440UART_INT_TXD);
    m_HardwareLock.Unlock();
    return TRUE;
        
}
BOOL  CPdd2440Uart::CancelXmit()
{
    return InitXmit(TRUE);     
}
static PAIRS s_HighWaterPairs[] = {
    {0, 4 },
    {1, 8 },
    {2, 12 },
    {3, 16 }
};

BYTE  CPdd2440Uart::GetWaterMarkBit()
{
    BYTE bReturnKey = (BYTE)s_HighWaterPairs[0].Key;
    for (DWORD dwIndex=dim(s_HighWaterPairs)-1;dwIndex!=0; dwIndex --) {
        if (m_dwWaterMark>=s_HighWaterPairs[dwIndex].AssociatedValue) {
            bReturnKey = (BYTE)s_HighWaterPairs[dwIndex].Key;
            break;
        }
    }
    return bReturnKey;
}
DWORD   CPdd2440Uart::GetWaterMark()
{
    BYTE bReturnValue = (BYTE)s_HighWaterPairs[0].AssociatedValue;
    for (DWORD dwIndex=dim(s_HighWaterPairs)-1;dwIndex!=0; dwIndex --) {
        if (m_dwWaterMark>=s_HighWaterPairs[dwIndex].AssociatedValue) {
            bReturnValue = (BYTE)s_HighWaterPairs[dwIndex].AssociatedValue;
            break;
        }
    }
    return bReturnValue;
}

// Receive
BOOL    CPdd2440Uart::InitReceive(BOOL bInit)
{
    m_HardwareLock.Lock();    
    if (bInit) {         
        BYTE uWarterMarkBit = GetWaterMarkBit();
        if (uWarterMarkBit> 3)
            uWarterMarkBit = 3;
        // Setup Receive FIFO.
        // Reset Receive Fifo.
        DWORD dwBit = m_pReg2440Uart->Read_UFCON();
        dwBit |= (1<<1);
        dwBit &= ~(1<<0);
        m_pReg2440Uart->Write_UFCON( dwBit);
        // Set Trigger level to WaterMark.
        dwBit &= ~(3<<4);
        dwBit |= (uWarterMarkBit<<4);
        m_pReg2440Uart->Write_UFCON(dwBit); 
        // Enable Receive FIFO.
        dwBit &= ~(1<<1);
        dwBit |= (1<<0);
        m_pReg2440Uart->Write_UFCON(dwBit); // Xmit Fifo Reset Done..
        m_pReg2440Uart->Read_UERSTAT(); // Clean Line Interrupt.
        dwBit = m_pReg2440Uart->Read_UCON();
        dwBit &= ~(3<<0);
        dwBit |= (1<<0)|(1<<7)|(1<<8); // Enable Rx Timeout and Level Interrupt Trigger.
        m_pReg2440Uart->Write_UCON(dwBit);
        EnableInterrupt(S2440UART_INT_RXD | S2440UART_INT_ERR );
    }
    else {
        DisableInterrupt(S2440UART_INT_RXD | S2440UART_INT_ERR );
    }
    m_HardwareLock.Unlock();
    return TRUE;
}
ULONG   CPdd2440Uart::ReceiveInterruptHandler(PUCHAR pRxBuffer,ULONG *pBufflen)
{
    DEBUGMSG(ZONE_THREAD|ZONE_READ,(TEXT("+CPdd2440Uart::ReceiveInterruptHandler pRxBuffer=%x,*pBufflen=%x\r\n"),
        pRxBuffer,pBufflen!=NULL?*pBufflen:0));
    DWORD dwBytesDropped = 0;
    if (pRxBuffer && pBufflen ) {
        DWORD dwBytesStored = 0 ;
        DWORD dwRoomLeft = *pBufflen;
        m_bReceivedCanceled = FALSE;
        m_HardwareLock.Lock();
        
        while (dwRoomLeft && !m_bReceivedCanceled) {
            ULONG ulUFSTATE = m_pReg2440Uart->Read_UFSTAT();
            DWORD dwNumRxInFifo = (ulUFSTATE & (0xf<<0));
            if ((ulUFSTATE & (1<<8))!=0) // Overflow. Use FIFO depth (16);
                dwNumRxInFifo = SER2440_FIFO_DEPTH_RX;
            DEBUGMSG(ZONE_THREAD|ZONE_READ,(TEXT("CPdd2440Uart::ReceiveInterruptHandler ulUFSTATE=%x,UTRSTAT=%x, dwNumRxInFifo=%X\r\n"),
                ulUFSTATE, m_pReg2440Uart->Read_UTRSTAT(), dwNumRxInFifo));
            if (dwNumRxInFifo) {
                ASSERT((m_pReg2440Uart->Read_UTRSTAT () & (1<<0))!=0);
                while (dwNumRxInFifo && dwRoomLeft) {
                    UCHAR uLineStatus = GetLineStatus();
                    UCHAR uData = m_pReg2440Uart->Read_URXH();
                    if (DataReplaced(&uData,(uLineStatus & UERSTATE_PARITY_ERROR)!=0)) {
                        *pRxBuffer++ = uData;
                        dwRoomLeft--;
                        dwBytesStored++;                    
                    }
                    dwNumRxInFifo --;
                }
            }
            else
                break;
        }
        if (m_bReceivedCanceled)
            dwBytesStored = 0;
        
        m_HardwareLock.Unlock();
        *pBufflen = dwBytesStored;
    }
    else {
        ASSERT(FALSE);
    }
    DEBUGMSG(ZONE_THREAD|ZONE_READ,(TEXT("-CPdd2440Uart::ReceiveInterruptHandler pRxBuffer=%x,*pBufflen=%x,dwBytesDropped=%x\r\n"),
        pRxBuffer,pBufflen!=NULL?*pBufflen:0,dwBytesDropped));
    return dwBytesDropped;
}
ULONG   CPdd2440Uart::CancelReceive()
{
    m_bReceivedCanceled = TRUE;
    m_HardwareLock.Lock();   
    InitReceive(TRUE);
    m_HardwareLock.Unlock();
    return 0;
}
BOOL    CPdd2440Uart::InitModem(BOOL bInit)
{
    m_HardwareLock.Lock();   
    m_pReg2440Uart->Write_UMCON((1<<0)); // Disable AFC and Set RTS as default.
    m_HardwareLock.Unlock();
    return TRUE;
}

ULONG   CPdd2440Uart::GetModemStatus()
{
    m_HardwareLock.Lock();    
    ULONG ulReturn =0 ;
    ULONG Events = 0;
    UINT8 ubModemStatus = (UINT8) m_pReg2440Uart->Read_UMSTAT();
    m_HardwareLock.Unlock();

    // Event Notification.
    if (ubModemStatus & (1<<2))
        Events |= EV_CTS;
    if (Events!=0)
        EventCallback(Events);

    // Report Modem Status;
    if ( ubModemStatus & (1<<0) )
        ulReturn |= MS_CTS_ON;
    return ulReturn;
}
void    CPdd2440Uart::SetRTS(BOOL bSet)
{
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_UMCON();
    if (bSet) {
        ulData |= (1<<0);
    }
    else
        ulData &= ~(1<<0);
    m_pReg2440Uart->Write_UMCON(ulData);
    m_HardwareLock.Unlock();

}
BOOL CPdd2440Uart::InitLine(BOOL bInit)
{
    m_HardwareLock.Lock();
    if  (bInit) {
        // Set 8Bit,1Stop,NoParity,Normal Mode.
        //m_pReg2440Uart->Write_ULCON( (0x3<<0) | (0<<1) | (0<<3) | (0<<6) );
        EnableInterrupt( S2440UART_INT_ERR );
    }
    else {
        DisableInterrupt(S2440UART_INT_ERR );
    }
    m_HardwareLock.Unlock();
    return TRUE;
}
BYTE CPdd2440Uart::GetLineStatus()
{
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_UERSTAT();
    m_HardwareLock.Unlock();  
    ULONG ulError = 0;
    if (ulData & (1<<0) ) {
        ulError |=  CE_OVERRUN;
    }
    if (ulData & (1<<1)) {
        ulError |= CE_RXPARITY;
    }
    if (ulData & (1<<2)) {
        ulError |=  CE_FRAME;
    }
    if (ulError)
        SetReceiveError(ulError);
    
    if (ulData & (1<<3)) {
         EventCallback(EV_BREAK);
    }
    return (UINT8)ulData;
        
}
void    CPdd2440Uart::SetBreak(BOOL bSet)
{
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_UCON();
    if (bSet)
        ulData |= (1<<4);
    else
        ulData &= ~(1<<4);
    m_pReg2440Uart->Write_UCON(ulData);
    m_HardwareLock.Unlock();      
}
BOOL    CPdd2440Uart::SetBaudRate(ULONG BaudRate,BOOL /*bIrModule*/)
{
    m_HardwareLock.Lock();
    BOOL bReturn = m_pReg2440Uart->Write_BaudRate(BaudRate);
    m_HardwareLock.Unlock();      
    return TRUE;
}
BOOL    CPdd2440Uart::SetByteSize(ULONG ByteSize)
{
    BOOL bRet = TRUE;
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_ULCON() & (~0x3);
    switch ( ByteSize ) {
    case 5: 
        break;
    case 6:
        ulData|= (1<<0);
        break;
    case 7:
        ulData |= (2<<0);
        break;
    case 8:
        ulData |= (3<<0);
        break;
    default:
        bRet = FALSE;
        break;
    }
    if (bRet) {
        m_pReg2440Uart->Write_ULCON(ulData);
    }
    m_HardwareLock.Unlock();
    return bRet;
}
BOOL    CPdd2440Uart::SetParity(ULONG Parity)
{
    BOOL bRet = TRUE;
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_ULCON() & (~(0x7<<3));
    switch ( Parity ) {
    case ODDPARITY:
        ulData |= (4<<3);
        break;
    case EVENPARITY:
        ulData |= (5<<3);
        break;
    case MARKPARITY:
        ulData |= (6<<3);
        break;
    case SPACEPARITY:
        ulData |= (7<<3);
        break;
    case NOPARITY:
        break;
    default:
        bRet = FALSE;
        break;
    }
    if (bRet) {
        m_pReg2440Uart->Write_ULCON(ulData);
    }
    m_HardwareLock.Unlock();
    return bRet;
}
BOOL    CPdd2440Uart::SetStopBits(ULONG StopBits)
{
    BOOL bRet = TRUE;
    m_HardwareLock.Lock();
    ULONG ulData = m_pReg2440Uart->Read_ULCON() & (~(0x1<<2));

    switch ( StopBits ) {
    case ONESTOPBIT :
        break;
    case TWOSTOPBITS :
        ulData |= (0x1<<2);
        break;
    default:
        bRet = FALSE;
        break;
    }
    if (bRet) {
        m_pReg2440Uart->Write_ULCON(ulData);
    }
    m_HardwareLock.Unlock();
    return bRet;
}
void    CPdd2440Uart::SetOutputMode(BOOL UseIR, BOOL Use9Pin)
{
    m_HardwareLock.Lock();
    CSerialPDD::SetOutputMode(UseIR, Use9Pin);
    ULONG ulData = m_pReg2440Uart->Read_ULCON() & (~(0x1<<6));
    ulData |= (UseIR?(0x1<<6):0);
    m_pReg2440Uart->Write_ULCON(ulData);
    m_HardwareLock.Unlock();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品毛片a∨一区二区三区| 国产精品你懂的| 亚洲1区2区3区4区| 色视频欧美一区二区三区| 国产精品久久久久久久久果冻传媒 | 欧美最猛黑人xxxxx猛交| 亚洲欧洲精品一区二区精品久久久| 国产九九视频一区二区三区| 精品少妇一区二区| 国产主播一区二区三区| 国产日本欧洲亚洲| 粉嫩aⅴ一区二区三区四区五区| 久久久无码精品亚洲日韩按摩| 国产专区欧美精品| 欧美国产日韩在线观看| 成人国产视频在线观看| 中文字幕在线观看不卡| 91色在线porny| 一区二区在线观看视频 | 99久久99久久精品免费观看| 国产精品第四页| 成人黄色大片在线观看| 国产精品久久久久久久裸模| 99久久综合99久久综合网站| 亚洲精品美腿丝袜| 在线观看国产日韩| 亚洲观看高清完整版在线观看| 欧美体内she精高潮| 免费人成网站在线观看欧美高清| 日韩欧美亚洲一区二区| 国产一区二区伦理片| 欧美精品一区二区三区蜜臀| 国产中文字幕一区| 国产午夜精品久久| 91亚洲精品一区二区乱码| 亚洲日韩欧美一区二区在线| 欧美性色黄大片手机版| 日韩中文字幕麻豆| 日韩视频免费观看高清完整版在线观看 | 一区二区三国产精华液| 在线电影院国产精品| 精品中文字幕一区二区| 久久精品欧美日韩| 色噜噜狠狠色综合欧洲selulu| 午夜电影一区二区三区| 精品国产乱码久久久久久闺蜜| 成人在线视频首页| 亚洲国产精品综合小说图片区| 日韩欧美高清在线| www.日韩精品| 日精品一区二区三区| 国产日韩三级在线| 欧美三日本三级三级在线播放| 久色婷婷小香蕉久久| 国产精品久久777777| 欧美精品黑人性xxxx| 国产成人av一区| 亚洲在线视频免费观看| www久久久久| 一本久久综合亚洲鲁鲁五月天 | 久久久久久久久久久电影| 99久久综合色| 美女mm1313爽爽久久久蜜臀| 国产精品免费网站在线观看| 欧美日韩成人一区二区| 国产高清不卡二三区| 亚洲成av人在线观看| 国产人成一区二区三区影院| 欧美午夜一区二区三区免费大片| 经典三级一区二区| 一区二区三区波多野结衣在线观看| 日韩精品一区在线观看| 91久久国产综合久久| 精品在线视频一区| 一二三四社区欧美黄| 国产亚洲午夜高清国产拍精品 | 91欧美一区二区| 久久精品国产精品亚洲综合| 亚洲欧美日韩人成在线播放| 日韩欧美国产综合一区| 色综合天天在线| 国产在线一区二区| 五月天精品一区二区三区| 国产精品美女久久久久久久| 欧美一区二区二区| 在线看国产日韩| 成人污视频在线观看| 免费成人av在线播放| 亚洲黄色免费网站| 国产精品久久久久影院色老大| 日韩欧美中文一区二区| 欧美亚洲一区二区在线观看| 国产成人av福利| 男人的天堂亚洲一区| 一区二区三区精品视频| 国产精品美女久久久久久久网站| 26uuu精品一区二区在线观看| 欧美日韩三级视频| 色婷婷国产精品久久包臀| 成人一道本在线| 久久er99精品| 日韩福利视频网| 亚洲成人av电影| 亚洲精品一二三区| 亚洲日本免费电影| 中文字幕欧美日本乱码一线二线| 精品久久久网站| 欧美一区二区美女| 欧美酷刑日本凌虐凌虐| 一区二区三区四区亚洲| 中文幕一区二区三区久久蜜桃| 欧美大片一区二区| 欧美一级国产精品| 欧美精品日韩一区| 欧美日韩国产一区二区三区地区| 色综合一个色综合亚洲| 99精品黄色片免费大全| 成人免费毛片aaaaa**| 国产一区二区三区最好精华液| 麻豆精品视频在线观看| 人人爽香蕉精品| 人禽交欧美网站| 日本亚洲欧美天堂免费| 三级在线观看一区二区| 婷婷久久综合九色国产成人| 亚洲图片欧美视频| 亚洲电影一区二区三区| 亚洲国产精品欧美一二99| 一区二区三区免费网站| 一区二区三区.www| 亚洲一区二区在线免费看| 亚洲自拍另类综合| 亚洲一级二级三级在线免费观看| 亚洲精品成人在线| 亚洲卡通动漫在线| 一二三区精品福利视频| 亚洲成人777| 免费黄网站欧美| 激情小说欧美图片| 国产精品一区二区你懂的| 国产福利一区在线观看| 不卡视频一二三四| 91欧美一区二区| 欧美日韩高清影院| 欧美一区二区三区视频在线| 欧美tk丨vk视频| 久久天堂av综合合色蜜桃网| 日本一区免费视频| 成人免费一区二区三区视频 | 国产亚洲va综合人人澡精品| 久久久久一区二区三区四区| 国产欧美一区二区精品性| 欧美国产综合色视频| **性色生活片久久毛片| 一区二区视频在线看| 亚洲国产视频网站| 免费在线一区观看| 韩国v欧美v亚洲v日本v| av影院午夜一区| 欧美揉bbbbb揉bbbbb| 91麻豆精品国产91久久久资源速度| 日韩精品中午字幕| 欧美国产禁国产网站cc| 一区二区成人在线视频| 日韩av网站在线观看| 国产精品亚洲一区二区三区妖精 | 国产欧美日韩三级| 亚洲精品成人少妇| 日本成人在线网站| 国产麻豆一精品一av一免费| 成人h精品动漫一区二区三区| 日本乱人伦aⅴ精品| 日韩三级视频在线看| 国产欧美精品一区aⅴ影院| 樱花影视一区二区| 美女高潮久久久| av一区二区三区四区| 欧美日韩精品三区| 久久久精品天堂| 亚洲国产精品久久久久婷婷884| 免费成人av资源网| 91在线你懂得| 欧美大片一区二区三区| 亚洲少妇30p| 免费视频最近日韩| 91麻豆产精品久久久久久| 日韩欧美在线观看一区二区三区| 欧美国产一区在线| 日本不卡视频在线| 国产欧美一区视频| 亚洲欧美日韩中文播放| 三级久久三级久久| 国产一区二区三区免费看| 色综合夜色一区| 欧美刺激脚交jootjob| 亚洲男同性视频| 2024国产精品视频| 亚洲午夜三级在线| 国产馆精品极品| 3751色影院一区二区三区|