一種基于協(xié)議的提高RS-485總線實(shí)時(shí)性的設(shè)計(jì)方案
0 引言
RS-485總線具有結(jié)構(gòu)簡單、成本低廉、通信速率高、傳輸距離遠(yuǎn)等諸多優(yōu)點(diǎn),因而被廣泛應(yīng)用于工廠自動(dòng)化、工業(yè)控制、安全監(jiān)控等領(lǐng)域。RS-485一般采用半雙工的通信方式,即在整個(gè)網(wǎng)絡(luò)中任一時(shí)刻只能有一個(gè)節(jié)點(diǎn)處于發(fā)送狀態(tài)并向總線發(fā)送數(shù)據(jù),如果有兩個(gè)或兩個(gè)以上節(jié)點(diǎn)同時(shí)向總線發(fā)送數(shù)據(jù),將會(huì)導(dǎo)致所有發(fā)送的數(shù)據(jù)發(fā)送失敗,即所謂的總線沖突。
為了避免總線沖突,整個(gè)RS-485通信系統(tǒng)一般由一個(gè)主節(jié)點(diǎn)、多個(gè)從節(jié)點(diǎn)組成。數(shù)據(jù)通信一般采用主節(jié)點(diǎn)輪詢各個(gè)從節(jié)點(diǎn)的方式。各個(gè)從節(jié)點(diǎn)有自己的通信地址,只有主節(jié)點(diǎn)輪詢幀中的地址信息與自己的地址相同時(shí),此從節(jié)點(diǎn)才會(huì)進(jìn)行應(yīng)答,其他從節(jié)點(diǎn)則忽略此幀,不做任何處理。這種傳統(tǒng)的主從調(diào)度方式雖然不會(huì)引起總線沖突,但是也存在著一些局限性。從節(jié)點(diǎn)需要發(fā)送數(shù)據(jù)必須等到主節(jié)點(diǎn)輪詢到自身,系統(tǒng)的通信效率較低,總線的利用率也較低。每個(gè)從節(jié)點(diǎn)在一個(gè)輪詢周期中只有一次發(fā)送數(shù)據(jù)的機(jī)會(huì),有實(shí)時(shí)性要求的信息得不到及時(shí)發(fā)送,系統(tǒng)的實(shí)時(shí)性較差。
為了提高RS-485通信系統(tǒng)的實(shí)時(shí)性,目前國內(nèi)外已進(jìn)行了一些研究工作,大多采用對RS-485進(jìn)行軟硬件改造使其具有多主結(jié)構(gòu)的方法,使得從節(jié)點(diǎn)能夠隨機(jī)發(fā)送數(shù)據(jù)。提出的實(shí)現(xiàn)方法是將RS-485接口芯片的數(shù)據(jù)接收引腳通過一反相器接到CPU的外部中斷引腳,用觸發(fā)中斷的方式判斷總線上是否有數(shù)據(jù)傳輸,同時(shí)結(jié)合定時(shí)器中斷判斷總線是否空閑;如果總線空閑就獲得總線控制權(quán)發(fā)送數(shù)據(jù),然后用監(jiān)聽自己發(fā)送數(shù)據(jù)的方法判斷是否發(fā)生總線沖突,如果發(fā)生沖突,則隨機(jī)延時(shí)一段時(shí)間,再重新偵聽發(fā)送的方法也與之類似。這些方法一般需要額外的硬件資源,需要對原設(shè)備進(jìn)行硬件改造;方法中提到的碰撞處理一般都采用CSMA/CD的隨機(jī)退避算法,實(shí)現(xiàn)較為復(fù)雜,而且時(shí)間不可預(yù)計(jì),不能保證實(shí)時(shí)性要求。
本文提出一種基于協(xié)議的新方法,該方法不需要改造硬件、不需要額外占用資源,只需要對軟件作簡單的修改就能升級RS-485通信系統(tǒng),提高從節(jié)點(diǎn)自主發(fā)送數(shù)據(jù)的能力,從而提高系統(tǒng)的通信效率和實(shí)時(shí)性。
1 工作原理
通信系統(tǒng)仍舊采用一個(gè)主節(jié)點(diǎn)、多個(gè)從節(jié)點(diǎn)的結(jié)構(gòu),主節(jié)點(diǎn)每次在輪詢完一個(gè)從節(jié)點(diǎn)以后,留出一段空隙時(shí)間給從節(jié)點(diǎn)按需主動(dòng)上傳信息。從節(jié)點(diǎn)如果有實(shí)時(shí)性要求的信息需要上傳,除了在主節(jié)點(diǎn)輪詢到自身時(shí)可以上傳,在空隙時(shí)也能上傳。首先規(guī)定從節(jié)點(diǎn)在空隙上傳數(shù)據(jù)的先后順序,即上傳機(jī)會(huì)的獲取機(jī)制,一種方法是按優(yōu)先級分配時(shí)間片,從節(jié)點(diǎn)只能在獲取了規(guī)定的發(fā)送機(jī)會(huì)時(shí)利用空隙上傳數(shù)據(jù)。如果在一個(gè)空隙中,有多個(gè)從節(jié)點(diǎn)需要上傳數(shù)據(jù),從節(jié)點(diǎn)需要在等待屬于自己的發(fā)送機(jī)會(huì)時(shí)偵聽總線的狀態(tài),如果偵聽到總線上已經(jīng)有其他節(jié)點(diǎn)進(jìn)行了數(shù)據(jù)傳輸,則從節(jié)點(diǎn)必須放棄這次空隙上傳的機(jī)會(huì),等待下次空隙。
通過理論分析可以比較本文提出的新方法與傳統(tǒng)的輪詢方式的實(shí)時(shí)性。一個(gè)傳輸單元由1位起始位、8位數(shù)據(jù)位、1位校驗(yàn)位、1位停止位組成,一個(gè)傳輸單元的傳輸時(shí)間稱為字節(jié)時(shí)間Tbyte,波特率為baudrate,則:
設(shè)主節(jié)點(diǎn)發(fā)送的輪詢幀長度為Lmaster,從節(jié)點(diǎn)回復(fù)的數(shù)據(jù)幀長度固定為Lslave,從節(jié)點(diǎn)數(shù)量為N,假設(shè)所有從節(jié)點(diǎn)都正常,去除收發(fā)狀態(tài)切換、幀間隔、程序處理等時(shí)間影響,則一個(gè)輪詢周期Tcycle理想的理論值為:
若采用本文提出的新方法,假設(shè)從節(jié)點(diǎn)的有實(shí)時(shí)性要求的信息平均需x(0xN-1)次空隙才能夠獲取總線,則響應(yīng)時(shí)間Tresponse′平均值為:
當(dāng)x=N-1時(shí),響應(yīng)時(shí)間Tresponse′最大值為:
采用新方法的實(shí)時(shí)數(shù)據(jù)平均響應(yīng)時(shí)間更短,系統(tǒng)的實(shí)時(shí)性更好。
由式(3)與式(6)可知,采用新方法的響應(yīng)時(shí)間在最差情況下比傳統(tǒng)輪詢方式的最差情況的響應(yīng)時(shí)間更長,大約為其2倍。綜合上述分析,新方法與傳統(tǒng)方法的實(shí)時(shí)性由平均所需空隙次數(shù)x決定,新方法適用于各從節(jié)點(diǎn)的有實(shí)時(shí)性要求的信息產(chǎn)生的時(shí)間比較離散,碰撞較少的場合。
2 軟件實(shí)現(xiàn)
與傳統(tǒng)輪詢方式相比,新方法的軟件實(shí)現(xiàn)的主要不同是從節(jié)點(diǎn)空隙時(shí)間的處理。其主要包括兩部分,一部分為總線狀態(tài)偵聽,一部分為空隙中發(fā)送機(jī)會(huì)的獲取判斷,流程圖如圖1所示。總線狀態(tài)偵聽的具體實(shí)現(xiàn)方法有許多種,可以使用串口中斷來偵測總線是否有數(shù)據(jù)傳輸,不需要額外使用其他資源。串口在完整接收完一個(gè)字節(jié)數(shù)據(jù)后會(huì)產(chǎn)生一個(gè)中斷,所以如果從節(jié)點(diǎn)在等待自己的時(shí)段時(shí)產(chǎn)生了串口接收中斷,則表明總線上有數(shù)據(jù)傳輸,總線為忙碌狀態(tài)。
評論