什么是串口通信
串口通信,就是傳數(shù)據(jù)只有一根線傳輸,一次只能傳一個位,要傳一個字節(jié)就需要傳8次。串口通信就是把數(shù)據(jù)串在一根線上傳輸,所以就叫串口吧。
在對速率要求不高的情況,使用一根線發(fā)送數(shù)據(jù)是帶來大大的方便和實(shí)用價值的。
為了能正常發(fā)送和接收正確的數(shù)據(jù),那異步串口通信就需要如下圖的格式。
在串口的通信參數(shù)上,就有了波特率、起始位、數(shù)據(jù)位、校驗(yàn)位、停止位這幾個參數(shù)。
串口通信主要為分232,485,422三種通信方式,這三種有什么區(qū)別呢?
232
232通信主要是由RX、TX、GND三根線組成。STM32串口通信相關(guān)實(shí)例:按下按鍵,通過串口發(fā)送數(shù)據(jù)實(shí)例。
RX接TX,TX接RX,GND接GND。這里發(fā)送和接收分別是由不同的線處理的,也就是能同時發(fā)送數(shù)據(jù)和接收數(shù)據(jù),這就是所謂的全雙工通信。
在這里擴(kuò)展一下,串口通信還有一個功能叫做全功能串口通信,也叫標(biāo)準(zhǔn)串口。因?yàn)樵趦蓚€設(shè)備間進(jìn)行數(shù)據(jù)傳輸,有些設(shè)備處理速度比較快,有些數(shù)據(jù)比較慢。為了保證數(shù)據(jù)能正常傳輸,在RX、TX的基礎(chǔ)上,還增加了幾個控制引腳,最后成了9個引腳,也就是常見的DB9這個東西,如下圖所示。
但是,如今很多控制器、人機(jī)界面、PLC等使用串口通信中一般不使用標(biāo)準(zhǔn)串口,而是直接使用RX、TX、GND三根線來通信的。
485
485的出現(xiàn),是為了解決232通信距離受限的問題。
485通信只需要+、-兩根線,或者也叫A、B兩根線。A,B兩根線的差分電平信號就是作為數(shù)據(jù)信號傳輸。由于發(fā)送與接收都是用這兩根線,也就是說每次只能用作發(fā)送或者只能用作接收。所以,485是半雙工通信。
485就是這樣犧牲了232全雙工的效率來達(dá)到自己傳輸距離遠(yuǎn)的代價。
422
422的出現(xiàn),是為了既實(shí)現(xiàn)232的全雙工通信方式,又能像485這樣提高傳輸距離。422也常被標(biāo)注為485-4,而485被標(biāo)注為485-2。因?yàn)?85-2是2根線,485-4是4根線,下圖是422的示意圖。??
422就是把232的RX分成兩根線,RX+,RX-,把TX分成TX+,TX-。這樣就可以同時發(fā)送和同時接收了,還可以像485這樣,有較遠(yuǎn)的傳輸距離??墒沁@樣一種很有優(yōu)勢的通信方式,卻用的不多,最常用到的是232跟485。
串口通信常見問題
電腦使用USB轉(zhuǎn)串口可以和設(shè)備通信上,換成屏與設(shè)備就通信不上了
1)有可能電腦USB轉(zhuǎn)串口接到設(shè)備上,使用的是標(biāo)準(zhǔn)串口功能,也就是除了RX,TX,GDN外,還使用了其它引腳。比如像歐姆龍PLC,三菱PLC,在實(shí)際與屏的通信中,就需要接某些引腳短接的情況。
2)電腦與控制器或PLC通信時,是掃描波特率參數(shù),自適應(yīng)的,屏通信可能參數(shù)沒有設(shè)備好。在三菱,基恩士等PLC,就存在變化波特率進(jìn)行通信交互的過程。
3)也有可能是接線方式不對。因?yàn)橛行〥B9,還需要公頭,母頭。如果不注意的話,也會存在把TX接到TX上,把RX接到RX上,這樣需要注意的地方。
4)?在這里補(bǔ)充一下,有時候可能會使用一些串口助手發(fā)送測試數(shù)據(jù)與控制器通信,有些串口助手的奇偶校驗(yàn)是不起作用,這個要提醒一下。
這A家的屏可以和設(shè)備通信,換成B家的屏就通信不上了
1)?首先確認(rèn)一下接線是否正確了,RX和TX是否兼容。
2)?地線是否沒有接。
3)?除了RX,TX,GND,是否還有其它引腳需要短接的。
4)?通信協(xié)議是否一致或不完善,波特率是否一樣。
以前不接地線可以通信,換個設(shè)備為什么需要接地線了
這個問題和上一個類似,因?yàn)橛行┰O(shè)備使用了隔離電源。以前不接地可以通信,有可能實(shí)際上地線已經(jīng)接了,所以才可以通信??赡軗Q了個帶隔離電源的,兩個設(shè)備的地是隔離的,就需要在串口上把地線接起來。這個我是自身經(jīng)歷過的,有個客戶老說他的設(shè)備通信不上,后來拍個照我給我,他地線沒有接,他說以前不接地線可以通信的。于是我就給他科普了一下。
一個設(shè)備是232,另一個設(shè)備是422,沒有轉(zhuǎn)換設(shè)備,怎么辦
這個情況我遇到過,客戶的設(shè)備是422通信的,但是我手上并沒有422設(shè)備,只有232通信可以測試。因此就需要把422轉(zhuǎn)成232進(jìn)行通信。
剛才也講了422和232的接線,因?yàn)檫@兩個都是全雙工的,接收和發(fā)送都是分到的,而422只是以一種差分信號進(jìn)行傳輸。
把422的Rx+與232的TX接,422的RX-與232的GND接。
把422的TX+與232的RX接,422的TX-與232的GDN接。
這樣,422設(shè)備要發(fā)送數(shù)據(jù)的,就可以發(fā)送到了232的RX上。232的TX發(fā)數(shù)據(jù)后,由于TX和GND也形成了差分信號給422,422就可以接收到數(shù)據(jù)了。
用232通信沒問題,用485通信沒問題,使用232轉(zhuǎn)485之后就通信不穩(wěn)定
232和485從通信原理上,最大一個差別是全雙工和半雙工的區(qū)別。可是應(yīng)用層發(fā)送數(shù)據(jù)和接收數(shù)據(jù)才不管底下是全雙工還是半雙工。
但是485就得管了。因?yàn)榧热皇前腚p工,就得嚴(yán)格保證通路上只能有發(fā)送或只能有接收的數(shù)據(jù),一旦同時有發(fā)送和接收,數(shù)據(jù)就會沖突了。所以解決的辦法就是主站設(shè)備,也就是主動命令的一方就需要嚴(yán)格控制好發(fā)送數(shù)據(jù)命令的節(jié)奏了。當(dāng)然有些232轉(zhuǎn)485的設(shè)備做的比較好了,可以優(yōu)化這個,但是主站還是要控制,比較把通信速率調(diào)節(jié)慢一些。
要想實(shí)現(xiàn)兩個屏或兩個主站通過485訪問modbus設(shè)備,有什么好的辦法
在485通信中,基本上是一主多從。但是遇到一些客戶實(shí)際使用中,有客戶想用兩個屏來訪問一個modbus設(shè)備的。目前暫時還沒有好的辦法。等這個功能出來后,再來給大家演示操作吧。
串口通信的弱點(diǎn)
1)信號干擾的問題
建議使用帶屏蔽線,接線要嚴(yán)格,比如要接地。有些485通信上,還考慮接上終端電阻來匹配。如果是232,盡量不要讓線太長。通信協(xié)議上盡量避免長報文的數(shù)據(jù)通信。
2)波特率匹配的問題
因?yàn)橛行┰O(shè)備的計算的波特率是存在誤差的,特別是一些控制器,由于使用的晶振不一樣。因此在一些波特率比如9600波特率就存在誤差。存在誤差帶來的影響是什么呢。因?yàn)榻邮辗绞峭ㄟ^時間來計算一個位的。那么如果一個報文過長,就會存在誤差積累的問題,算著算著就偏了。所以,這也是串口通信不穩(wěn)定的一些地方,在使用上應(yīng)注意避免發(fā)送太長數(shù)據(jù)的包。
3)在一些可能會存在干擾的情況,可以考慮使用奇校驗(yàn)或者偶校驗(yàn)
因?yàn)殡m說出現(xiàn)錯誤的可能性不大,但既然存在干擾,如果加了校驗(yàn),至少可以把錯誤的報文過濾掉??偤帽葲]有校驗(yàn)然后通信數(shù)據(jù)錯了不知道。或者盡量使用一些帶校驗(yàn)的協(xié)議,防止數(shù)據(jù)出錯。
4)?串口通信本來就比較慢,請降低對數(shù)據(jù)響應(yīng)的要求
因?yàn)榇谕ㄐ疟旧砭捅?a target="_blank">以太網(wǎng)慢。而且,串口通信并不是能像CPU那樣多線程處理。因?yàn)榫鸵粋€口一個線數(shù)據(jù)出去,即便你應(yīng)用到程序再怎么用多線程處理數(shù)據(jù),但是最底下也只有一個口出去,一次也只能傳一個位,一個字節(jié)過去。因?yàn)橛锌蛻粼谑褂?600的波特率通信,但是又希望多少的數(shù)據(jù)可以在多少毫秒內(nèi)得到響應(yīng)。
但是串口通信還是要事實(shí)求是,所以正確認(rèn)識串口通信對應(yīng)用,對開發(fā),對溝通都有著很大的幫助的。
為什么不用同步通信
剛才提到,同步通信需要依賴于時鐘信號。這就存在一個問題,這個時鐘信號是誰來發(fā)起呢。在同步通信中,往往需要一個主設(shè)備發(fā)起時鐘信號讀從模塊的數(shù)據(jù)。在實(shí)際中,有屏讀PLC,有屏讀屏的數(shù)據(jù)。而單純地從異步串口通信來說,是沒有主從之說,雙方都是平等的角色,都可以互發(fā)信息,互收信息。而同步通信一般是應(yīng)用于CPU讀一些模塊,由CPU發(fā)起時鐘信號,比如讀SD卡模塊,就可以通過SPI方式,還有一些傳感器模塊。
審核編輯:湯梓紅
評論
查看更多