串口通訊超時的設置與含義(COMMTIMEOUTS)

COMMTIMEOUTS:COMMTIMEOUTS主要用於串口超時參數設置。COMMTIMEOUTS結構如下: 

typedef struct _COMMTIMEOUTS { 
DWORD ReadIntervalTimeout; 
DWORD ReadTotalTimeoutMultiplier; 
DWORD ReadTotalTimeoutConstant; 
DWORD WriteTotalTimeoutMultiplier; 
DWORD WriteTotalTimeoutConstant; 
} COMMTIMEOUTS,*LPCOMMTIMEOUTS; 

 

間隔超時=ReadIntervalTimeout
總超時   =   ReadTotalTimeoutMultiplier   * 字節數   +   ReadTotalTimeoutConstant 

 

串口讀取事件分爲兩個階段(我以Win32 API函數ReadFile讀取串口過程來說明一下)
第一個階段是:串口執行到ReadFile()函數時,串口還沒有開始傳輸數據,所以串口緩衝區的第一個字節是沒有裝數據的,這時候總超時起作用,如果在總超時時間內沒有進行串口數據的傳輸,ReadFile()函數就返回,當然 沒有讀取到任何數據。而且,間隔超時並沒有起作用。
第二階段:假設總超時爲20秒,程序運行到ReadFile(),總超時開始從0 計時,如果在計時到達10秒時,串口開始了數據的傳輸,那麼從接收的第一個字節開始,間隔超時就開始計時,假如間隔超時爲1ms,那麼在讀取完第一個字節後,串口開始等待1ms,如果1ms之內接收到了第二個字節,就讀取第二個字節,間隔超時重置爲0並計時,等待第三個字節的到來,如果第三個字節到來的時間超過了1ms,那麼ReadFile()函數立即返回,這時候總超時計時是沒到20秒的。如果在20秒總計時時間結束之前,所有的數據都遵守數據間隔爲1ms的約定並陸陸續續的到達串口緩衝區,那麼就成功進行了一次串口傳輸和讀取;如果20秒總計時時間到,串口還陸陸續續的有數據到達,即使遵守字節間隔爲1ms的約定,ReadFile()函數也會立即返回,這時候總超時就起作用了。
總結起來,總超時在兩種情況下起作用
第一:串口沒進行數據傳輸,等待總超時時間那麼長ReadFile()才返回。非正常數據傳輸
第二:數據太長,總超時設置太短,數據還沒讀取完就返回了。讀取的數據是不全的
間隔超時觸發是有條件的
第一:在總超時時間內。
第二:串口進行了數據的傳輸。
成功的進行一次串口數據的傳輸和讀取,只有總超時和間隔超時相互參與配合才能完成

 

轉自https://www.cnblogs.com/visionfeng/p/5614066.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章