基于LabVIEW的CSDB總線數(shù)據(jù)測試
本文分析和研究了CSDB總線的協(xié)議,并介紹了通過計算機的RS-232串口及相應(yīng)電平轉(zhuǎn)換電路,基于LabVIEW7.1軟件開發(fā)平臺實現(xiàn)的計算機與UUT的雙向通信。其中,支持通信的軟件實現(xiàn)是關(guān)鍵。
本文引用地址:http://www.ex-cimer.com/article/195296.htm
CSDB總線體系結(jié)構(gòu)的物理層規(guī)定了總線的機械特性和電氣特性;數(shù)據(jù)鏈路層給出了數(shù)據(jù)幀的定義以及數(shù)據(jù)幀之間的定時要求,并對總線連接的各種航空設(shè)備的參數(shù)做出了詳細的規(guī)定。
物理層
CSDB是單向廣播式異步串行總線標(biāo)準(zhǔn),它可以構(gòu)成單信源、多接收器的傳輸系統(tǒng)。總線數(shù)據(jù)采用NRZ編碼,全雙工差分方式傳輸。CSDB信號的數(shù)據(jù)格式與RS-232-C標(biāo)準(zhǔn)完全相同,都為異步串行通信格式,即:一個起始位、八個數(shù)據(jù)位、一個奇偶校驗位、一個停止位,其電氣標(biāo)準(zhǔn)為RS-422-A。
數(shù)據(jù)鏈路層
CSDB總線是面向字節(jié)的傳輸協(xié)議,固定長度的字節(jié)組成消息塊,再由一定長度的消息塊組合成幀,封裝在數(shù)據(jù)幀中的不同數(shù)據(jù)通過各自的地址字節(jié)加以區(qū)別,不同的數(shù)據(jù)幀之間通過同步消息塊分割。CSDB總線數(shù)據(jù)結(jié)構(gòu)如圖1所示。
在圖1中,消息塊(Message Block)的第一個字節(jié)Byte 0稱為標(biāo)識 (或地址),消息塊都是通過標(biāo)識來區(qū)分的。消息塊的長度是固定不變的,為6字節(jié)。CSDB采用的是異步串行傳輸方式,通過起始位和停止位完成字節(jié)的位同步,因此,在編碼中不必帶有時鐘信息。幀同步通過識別同步消息塊6個字節(jié)的十六進制“A5”來實現(xiàn),同步消息塊標(biāo)識了每個數(shù)據(jù)幀的開始位置。
其中:t1=幀時間長=1/最大更新率
t2=消息塊間隙時間長(無限制)
t3=總線空閑時間(最小11bit的時間)
t4=字節(jié)間隙時長(無限制)
CSDB總線信號測試
測試原理
對CSDB總線信號進行測試,是先將CSDB信號電平轉(zhuǎn)換為和計算機適應(yīng)的RS-232電平,再根據(jù)CSDB總線的規(guī)則,實現(xiàn)對控制信息的正確發(fā)送和實時反饋信息的正確接收,并根據(jù)需要,將有用信息提出送測試系統(tǒng)處理,完成對航空機載設(shè)備的自動化測試。具體步驟分為信號電氣轉(zhuǎn)換、通信同步、LabVIEW實現(xiàn)。
圖2 CSDB總線信號通信原理框圖
通信配置
(1)電氣轉(zhuǎn)換
CSDB總線信號經(jīng)過電氣轉(zhuǎn)換芯片后直接與計算機進行串口通信。在進行RS-422-A到RS-232的電氣標(biāo)準(zhǔn)轉(zhuǎn)換時,使用MAX488全雙工電平轉(zhuǎn)換芯片。
(2)通信同步
CSDB總線為異步串行通信,按照串行數(shù)據(jù)傳輸?shù)幕驹?,實現(xiàn)正確通信的基本條件是保持接收和發(fā)送雙方時鐘一致,以避免發(fā)送與接收雙方的數(shù)據(jù)位寬產(chǎn)生累積誤差,造成不能正確檢測到總線數(shù)據(jù)。在串行通信中,信息是按位傳送的,傳送速率用波特率表示,數(shù)據(jù)的發(fā)送和接收受各自的時鐘控制,因此,發(fā)送方和接收方的波特率應(yīng)保持一致。經(jīng)對具體部品測試,CSDB數(shù)據(jù)總線數(shù)據(jù)波特率為12.5Kbit/s,為與此同步,要求計算機產(chǎn)生的波特率也應(yīng)為12.5Kbit/s。
如圖2所示,在計算機中負責(zé)串行通信的器件為8250異步通信適配器(UART),或其兼容元器件,程序通過對8250內(nèi)部的寄存器讀寫來控制通信模式,8250使用頻率為1.8432MHz的基準(zhǔn)時鐘輸入信號作為主數(shù)據(jù)時鐘,通過對8250內(nèi)部寄存器置位來獲得需要的波特率。在異步串行通信中,為防止由于信號畸形、不同步等原因造成對數(shù)據(jù)的誤讀,通信適配器規(guī)定每讀取或發(fā)送1bit數(shù)據(jù)至少要用16個時鐘脈沖來控制其波特率,實際應(yīng)用中波特率時鐘是主時鐘的1/16或1/(16×N),對于要求的波特率,在寫寄存器時用如下公式計算除數(shù)因子:
除數(shù)因子=(主數(shù)據(jù)時鐘頻率/16)/波特率=115200/波特率
在算出除數(shù)因子后,將相應(yīng)數(shù)據(jù)寫入8250內(nèi)部的波特率設(shè)置寄存器,即可在串口得到相應(yīng)波特率的數(shù)據(jù)。經(jīng)計算,115200除以12500后不為整數(shù),所以,受到計算機異步通信適配器8250的限制,在波特率設(shè)置上不能完全和12.5Kbit/s相同,經(jīng)計算,當(dāng)除數(shù)因子取9時對應(yīng)的波特率為12.8Kbit/s,與CSDB總線要求的波特率最為接近,其每bit占據(jù)78?S,相對80?S/bit(12.5Kbit/s)誤差為0.25%,小于串行通信波特率最大容許誤差5%,理論上可實現(xiàn)通信同步,因此在程序上將通信的波特率設(shè)置為12.8Kbit/s。
評論