新聞中心

EEPW首頁 > 測試測量 > 設(shè)計應(yīng)用 > 基于LabVIEW的CSDB總線數(shù)據(jù)測試

基于LabVIEW的CSDB總線數(shù)據(jù)測試

作者: 時間:2010-09-15 來源:網(wǎng)絡(luò) 收藏

本文分析和研究了的協(xié)議,并介紹了通過計算機的RS-232串口及相應(yīng)電平轉(zhuǎn)換電路,基于7.1軟件開發(fā)平臺實現(xiàn)的計算機與UUT的雙向通信。其中,支持通信的軟件實現(xiàn)是關(guān)鍵。

本文引用地址:http://2s4d.com/article/195296.htm

  


  圖1 結(jié)構(gòu)

  協(xié)議簡介

  CSDB總線體系結(jié)構(gòu)的物理層規(guī)定了總線的機械特性和電氣特性;鏈路層給出了幀的定義以及幀之間的定時要求,并對總線連接的各種航空設(shè)備的參數(shù)做出了詳細的規(guī)定。

  物理層

  CSDB是單向廣播式異步串行總線標準,它可以構(gòu)成單信源、多接收器的傳輸系統(tǒng)。總線數(shù)據(jù)采用NRZ編碼,全雙工差分方式傳輸。CSDB信號的數(shù)據(jù)格式與RS-232-C標準完全相同,都為異步串行通信格式,即:一個起始位、八個數(shù)據(jù)位、一個奇偶校驗位、一個停止位,其電氣標準為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稱為標識 (或地址),消息塊都是通過標識來區(qū)分的。消息塊的長度是固定不變的,為6字節(jié)。CSDB采用的是異步串行傳輸方式,通過起始位和停止位完成字節(jié)的位同步,因此,在編碼中不必帶有時鐘信息。幀同步通過識別同步消息塊6個字節(jié)的十六進制“A5”來實現(xiàn),同步消息塊標識了每個數(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)換、通信同步、實現(xiàn)。

  

  圖2 CSDB總線信號通信原理框圖

  通信配置

  (1)電氣轉(zhuǎn)換

  CSDB總線信號經(jīng)過電氣轉(zhuǎn)換芯片后直接與計算機進行串口通信。在進行RS-422-A到RS-232的電氣標準轉(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的基準時鐘輸入信號作為主數(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。


上一頁 1 2 下一頁

關(guān)鍵詞: LabVIEW CSDB 總線 數(shù)據(jù)

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉