找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2267|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

串口通信踩坑指南

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:224104 發(fā)表于 2021-1-6 11:36 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
今天在研究串口調(diào)試的時候發(fā)現(xiàn)了一個極其吊詭的現(xiàn)象。
單片機從下位機發(fā)送字符“A”(二進制 01000001)給上位機,但上位機始終受到的是“”(二進制00000101)


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




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


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

評分

參與人數(shù) 1黑幣 +40 收起 理由
admin + 40 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:365802 發(fā)表于 2021-1-6 15:41 | 只看該作者
嗯, 是不是把停止位設(shè)置長一點會有改善.

評分

參與人數(shù) 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復(fù)

使用道具 舉報

板凳
ID:874380 發(fā)表于 2021-1-6 17:22 | 只看該作者
如果用軟件模擬的串口,發(fā)生這種情況的概率會不小,如果是硬件模塊發(fā)送出現(xiàn)這種情況建議換器件,帶緩沖的發(fā)送器會在發(fā)送移位寄存器為空時自動把緩沖器內(nèi)的數(shù)據(jù)裝入移位寄存器,接收反之。接收一般會在檢測到起始位的中點(由波特率算出)對RX引腳進行采樣,由于波特率的誤差累計,數(shù)據(jù)幀越長,采樣點就會前后移動,偏離數(shù)據(jù)位中心。一般的經(jīng)驗是:波特率理論誤差0.2%以內(nèi),加上振蕩器誤差2%(內(nèi)部、最大),則數(shù)據(jù)幀長度不超過128位,這樣粗略計算在接收最后一位時采樣點偏移不超過30%,相對安全

評分

參與人數(shù) 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復(fù)

使用道具 舉報

地板
ID:224104 發(fā)表于 2021-1-6 21:32 | 只看該作者
ping264888 發(fā)表于 2021-1-6 15:41
嗯, 是不是把停止位設(shè)置長一點會有改善.

嗯嗯,差不多是這么個道理
回復(fù)

使用道具 舉報

5#
ID:224104 發(fā)表于 2021-1-6 21:42 | 只看該作者
qq863 發(fā)表于 2021-1-6 17:22
如果用軟件模擬的串口,發(fā)生這種情況的概率會不小,如果是硬件模塊發(fā)送出現(xiàn)這種情況建議換器件,帶緩沖的發(fā) ...

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

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

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表