基于USB總線通信數(shù)據(jù)采集器的設(shè)計與實現(xiàn)
AT89C52的控制程序分為初始化、主循環(huán)和中斷服務(wù)3部分。初始化部分完成單片機和所有外圍電路(包括PDIUSBD12)的初始化;主循環(huán)部分等待來自上位機的命令或來自終端設(shè)備的數(shù)據(jù);中斷服務(wù)程序完成相應(yīng)的中斷處理功能。下面列出了中斷服務(wù)程序的處理過程:
usb_isr( )interrupt( )
{DISABLE
fn_usb_isr( );
ENABLE
}
void fn_usb_isr( )
{unsigned int i_st
bEPPflags.bits.in_isr=1;
i_st=D12_ReadInterruptRegister( );//讀中斷寄存器
if(i_st !=0)
{ if(i_stD12_INT_BUSRESET)
{ bus_reset( );//總線復(fù)位處理
bEPPflags.bits.bus_reset=1;
}
if(i_stD12_INT_EOT)
dma_eot( );//DMA結(jié)束處理
if(i_st Dl2_INT_SUSPENDCHANGE)
bEPPflags.bits.suspend=1;
if(i_st Dl2_INT_ENDPOIN)
ep0-txdone( );//控制端點0輸入
if(i_stD12_INT_ENDPOOUT)
ep0-rxdone( );//控制端點0輸出
if(i_stD12_INT_ENDPlIN)
epl_txdone( );//端點1輸入
if(i_stD12_INT_ENDPlOUT)
epl_rxdone( );//端點1輸出
if(i_stDl2_INT_ENDP2IN)
main_txdone( );//主端點2輸入
if(i_stD12_INT_ENDP20UT)
main-rxdone( );//主端點2輸出
}
bEPPflags.bits.in_isr=0;
}
設(shè)備安裝完后準備運行前,操作人員可利用上位機管理軟件提供的用戶界面初始化一些系統(tǒng)參數(shù),如總線類型、終端類型等。在執(zhí)行對終端單元的智能識別時,MCU首先接收一個上位機客戶服務(wù)軟件下傳的指令幀,經(jīng)過確認是協(xié)議識別指令后,上傳一個表示就緒的狀態(tài)幀。然后,接收識別用的數(shù)據(jù)幀,經(jīng)過檢驗,如果數(shù)據(jù)幀有錯就返回相應(yīng)的狀態(tài)幀并等待上位機重新發(fā)出數(shù)據(jù),如果數(shù)據(jù)正確則先返回狀態(tài)幀,然后開始對終端單元的識別與數(shù)據(jù)采集。
對一個固定的終端而言,MCU發(fā)出握手信號,遠方終端返回相應(yīng)的信息,數(shù)據(jù)經(jīng)RS232/RS485接收,經(jīng)過MCU的協(xié)議解析后得到所需的純數(shù)據(jù),將其暫存入RAM62256中的指定地址;當上位機發(fā)出讀取數(shù)據(jù)的命令后MCU將數(shù)據(jù)經(jīng)PDIUSBD12傳給上位機。
4.2 上位機的程序設(shè)計
從上位機來看,通信數(shù)據(jù)采集器為它的一個USB外設(shè),因此上位機必須提供USB外設(shè)的驅(qū)動程序。上位機的管理軟件包括客戶服務(wù)程序和USB驅(qū)動程序。USB驅(qū)動程序(USBD)是駐留在上位機的為客戶提供通用服務(wù)的軟件實體,它管理主控制器上的一個或多個功能。它通過調(diào)用適當?shù)闹骺刂破黩?qū)動程序(HCD)將用戶I/O請求包(IRP)中的數(shù)據(jù)轉(zhuǎn)化為設(shè)備端點的數(shù)據(jù),或通過回調(diào)適當?shù)腍CD將設(shè)備端點的數(shù)據(jù)轉(zhuǎn)化為客戶IRP中的數(shù)據(jù)。
客戶服務(wù)程序是用VC++6.0編寫的,主要完成數(shù)據(jù)的分析顯示功能。MCU上傳的數(shù)據(jù)信息經(jīng)過相應(yīng)的校驗,如有誤,則通知終端重傳;如無誤,則將校驗后的信息轉(zhuǎn)存人計算機指定的內(nèi)存,并備份到相應(yīng)的文檔,供其他的客戶服務(wù)程序使用。
USB驅(qū)動程序的編寫往往是USB設(shè)備開發(fā)過程中最困難的,通常采用Windows DDK來實現(xiàn)。目前有許多軟件廠商提供各種各樣的驅(qū)動程序生成工具,如Computer ware的Driver Studio,Blue Waters的Driver Wizard等。本設(shè)計是采用Driver Studio軟件生成的程序框架,添加了適當?shù)挠脩舸a,完成了適合于通信數(shù)據(jù)采集器的驅(qū)動程序的編寫。
5 通信數(shù)據(jù)采集器與傳統(tǒng)數(shù)據(jù)采集方式通信效率的比較
以采集歐姆龍公司的可編程邏輯控制器(PLC)為例,一次采集30個通道,每個通道16個開關(guān)量(即4個十六進制數(shù)),則有120個十六進制數(shù)需要采集和傳輸,加上通信協(xié)議中的其它位,一幀共有131個字符,每一個字符又按串行通信中的一幀11位來發(fā)送,則共有1441位ASCII碼有待傳輸。若波特率設(shè)為9600b/s,則每采集一次需要用時150ms,在此期間每一幀的接收、效驗工作都需CPU的介入。若以傳統(tǒng)的方式進行數(shù)據(jù)的采集和通信,那么主機CPU在這段時間就被串行通信的事務(wù)占用而不能處理其它工作,這很耽誤時間。而采用通信數(shù)據(jù)采集器代替主機來完成這一費時的工作后,數(shù)據(jù)的采集、傳輸以及協(xié)議的解析都不需占用主機的時間,解析后的純數(shù)據(jù)經(jīng)過PDIUS-BDl2上傳也僅需很短時間即可完成(大約為0.12ms,PDIUSBD12在同步模式下的數(shù)據(jù)傳輸率為1Mb/s),通信效率比傳統(tǒng)方式提高了很多倍,這樣就把主機從通信瓶頸中解放出來,為主機節(jié)省了大量的時間去完成其它工作。
6 結(jié)論
本文提出的基于USB總線的智能通信數(shù)據(jù)采集器具有數(shù)據(jù)采集和通信的效率高,結(jié)構(gòu)簡單,運行可靠,使用方便等優(yōu)點,在實際應(yīng)用中取得了良好的效果。它適用于實時監(jiān)控、數(shù)據(jù)采集等場合,也可以增強協(xié)議識別和協(xié)議解析功能,因而在有標準通信協(xié)議和規(guī)范化的數(shù)據(jù)格式而缺少詳細技術(shù)資料的終端設(shè)備的通信中具有廣泛的使用價值。
光電開關(guān)相關(guān)文章:光電開關(guān)原理
評論