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

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

?? xrmdd.c

?? wince 5.0下 實現PCI8串口卡驅動
?? C
?? 第 1 頁 / 共 5 頁
字號:
                       RxBytesAvail(pSerialHead), RxLength(pSerialHead),
                       RoomLeft));


            // If flow control enabled then we need to scan for XON/XOFF
            // characters
            if ( pSerialHead->XFlow ) {
                for ( CharIndex=0; CharIndex < RoomLeft; ) {
                    if ( RxBuffWrite(pSerialHead)[CharIndex] ==
                         pSerialHead->DCB.XoffChar ) {
                        DEBUGMSG (ZONE_FLOW, (TEXT("Received XOFF\r\n")));

                        pSerialHead->StopXmit = 1;
                        memmove (RxBuffWrite(pSerialHead)+CharIndex,
                                 RxBuffWrite(pSerialHead)+CharIndex+1,
                                 RoomLeft - CharIndex);
                        RoomLeft--;
                        continue;
                    } else if ( RxBuffWrite(pSerialHead)[CharIndex] ==
                                pSerialHead->DCB.XonChar ) {
                        pSerialHead->StopXmit = 0;
                        DEBUGMSG (ZONE_FLOW, (TEXT("Received XON\r\n")));
                        memmove (RxBuffWrite(pSerialHead)+CharIndex,
                                 RxBuffWrite(pSerialHead)+CharIndex+1,
                                 RoomLeft - CharIndex);
                        RoomLeft--;
                        // We disabled TX on XOFF, so now we need to start sending
                        // again. Easiest way is to pretend we saw a TX interrupt
                        it |= INTR_TX;
                        continue;
                    }
                    CharIndex++;
                }
            }

            pSerialHead->RxBytes += RoomLeft;
            RxWrite(pSerialHead) = 
                (RxWrite(pSerialHead)+RoomLeft<RxLength(pSerialHead)? RxWrite(pSerialHead)+RoomLeft: RxWrite(pSerialHead)+RoomLeft-RxLength(pSerialHead));
            if ( RoomLeft ) {
                RxDataAvail = TRUE;
            }

            /* Support DTR_CONTROL_HANDSHAKE/RTS_CONTROL_HANDSHAKE
             * signal is cleared when the input buffer is more than 3/4 full.
             */
            if ( (pSerialHead->DCB.fDtrControl == DTR_CONTROL_HANDSHAKE) &&
                 (!pSerialHead->DtrFlow) && 
                 (4*RxBytesAvail(pSerialHead) > (3*RxLength(pSerialHead))) ) {
                DEBUGMSG (ZONE_READ|ZONE_FLOW,
                          (TEXT("DTR_CONTROL_HANDSHAKE Clearing DTR\r\n")));
                pSerialHead->DtrFlow = 1;
                pFuncTbl->HWClearDTR(pHWHead);
            }
            if ( (pSerialHead->DCB.fRtsControl == RTS_CONTROL_HANDSHAKE) &&
                 (!pSerialHead->RtsFlow) &&
                 (4*RxBytesAvail(pSerialHead) > (3*RxLength(pSerialHead))) ) {
                DEBUGMSG (ZONE_READ|ZONE_FLOW,
                          (TEXT("RTS_CONTROL_HANDSHAKE Clearing RTS\r\n")));
                pSerialHead->RtsFlow = 1;
                pFuncTbl->HWClearRTS(pHWHead);
            }

            /* If Xon/Xoff flow control is desired. check the limit against
             * the remaining room and act accordingly.
             */
            if ( pSerialHead->DCB.fInX && !(pSerialHead->SentXoff) &&
                 ( pSerialHead->DCB.XoffLim >=
                   (RxLength(pSerialHead) - RxBytesAvail(pSerialHead))) ) {
                DEBUGMSG (ZONE_FLOW, (TEXT("Sending XOFF\r\n")));
                pFuncTbl->HWXmitComChar(pHWHead, pSerialHead->DCB.XoffChar);

                pSerialHead->SentXoff = 1;
                if ( !pSerialHead->DCB.fTXContinueOnXoff ) {
                    pSerialHead->StopXmit = 1;
                }
            }
        }

        if ( it & INTR_TX ) {
            DEBUGMSG (ZONE_THREAD|ZONE_WRITE , (TEXT("Tx Event\r\n")));
            DoTxData( pSerialHead );
        }

        if ( (it & INTR_MODEM) ) {
            DEBUGMSG (ZONE_THREAD, (TEXT("Other Event, it:%x\r\n"), it));

            /* Call low level status clean up code.
             */
            pFuncTbl->HWModemIntrHandler(pHWHead);
        }

        if ( it & INTR_LINE ) {
            DEBUGMSG (ZONE_THREAD, (TEXT("Line Event, it:%x\r\n"), it));

            /* Call low level line status clean up code.
             * Then unmask the interrupt
             */
            pFuncTbl->HWLineIntrHandler(pHWHead);
        }
    }

    // We kept this till the end to optimize the above loop
    if ( RxDataAvail ) {
        // Signal COM_Read that bytes are available.
        SetEvent(pSerialHead->hReadEvent);
        EvaluateEventFlag(pSerialHead, EV_RXCHAR);
    }

    DEBUGMSG (ZONE_THREAD ,
              (TEXT("-SerialEventHandler, Fifo(R=%d,W=%d,L=%d)\r\n"),
               RxRead(pSerialHead), RxWrite(pSerialHead),
               RxLength(pSerialHead)));

    if ( pSerialHead->pAccessOwner )
        COM_DEC_USAGE_CNT(pSerialHead->pAccessOwner);
    return;
}

/*
 @doc INTERNAL
 @func	ULONG | SerialDispatchThread | Main serial event dispatch thread code.
 *	This is the reading and dispatching thread. It gets the
 *	event associated with the logical interrupt dwIntID and calls
 *	hardware specific routines to determine whether it's a receive event
 *	or a transmit event. If it's a transmit event, it calls the HW tx handler.
 *	If it's a receive event, it calls for the number of characters and calls
 *	atomic GetByte() to extract characters and put them into the drivers
 *	buffer represented by pSerialHead->pTargetBuffer, managing waiting
 *	for events and checking to see if those signals correspond to reading.
 *	It relies on NK masking the interrupts while it does it's thing, calling
 *	InterruptDone() to unmask them for each of the above cases.
 *
 *	Not exported to users.
 *
 @rdesc This thread technically returns a status, but in practice, doesn't return
 *		while the device is open.
 */
static DWORD WINAPI
SerialDispatchThread(
                    PVOID   pContext    /* @parm [IN] Pointer to main data structure. */
                    )
{
    PHW_INDEP_INFO      pSerialHead    = (PHW_INDEP_INFO)pContext;
    ULONG               WaitReturn;

    DEBUGMSG (ZONE_THREAD, (TEXT("Entered SerialDispatchThread %X\r\n"),
                            pSerialHead));

    // It is possible for a PDD to use this routine in its private thread, so
    // don't just assume that the MDD synchronization mechanism is in place.
    if ( pSerialHead->pHWObj->BindFlags & THREAD_IN_MDD ) {
        DEBUGMSG(ZONE_INIT,
                 (TEXT("Spinning in dispatch thread %X %X\n\r"), pSerialHead, pSerialHead->pHWObj));
        while ( !pSerialHead->pDispatchThread ) {
            Sleep(20);
        }
    }

    /* Wait for the event that any serial port action creates.
     */
    while ( !pSerialHead->KillRxThread ) {
        DEBUGMSG (ZONE_THREAD, (TEXT("Event %X, %d\r\n"),
                                pSerialHead->hSerialEvent,
                                pSerialHead->pHWObj->dwIntID ));
        WaitReturn = WaitForSingleObject(pSerialHead->hSerialEvent, INFINITE);

        SerialEventHandler(pSerialHead);
        InterruptDone(pSerialHead->pHWObj->dwIntID);
    }

    DEBUGMSG (ZONE_THREAD, (TEXT("SerialDispatchThread %x exiting\r\n"),
                            pSerialHead));
    return(0);
}

// ****************************************************************
//
//	@doc INTERNAL
//	@func		BOOL | StartDispatchThread | Start thread if requested by PDD.
//
//	@parm 		ULONG  | pSerialHead
//
//	 @rdesc		TRUE if success, FALSE if failed.
//
BOOL
StartDispatchThread(
                   PHW_INDEP_INFO  pSerialHead
                   )
{
    // Initialize the interrupt to be associated with the hSerialEvent
    // event. GetByte waits on this event and acts as a second
    // level decoder determining the type of serial event. If this return
    // fails, then another process has registered for the interrupt, so
    // fail the init and set the hSerialEvent to NULL.
    DEBUGMSG(ZONE_INIT,
             (TEXT("Initializing interrupt 0x%X, 0x%X\n\r"),
              pSerialHead->pHWObj->dwIntID, pSerialHead->hSerialEvent));

    if ( !InterruptInitialize(pSerialHead->pHWObj->dwIntID,
                              pSerialHead->hSerialEvent,
                              NULL,
                              0) ) {
        DEBUGMSG(ZONE_INIT | ZONE_ERROR,
                 (TEXT("Error initializing interrupt\n\r")));
        return(FALSE);
    }

    InterruptDone(pSerialHead->pHWObj->dwIntID);

    // Set up the dispatch thread and it's kill flag. Note that the thread
    // fills in its own handle in pSerialHead.
    pSerialHead->KillRxThread = 0;
    pSerialHead->pDispatchThread = NULL;

    DEBUGMSG(ZONE_INIT,
             (TEXT("Spinning thread%X\n\r"), pSerialHead));

    pSerialHead->pDispatchThread = CreateThread(NULL,0, SerialDispatchThread,
                                                pSerialHead, 0,NULL);
    if ( pSerialHead->pDispatchThread == NULL ) {
        DEBUGMSG(ZONE_INIT|ZONE_ERROR,
                 (TEXT("Error creating dispatch thread (%d)\n\r"),
                  GetLastError()));
        return(FALSE);
    }

    DEBUGMSG (ZONE_INIT, (TEXT("Created receive thread %X\r\n"),
                          pSerialHead->pDispatchThread));     
    return(TRUE);
}

// ****************************************************************
//
//	@doc INTERNAL
//	@func		BOOL | StartDispatchThread | Stop thread, disable interrupt.
//
//	@parm 		ULONG  | pSerialHead
//
//	 @rdesc		TRUE if success, FALSE if failed.
//
BOOL
StopDispatchThread(
                  PHW_INDEP_INFO  pSerialHead
                  )

{
    HANDLE              pThisThread = GetCurrentThread();
    ULONG               priority256;

    /* If we have an interrupt handler thread, kill it */
    if ( pSerialHead->pDispatchThread ) {
        DEBUGMSG (ZONE_INIT, (TEXT("\r\nTrying to close dispatch thread\r\n")));        

        /* Set the priority of the dispatch thread to be equal to this one,
         * so that it shuts down before we free its memory. If this routine
         * has been called from SerialDllEntry then RxCharBuffer is set to
         * NULL and the dispatch thread is already dead, so just skip the
         * code which kills the thread.
         */
        priority256 = CeGetThreadPriority(pThisThread);
        CeSetThreadPriority(pSerialHead->pDispatchThread, priority256);        

        /* Signal the Dispatch thread to die.
         */
        pSerialHead->KillRxThread = 1;
        DEBUGMSG (ZONE_INIT, (TEXT("\r\nTrying to signal serial thread.\r\n")));
        SetEvent(pSerialHead->hSerialEvent);

        WaitForSingleObject(pSerialHead->hKillDispatchThread, 3000);
        Sleep(10);

        DEBUGMSG (ZONE_INIT, (TEXT("\r\nTrying to call CloseHandle\r\n")));

        CloseHandle(pSerialHead->pDispatchThread);
        pSerialHead->pDispatchThread = NULL;        
        DEBUGMSG (ZONE_INIT, (TEXT("\r\nReturned from CloseHandle\r\n")));
    }

    if ( pSerialHead->pHWObj ) {
        /* Ack any remaining interrupts and unregister the event from the
         * logical interrupt.
         */
        InterruptDone(pSerialHead->pHWObj->dwIntID);
        InterruptDisable(pSerialHead->pHWObj->dwIntID);
    }

    return(TRUE);
}


/*
 *  @doc INTERNAL
 *	@func		BOOL | ApplyDCB | Apply the current DCB.
 *
 *	This function will apply the current DCB settings to the device.
 *	It will also call to the PDD to set the PDD values.
 */
BOOL
ApplyDCB (PHW_INDEP_INFO pSerialHead, DCB *pDCB, BOOL fOpen)
{
    PHWOBJ          pHWObj      = pSerialHead->pHWObj;

    if ( !pHWObj->pFuncTbl->HWSetDCB(pSerialHead->pHWHead,
                                     pDCB) ) {
        return(FALSE);
    }

    if ( !fOpen ) {
        return(TRUE);
    }

	// If PDD SetDCB was successful, save the supplied DCB and
	// configure port to match these settings.
    memcpy(&(pSerialHead->DCB), pDCB, sizeof(DCB));

    if ( pSerialHead->DCB.fDtrControl == DTR_CONTROL_DISABLE ) {
        pHWObj->pFuncTbl->HWClearDTR(pSerialHead->pHWHead);
    } else if ( pSerialHead->DCB.fDtrControl == DTR_CONTROL_ENABLE ) {
        pHWObj->pFuncTbl->HWSetDTR(pSerialHead->pHWHead);
    }

    if ( pSerialHead->DCB.fRtsControl == RTS_CONTROL_DISABLE ) {
        pHWObj->pFuncTbl->HWClearRTS(pSerialHead->pHWHead);
    } else if ( pSerialHead->DCB.fRtsControl == RTS_CONTROL_ENABLE ) {
        pHWObj->pFuncTbl->HWSetRTS(pSerialHead->pHWHead);
    }

    if ( pSerialHead->DCB.fDtrControl == DTR_CONTROL_HANDSHAKE ) {
        if ( (!pSerialHead->DtrFlow) && 
             (4*RxBytesAvail(pSerialHead) > (3*RxLength(pSerialHead))) ) {
            DEBUGMSG (ZONE_READ|ZONE_FLOW,
                      (TEXT("IOCTL:DTR_CONTROL_HANDSHAKE Clearing DTR\r\n")));
            pSerialHead->DtrFlow = 1;
            pHWObj->pFuncTbl->HWClearDTR(pSerialHead->pHWHead);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲麻豆国产自偷在线| 亚洲一二三四在线| 国产精品午夜在线观看| 国产精品视频免费| 亚洲综合激情另类小说区| 久久国产精品色| 99精品视频一区二区| 欧美日韩成人一区| 国产欧美一区二区三区鸳鸯浴 | 中文字幕在线一区免费| 亚洲国产成人av网| 国产999精品久久久久久绿帽| 99精品视频一区二区三区| 日韩欧美一区二区视频| 樱花影视一区二区| 国产精品资源在线看| 在线观看欧美黄色| 国产嫩草影院久久久久| 日韩av二区在线播放| 欧美精选在线播放| 亚洲精品视频在线观看免费 | 欧美无砖砖区免费| 亚洲欧洲国产日韩| 韩国一区二区在线观看| 69成人精品免费视频| 亚洲男女毛片无遮挡| av动漫一区二区| 国产精品色婷婷| 精品一区二区三区影院在线午夜| 色8久久精品久久久久久蜜| 欧美国产一区视频在线观看| 99re视频精品| 久久精品在这里| 丁香啪啪综合成人亚洲小说| 日韩欧美一二区| 久久精品久久精品| 精品国产一区久久| 韩国成人精品a∨在线观看| 91精品国产综合久久久久久久久久 | 一级精品视频在线观看宜春院| 91福利精品第一导航| 亚洲国产综合人成综合网站| 在线免费不卡视频| 日韩高清电影一区| 久久精品一区二区三区不卡 | 国产网站一区二区三区| 成人免费看片app下载| 国产精品丝袜91| 欧美偷拍一区二区| 日韩中文字幕一区二区三区| 1024成人网| 国产永久精品大片wwwapp| 亚洲少妇屁股交4| 欧美在线观看18| 黑人巨大精品欧美黑白配亚洲| 国产午夜精品久久| 欧美变态凌虐bdsm| 国产日韩欧美精品一区| 国产精品久久久久久久第一福利 | 日韩美女视频19| 国产精品国产三级国产aⅴ中文| 国产一区不卡在线| 丁香一区二区三区| 色婷婷久久综合| 7777精品伊人久久久大香线蕉的| 日韩欧美视频在线| 国产精品青草久久| 亚洲成人免费视| 精品一区二区日韩| 99国产欧美另类久久久精品| 国产亚洲女人久久久久毛片| 欧美色综合网站| 欧美一区在线视频| 国产精品女主播在线观看| 亚洲女女做受ⅹxx高潮| 日韩电影免费在线| 国产激情一区二区三区四区| 97se亚洲国产综合在线| 91精品国产91久久久久久一区二区| 欧美mv和日韩mv的网站| 亚洲蜜桃精久久久久久久| 免费成人在线观看| 色综合天天综合在线视频| 日韩欧美www| 中文字幕亚洲一区二区av在线| 午夜精彩视频在线观看不卡| 国产精选一区二区三区| 欧美视频精品在线| 久久久天堂av| 午夜一区二区三区视频| 国产成人免费视频网站高清观看视频| 欧亚洲嫩模精品一区三区| 2022国产精品视频| 亚洲午夜私人影院| 成人国产电影网| 日韩三级伦理片妻子的秘密按摩| 亚洲色图.com| 国产99精品视频| 日韩视频免费观看高清完整版| 亚洲欧洲99久久| 国产美女av一区二区三区| 欧美日韩一区二区三区高清| 国产精品久久久久国产精品日日| 久久精品国产久精国产| 欧美三级在线视频| 国产精品久久二区二区| 国产一区二区三区美女| 日韩久久久久久| 亚洲成年人影院| 色欧美日韩亚洲| 国产精品三级av| 国产成a人无v码亚洲福利| 欧美成人一区二区三区在线观看| 亚洲国产精品麻豆| 97久久精品人人爽人人爽蜜臀| 久久久99久久| 狠狠色丁香婷婷综合| 91精品综合久久久久久| 亚洲国产sm捆绑调教视频| 91亚洲精品久久久蜜桃| 中文av一区二区| 国产99精品视频| 欧美国产一区二区| 粉嫩av一区二区三区粉嫩| 亚洲精品一区二区在线观看| 午夜欧美电影在线观看| 欧美在线|欧美| 洋洋成人永久网站入口| 色婷婷综合中文久久一本| 国产成人综合网站| 国产丝袜欧美中文另类| 国产黄色精品网站| 欧美高清在线精品一区| 成人免费看片app下载| 国产午夜精品久久| 成人深夜在线观看| 亚洲欧洲精品一区二区三区| av资源站一区| 国产精品国产三级国产普通话99| 成人免费高清在线| 国产精品国产a级| av成人老司机| 亚洲日本欧美天堂| 日本韩国精品在线| 亚洲超碰精品一区二区| 日韩一区二区影院| 国产大陆精品国产| 中文字幕一区日韩精品欧美| 91视频在线观看免费| 亚洲美腿欧美偷拍| 欧美精品色综合| 蜜桃视频一区二区| 国产网站一区二区| 色拍拍在线精品视频8848| 图片区小说区国产精品视频| 欧美草草影院在线视频| 成人免费av在线| 一区二区久久久久| 日韩无一区二区| 国v精品久久久网| 亚洲精品视频一区| 欧美年轻男男videosbes| 久久99久久久欧美国产| 中文一区在线播放| 欧美性做爰猛烈叫床潮| 精品在线一区二区三区| 国产精品国产a| 精品视频一区 二区 三区| 老司机免费视频一区二区三区| 国产欧美一区二区精品秋霞影院| 99精品国产91久久久久久| 亚洲影院理伦片| 久久精品一区四区| 欧美日韩一区国产| 久久99精品一区二区三区| 亚洲国产精品av| 91精品国产一区二区三区| 国产成人综合网站| 亚洲国产精品精华液网站| 久久亚洲欧美国产精品乐播| 一本到不卡精品视频在线观看| 久久69国产一区二区蜜臀| 亚洲天堂2014| 精品国产一区二区三区不卡| 99re这里都是精品| 久久精品久久久精品美女| 一区二区三区中文字幕精品精品| 久久综合九色综合97婷婷女人 | 蜜乳av一区二区| 日韩毛片精品高清免费| 日韩一区二区视频在线观看| 91免费观看国产| 精品夜夜嗨av一区二区三区| 亚洲乱码精品一二三四区日韩在线| 欧美电影免费观看高清完整版在 | 欧美一级高清片| 欧美在线视频不卡| 高清不卡在线观看| 国精产品一区一区三区mba视频| 亚洲午夜一二三区视频|