新聞中心

EEPW首頁 > 測試測量 > 設計應用 > 基于TCP/IP的多數(shù)據流傳輸測控系統(tǒng)的設計與實現(xiàn)

基于TCP/IP的多數(shù)據流傳輸測控系統(tǒng)的設計與實現(xiàn)

作者: 時間:2012-05-31 來源:網絡 收藏

1.3 遠程控制臺模塊
遠程控制臺負責對數(shù)傳與實時處理模塊、控制臺模塊的網絡喚醒和網絡監(jiān)控,以及完成對遠程設備電源的相關操作。遠程控制臺接收相鄰模塊的網絡數(shù)據幀(包括數(shù)傳與實時處理模塊對多進行整合的數(shù)據幀和控制臺模塊轉發(fā)的單片機采集數(shù)據幀),對控制臺發(fā)送網絡控制幀(完成參數(shù)設置、系統(tǒng)開啟關閉、板卡操作、串口操作等任務),采用UDP協(xié)議進行通信。
1.4 控制臺設備模塊
控制臺設備模塊由CPCI工控計算機和繼電器板卡組成。供電電源繼電器卡采用NI PXI-2564 16路5 A SPST開關模塊,它是大功率繼電器卡,可進行電源輸入和電源備份;斷電及轉電控制信號繼電器卡采用ADLINK PXI-7901 16路通用SPDT開關模塊,可進行電源的控制切換。系統(tǒng)結構及外部接口關系如圖3所示。

b.jpg


系統(tǒng)采用Agilent N6700系列模塊電源供電,控制臺由RS 422串行通信接口連接到單片機測控模塊、網絡連接到遠程控制臺。為通信的穩(wěn)定可靠,控制臺與遠程控制臺間的千兆以太網通過光電轉換器轉為光纖連接??刂婆_接受遠程控制臺的控制,對來自單片機采集模塊的數(shù)據進行解碼及顯示并傳向遠程控制臺,通信采用UDP協(xié)議。

2 軟件設計與實現(xiàn)
2.1 多重事件方式實現(xiàn)網口及串口通信
控制臺模塊需要接收遠程控制臺的遠程控制命令幀和來自RS 422串行通信接口(與單片機采集模塊相連)的串行數(shù)據,并把串行數(shù)據打包成既定格式UDP數(shù)據幀轉發(fā)送到遠程控制臺,為此控制臺軟件需建立后臺管理器(CTConManager)來開啟網絡監(jiān)控線程、串口監(jiān)控線程兩個獨立線程進行監(jiān)控網口和串行口。二者流程圖如圖4所示。

d.jpg


軟件需要把串口數(shù)據進行協(xié)議轉換為UDP數(shù)據幀發(fā)送,所以網絡監(jiān)控線程采用等待多重事件的方式來處理由WSACreateEvent函數(shù)創(chuàng)建的網絡事件(m_evtNetWork)和串口事件(m_evtOverlappedSeira1),串口監(jiān)控流程采用異步事件模式監(jiān)控串行口的數(shù)據接收。網絡事件由WSAEvent Select函數(shù)與當前的socket接口綁定,串口事件由串口接收一個完整數(shù)據幀后設置到網絡監(jiān)控線程。當控制臺網絡可以接收到遠程控制臺的網絡幀(即有網絡事件發(fā)生)時,線程調用ProcessNetworkEvent函數(shù)來處理這個事件(即開始解析遠程命令幀),相應串口事件調用網絡監(jiān)控線程的ProcessSerialEvent函數(shù)來處理這個事件(即發(fā)送數(shù)據幀)。線程中的網絡超時事件(WSA_WAIT_TIME OUT)處理超時任務(ProcessTimeOut Event)包括串口和板卡狀態(tài)的循環(huán)檢測以及狀態(tài)數(shù)據包的發(fā)送。
軟件采用這種機制能及時響應多重事件,實現(xiàn)了串口和網絡接口的對接,節(jié)省了設備資源,使系統(tǒng)效率得到了提高。
2.2 整合同步處理
根據系統(tǒng)要求,數(shù)傳與實時處理模塊將多個流的相同或不同字段的數(shù)據進行提取并整合為一個UDP數(shù)據報文并發(fā)送至遠程控制臺。
由于多個發(fā)送過程中很可能會出現(xiàn)某個數(shù)據流到達時間相對其他數(shù)據流有延遲,這就會造成在整合為UDP數(shù)據報文的過程中數(shù)據的不同步。為解決這個問題,軟件采用基于數(shù)據隊列的方式實現(xiàn)碼流同步。首先將多個既定長度的TCP流數(shù)據(TCPDataValue)加入(push)多個相應隊列(CDataQueue),當所有隊列的長度大于等于1,即所有隊列有元素時,將隊列中的第一個(即最先壓入隊列)元素彈出(GetFirstDa ta),然后進行碼流的數(shù)據提取。

tcp/ip相關文章:tcp/ip是什么




評論


相關推薦

技術專區(qū)

關閉