最近測試涉及到底層串口代碼的修改。經(jīng)過這次修改,突然發(fā)現(xiàn)其實(shí)自己對于串口的一些特性以前并不是十分清楚。
首先遇到的一些問題:
1)在使用IO的數(shù)據(jù)位的時(shí)候,沒有考慮校驗(yàn)位所占的位數(shù)。
2)在設(shè)置串口輸入的時(shí)候,使用懸空輸入。
關(guān)于1),在一次使用STM32串口參數(shù)9600,N,8,1與另一個(gè) 8051MCU通信的時(shí)候發(fā)現(xiàn)偶校驗(yàn)沒有問題,但是無校驗(yàn)通信就出現(xiàn)異常。但是,當(dāng)將STM32與電腦通信的時(shí)候,偶校驗(yàn)與無校驗(yàn)通信又完全都是正確的。8051MCU單獨(dú)與電腦通信也都是完全正確的。查看代碼,還真不知道有什么不對勁的。因?yàn)檫@段代碼,用了很長時(shí)間了。后來一個(gè)同事看代碼后,提醒說對于數(shù)據(jù)位的設(shè)置,偶校驗(yàn)和無校驗(yàn)是一致的,既然沒有數(shù)據(jù)位,有可能會(huì)少一位。從這點(diǎn)看,這段代碼可以修改看看。于是在這個(gè)地方,將偶校驗(yàn)的時(shí)候數(shù)據(jù)位長度設(shè)置為9bit,無校驗(yàn)的時(shí)候設(shè)置為8bit。重新測試,發(fā)現(xiàn)通信正常了。
原來這段代碼,由于一直用偶校驗(yàn)進(jìn)行通信,所以對于奇校驗(yàn)和無校驗(yàn)的參數(shù)設(shè)置,沒有測試過。雖然,已經(jīng)存在很長時(shí)間,但是由于一直沒有用到奇校驗(yàn)和無校驗(yàn),于是這個(gè)BUG。一直潛伏到現(xiàn)在。直到這次使用到才發(fā)現(xiàn)。
關(guān)于2),是在一次使用中發(fā)現(xiàn),串口線的連接如果與從機(jī)分離,則串口上會(huì)莫名接收到一些00數(shù)據(jù)。一開始沒有在意,以為是離開確定電平后,導(dǎo)致的什么干擾造成的。但是,沒有去考慮是什么造成接收這么容易受干擾。直到有一次,和同事確認(rèn)串口的初始化電平設(shè)置時(shí),他告訴說是懸空設(shè)置。這下子感覺不對了,懸空很容易造成受干擾。于是馬上查看串口的初始化代碼,發(fā)現(xiàn)確實(shí)是懸空設(shè)置。馬上修改了。在測試,將連接的串口懸空,也沒有再收到。
后來查看了關(guān)于串口的內(nèi)容發(fā)現(xiàn)以前有些東西沒有注意到:
串口分為同步串口,異步串口。
這里說的串口指通常說的UART,異步串行通信接口。
還有就是同步串口,即SPI,I2C之類。
首先,UART不需要接收和發(fā)送兩端嚴(yán)格的時(shí)鐘同步,在不通信的時(shí)候IO電平呈現(xiàn)高電平,即空閑。所以對于UART來說,如果沒有數(shù)據(jù)交互,數(shù)據(jù)線是呈現(xiàn)高電平的。
對于UART的數(shù)據(jù)位問題,是包含數(shù)據(jù) 校驗(yàn)的bit數(shù)總和。
為了提高UART的抗干擾性,無論在哪一種工作模式下,都能夠保證數(shù)據(jù)線上有穩(wěn)定的電平。所以串口設(shè)置時(shí),對于串口輸入引腳設(shè)置為上拉輸入。對于串口的設(shè)置,輸出一般設(shè)置為push-pull,輸入一般設(shè)置為pull up。
(這里有一個(gè)疑問,為什么串口還會(huì)留下懸空輸入?既然一般情況下,上拉輸入對于接收方而言會(huì)處于一個(gè)比較穩(wěn)定的狀態(tài)。如果將輸入設(shè)置為懸空輸入反而會(huì)引入接收不穩(wěn)定的因素,為什么會(huì)有懸空輸入。在什么地方,又會(huì)使用懸空輸入呢?在不同電壓的時(shí)候可能是一種情況,及3.3VTTL電平的CPU,與5.0VTTL的CPU直接使用串口通信的時(shí)候,為了避免電平問題采用懸空有可能是一個(gè)種情況。)
這里也提出一個(gè)問題,對于系統(tǒng)的底層代碼要格外嚴(yán)謹(jǐn)。保證開發(fā)出來的代碼,有高的穩(wěn)定性,可靠性。才能保證其他程序順利開發(fā)。
同時(shí)對于代碼的測試要盡可能覆蓋所有代碼。對于開發(fā)過程中,引入的功能及代碼要進(jìn)行實(shí)際測試,明確其執(zhí)行到的時(shí)候?qū)τ诔绦虻挠绊憽]有運(yùn)行過的代碼,在程序中就是一座可能噴發(fā)的活火山。所以對于添加的功能及代碼,要確保執(zhí)行過。
在開發(fā)過程中,要時(shí)刻保持警惕,警惕可能出現(xiàn)異常的地方,學(xué)著用推理去找到BUG的巢穴。
上一篇:51單片機(jī)中的定時(shí)器和計(jì)數(shù)器
下一篇:輸入輸出設(shè)備I/O設(shè)備總結(jié)
推薦閱讀
史海拾趣
設(shè)計(jì)資源 培訓(xùn) 開發(fā)板 精華推薦
- 全主動(dòng)懸架國產(chǎn)化落地,未來也能“人人買得起”?
- 第三方激光雷達(dá)ASIC方案,能改變行業(yè)格局嗎?
- 為何端到端成為各車企智駕布局的首要選擇?
- 智能網(wǎng)聯(lián)汽車組合駕駛輔助系統(tǒng)安全要求立項(xiàng)制定,東風(fēng)、華為等參與起草
- 從高精地圖到VLA,一場技術(shù)路線的競速
- 韓國團(tuán)隊(duì)開發(fā)自動(dòng)駕駛軟件 透明障礙物識別準(zhǔn)確率達(dá)96%
- OpenGMSL?聯(lián)盟宣告成立 推動(dòng)未來車載連接技術(shù)變革
- 高通完成對V2X芯片企業(yè)Autotalks收購,強(qiáng)化車聯(lián)網(wǎng)通信
- “磷酸鐵鋰需求激增,寧德時(shí)代等電池巨頭鎖定未來五年大單”
- 面壁智能端側(cè)大模型首日上線,英特爾工程師聯(lián)合優(yōu)化實(shí)現(xiàn)2.2倍推理效率躍升
- Hercules DIY創(chuàng)意大搜集!比比看,誰的設(shè)計(jì)最“安全”?
- 征集|無線充電套件已經(jīng)準(zhǔn)備好,你打算用它做什么?
- “玄鐵杯”第三屆RISC-V應(yīng)用創(chuàng)新大賽—國產(chǎn)高性能RISC-V Linux開發(fā)板LicheePi 4A報(bào)名專場,萬元獎(jiǎng)金,邀您奔赴開源設(shè)計(jì)盛宴
- 半導(dǎo)體品牌知名度問卷調(diào)查
- TI CC1310網(wǎng)絡(luò)研討會(huì)誠邀您預(yù)報(bào)名參加,驚喜獎(jiǎng)不停!
- 有獎(jiǎng)大調(diào)查:你遇到的電源設(shè)計(jì)挑戰(zhàn)有哪些?
- 炎炎盛夏,EEWORLD社區(qū)6月明星人物出爐嘍!
- 安森美半導(dǎo)體工業(yè)物聯(lián)網(wǎng)解決方案下載有驚喜!
- 中微公司:美國防部將AMEC從涉軍企業(yè)名單中刪除
- 俄羅斯世界杯激情背后,成了家電產(chǎn)業(yè)的戰(zhàn)場?
- 高端安全芯片一騎絕塵,紫光國微或開啟可轉(zhuǎn)債申購
- Sonos發(fā)布Beam智能音響,可實(shí)現(xiàn)哪些功能?
- 毛軍發(fā)院士:異質(zhì)集成電路 繞道摩爾定律
- 白電三巨頭年中報(bào) 從市占率看行業(yè)現(xiàn)狀
- 優(yōu)劣幾何?三角法和TOF 激光雷達(dá)大解析
- 脫離“AI泡沫” 垂直家電企業(yè)改念“健康經(jīng)”
- 人工掏糞或?qū)⒊蔀檫^去!印度創(chuàng)企研發(fā)下水道清潔機(jī)器人
- 瑞薩電子以67億美元收購芯片創(chuàng)企IDT 深入自動(dòng)駕駛領(lǐng)域
- TB5128FTG 的衰減動(dòng)作的時(shí)序分析
- 關(guān)于開關(guān)電源選型的問題
- 5v怎么轉(zhuǎn)到6v求大神給個(gè)電路圖做參考
- 加載程序時(shí),彈出如下提示
- “少校總裁”的十年創(chuàng)業(yè)——華清遠(yuǎn)見成長之路
- 6月8日在深圳有李龍文老師的會(huì),有人愿意同去么?
- 了解一下現(xiàn)在大學(xué)里單片機(jī)教材都以什么類型的單片機(jī)為主了?
- 產(chǎn)業(yè)亂彈之——安防監(jiān)控品牌
- 火車模型收藏:機(jī)械魅力延續(xù)兒時(shí)的夢想
- 空中職場加油站指點(diǎn)就業(yè)迷津:“三套車”助你成功求職