標(biāo)題: 串口通信踩坑指南 [打印本頁(yè)]

作者: guysxpf    時(shí)間: 2021-1-6 11:36
標(biāo)題: 串口通信踩坑指南
今天在研究串口調(diào)試的時(shí)候發(fā)現(xiàn)了一個(gè)極其吊詭的現(xiàn)象。
單片機(jī)從下位機(jī)發(fā)送字符“A”(二進(jìn)制 01000001)給上位機(jī),但上位機(jī)始終受到的是“”(二進(jìn)制00000101)


于是乎我打開(kāi)示波器,但發(fā)現(xiàn)其波形與理論上的波形沒(méi)有任何區(qū)別。




發(fā)送的 01000001 為何會(huì)變成 00000101。經(jīng)過(guò)分析后大概知道了其中的緣故。


由于停止位和下一個(gè)起始位離得太近。如果上位機(jī)非常不巧地把數(shù)據(jù)位當(dāng)成了起始位,那么所有的數(shù)據(jù)就完全錯(cuò)位了,就像圖中那樣。
所以建議發(fā)送每個(gè)字節(jié)之間加上一點(diǎn)延時(shí)。防止這種極端的情況發(fā)生

作者: ping264888    時(shí)間: 2021-1-6 15:41
嗯, 是不是把停止位設(shè)置長(zhǎng)一點(diǎn)會(huì)有改善.
作者: qq863    時(shí)間: 2021-1-6 17:22
如果用軟件模擬的串口,發(fā)生這種情況的概率會(huì)不小,如果是硬件模塊發(fā)送出現(xiàn)這種情況建議換器件,帶緩沖的發(fā)送器會(huì)在發(fā)送移位寄存器為空時(shí)自動(dòng)把緩沖器內(nèi)的數(shù)據(jù)裝入移位寄存器,接收反之。接收一般會(huì)在檢測(cè)到起始位的中點(diǎn)(由波特率算出)對(duì)RX引腳進(jìn)行采樣,由于波特率的誤差累計(jì),數(shù)據(jù)幀越長(zhǎng),采樣點(diǎn)就會(huì)前后移動(dòng),偏離數(shù)據(jù)位中心。一般的經(jīng)驗(yàn)是:波特率理論誤差0.2%以內(nèi),加上振蕩器誤差2%(內(nèi)部、最大),則數(shù)據(jù)幀長(zhǎng)度不超過(guò)128位,這樣粗略計(jì)算在接收最后一位時(shí)采樣點(diǎn)偏移不超過(guò)30%,相對(duì)安全
作者: guysxpf    時(shí)間: 2021-1-6 21:32
ping264888 發(fā)表于 2021-1-6 15:41
嗯, 是不是把停止位設(shè)置長(zhǎng)一點(diǎn)會(huì)有改善.

嗯嗯,差不多是這么個(gè)道理
作者: guysxpf    時(shí)間: 2021-1-6 21:42
qq863 發(fā)表于 2021-1-6 17:22
如果用軟件模擬的串口,發(fā)生這種情況的概率會(huì)不小,如果是硬件模塊發(fā)送出現(xiàn)這種情況建議換器件,帶緩沖的發(fā) ...

其實(shí)硬件串口也沒(méi)有那么糟糕,而且只要主頻足夠高,波特率誤差就可以足夠小。

核心問(wèn)題還是上位機(jī)采樣時(shí)機(jī)晚了、或者說(shuō)單片機(jī)太"著急"了,我覺(jué)得串口有必要遵循一定的邏輯步驟。例如,在程序里加一步"按鈕觸發(fā)",單片機(jī)啟動(dòng)后先不發(fā)字符,然后上位機(jī)打開(kāi)串口等待接收,單片機(jī)按下按鍵觸發(fā)中斷開(kāi)始發(fā)送字符。這樣其實(shí)可以不需要每次發(fā)送字符都要延時(shí),也可以非常完美地傳輸數(shù)據(jù)。




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1