1引言
通用串行總線( USB)自從 1994年由微軟等公司共同提出到現(xiàn)在人們所熟知的USB2.0,USB技術(shù)不斷發(fā)展成熟。由于具有傳輸速度快、支持熱插拔、即插即用、擴(kuò)展性強(qiáng)等諸多優(yōu)點(diǎn),USB已經(jīng)被廣泛應(yīng)用于各種 PC標(biāo)準(zhǔn)外設(shè)和用戶自定義開發(fā)設(shè)備中。正是由于 USB擁有其他接口(如并口、串口)無法比擬的優(yōu)勢(shì),將 USB接口應(yīng)用到彈載測(cè)量系統(tǒng)地面測(cè)試臺(tái)的設(shè)計(jì)中,其通用性可擴(kuò)展性強(qiáng),能夠提高讀數(shù)速度、簡(jiǎn)化電路設(shè)計(jì)及驅(qū)動(dòng)程序開發(fā)。
完整的 USB系統(tǒng)除了硬件電路外,還包括驅(qū)動(dòng)程序、單片機(jī)固件程序。固件是 USB系統(tǒng)的核心,它要響應(yīng)各種來自系統(tǒng)的 USB設(shè)備請(qǐng)求,完成各種數(shù)據(jù)的交換工作和事件處理,直接影響到 USB接口的數(shù)據(jù)傳輸速度[1]。因此,固件程序的編寫是開發(fā) USB設(shè)備的關(guān)鍵環(huán)節(jié)。
本測(cè)試臺(tái)上采用的是Cypress公司的EZ-USB FX2系列單片機(jī) CY7C68013。實(shí)現(xiàn) USB接口的數(shù)據(jù)通信,CY7C68013可以配置為3種模式:端口模式、 GPIF和Slave FIFO[2]。后兩種模式由于使用FX2的管道連接方法,單片機(jī)的 CPU不參與數(shù)據(jù)傳輸,提高了數(shù)據(jù)傳輸速率,從而廣泛應(yīng)用于圖像、視頻信號(hào)采集等大批量數(shù)據(jù)的傳輸中。但使用這兩種模式進(jìn)行 USB設(shè)備的開發(fā)相對(duì)較復(fù)雜,開發(fā)周期長(zhǎng)。至于端口模式,文獻(xiàn)中很少有介紹,由于這種模式下 CPU參與了數(shù)據(jù)傳輸,因此傳輸速率相對(duì)較慢 [3],不過端口模式開發(fā)簡(jiǎn)單,可以降低工程人員的開發(fā)難度,縮短開發(fā)周期。本測(cè)試臺(tái)中傳輸數(shù)據(jù)量較少,傳輸速率也要求不高,因此本設(shè)計(jì)采用端口模式。 測(cè)試臺(tái)系統(tǒng)總體框圖彈載測(cè)量系統(tǒng)地面測(cè)試臺(tái)由模擬信號(hào)源、數(shù)字信號(hào)源、圖像信號(hào)源、 PCM碼解調(diào)模塊、實(shí)時(shí)監(jiān)測(cè)等幾部分組成,系統(tǒng)總體框圖如圖 1所示。
500)this.style.width=500;" border="0" />
上位機(jī)通過 USB接口分別下載模擬量、數(shù)字量及圖像數(shù)據(jù)到各自的信號(hào)源存儲(chǔ)器中,而解調(diào)出的PCM碼數(shù)據(jù)和實(shí)時(shí)監(jiān)測(cè)數(shù)據(jù)也是經(jīng)由 USB接口讀回到上位機(jī),從而實(shí)現(xiàn)了USB接口的雙向數(shù)據(jù)傳輸。 3硬件連接
CY7C68013與外圍電路連接如圖 2所示。
500)this.style.width=500;" border="0" />
測(cè)試臺(tái)下載信號(hào)源數(shù)據(jù)時(shí),USB單片機(jī)將數(shù)據(jù)先寫入 FIFO1中,F(xiàn)PGA(XC2S50)通過判斷 FIFO1的空信號(hào)將數(shù)據(jù)讀出;而回讀時(shí) FPGA將數(shù)據(jù)寫入 FIFO2,當(dāng) FIFO2半滿時(shí), USB單片機(jī)產(chǎn)生 FIFO2的讀信號(hào)將數(shù)據(jù)讀出送至上位機(jī)。USB單片機(jī)通過 PE口產(chǎn)生不同的狀態(tài)信號(hào)(Status[7:0])使系統(tǒng)進(jìn)行上述不同操作。 4固件程序設(shè)計(jì)
所有基于微控制器及其外圍電路的功能設(shè)備的正常工作都離不開固件的參與,固件程序是基于微控制器設(shè)備運(yùn)行的核心。固件設(shè)計(jì)的目標(biāo)就是控制硬件來完成預(yù)期的設(shè)備功能。USB設(shè)備也不例外,用戶必須編寫固件程序來輔助硬件完成USB通信任務(wù)。CY7C68013芯片的固件程序負(fù)責(zé)處理上位機(jī)發(fā)來的各種 USB設(shè)備請(qǐng)求,并負(fù)責(zé)控制 CY7C68013與外圍電路進(jìn)行數(shù)據(jù)傳輸,其工作主要包括以下幾點(diǎn)[4]:
(1)初始化工作,包括設(shè)置一些特殊功能寄存器的初值以實(shí)現(xiàn)所需的設(shè)備屬性或者功能; (2) 對(duì)設(shè)備進(jìn)行重新列舉(ReNumeration),主要的工作有:模擬設(shè)備的斷開與重新連接、對(duì)接收到的設(shè)置包進(jìn)行分析判斷、對(duì)主機(jī)的設(shè)備請(qǐng)求作出適當(dāng)?shù)捻憫?yīng),完成主機(jī)對(duì)設(shè)備的配置任務(wù);
(3)響應(yīng)中斷,并對(duì)中斷作相應(yīng)的處理。USB接口在設(shè)備列舉、響應(yīng)主機(jī)標(biāo)準(zhǔn)請(qǐng)求和廠商請(qǐng)求、數(shù)據(jù)傳送等動(dòng)作過程中都會(huì)向微控制器申請(qǐng)中斷,因此微控制器必須正確處理這些中斷才能保證 USB傳輸?shù)恼_M(jìn)行;
(4)數(shù)據(jù)的接收與發(fā)送。USB設(shè)備的主要任務(wù)就是進(jìn)行數(shù)據(jù)的接收和發(fā)送,因此CY7C68013的固件程序必須要對(duì)接收和發(fā)送數(shù)據(jù)的端點(diǎn)進(jìn)行正確的配置及控制,才能正確地接收和發(fā)送數(shù)據(jù);
(5)外圍電路的控制。USB接口要進(jìn)行數(shù)據(jù)傳輸,CY7C68013就必須對(duì)外部 FIFO進(jìn)行讀寫控制,因此固件程序中包含對(duì)外圍電路進(jìn)行控制的代碼也是必要的。
在使用 EZ-USB FX2芯片進(jìn)行應(yīng)用開發(fā)中,利用其固件框架可以簡(jiǎn)化開發(fā)工作。用戶在這個(gè)固件框架的基礎(chǔ)上只需要再提供一個(gè) USB描述符表,配置一些相關(guān)的寄存器,添加所使用的端點(diǎn)接收和發(fā)送數(shù)據(jù)的通信代碼,以及控制外圍電路的程序代碼就可以完成 USB設(shè)備的固件開發(fā)工作。本設(shè)計(jì)中采用的固件框架流程圖如圖 3所示 [5]。
500)this.style.width=500;" border="0" />
Cypress公司為簡(jiǎn)化用戶開發(fā)提供了 EZ-USB固件程序框架。本設(shè)計(jì)中固件包括五個(gè)部分:fw.c(框架源文件)、periph.c(用戶任務(wù)調(diào)度函數(shù)文件)、dscr.a51(描述符表)、 USBJmpTb.OBJ(中斷跳轉(zhuǎn)表)、Ezusb.lib(EZ-USB庫(kù)文件),其中主要對(duì) periph.c和dscr.a51
進(jìn)行了修改。dscr.a51中包含各種描述符,根據(jù)設(shè)計(jì)需要修改了設(shè)備的VID、PID。
periph.c中主要包括 TD_PreInit()、TD_Init()和TD_Poll()函數(shù),TD_PreInit()中包含配置外圍接口的輸入/輸出及設(shè)置端口初始值的代碼。TD_Init()函數(shù)負(fù)責(zé)初始化端點(diǎn)狀態(tài)變量,而實(shí)現(xiàn)數(shù)據(jù)通信的軟件代碼包含在TD_Poll()函數(shù)中。部分代碼如下:
void TD_PreInit(void)
{ PORTACFG = 0x00; OEA = 0xfd; //使能 PA1為輸入,其余 PA口為輸出 IOA = 0xff;//置 PA口為 ffH IOA |= 0x0C; //由PA2口產(chǎn)生FIFO1的復(fù)位信號(hào) PORTECFG = 0x00; OEE = 0xff;} //使能 PE口為狀態(tài)輸出
void TD_Poll(void)
{WORD i; if (PStatus == VCOMMAND_READ) //上位機(jī)發(fā)出讀數(shù)命令 {for ( i=0;i<80;i++)
if (!(IOA & 0x02)) break; //等待外部 FIFO2半滿 if (i<80) { if (!(EP2468STAT & bmEP6FULL)) //FIFO2半滿、EP6不滿,讀 512字節(jié)
{for( i = 0x0000;i < EP6BUFSIZE;i+=16 ){ EXTAUTODAT2 = EXTAUTODAT1; ┆
EXTAUTODAT2 =EXTAUTODAT1;}//一次讀出 16字節(jié),加快讀數(shù)速度設(shè)備請(qǐng)求部分修改了 DR_VendorCmnd()函數(shù)代碼,由于篇幅有限,僅列出一部分。 BOOL DR_VendorCmnd(void) { switch(SETUPDAT[1])
{ case VCOMMAND_START_T: //上位機(jī)發(fā)出啟動(dòng)監(jiān)測(cè)命令 PStatus = 0x22;//單片機(jī)產(chǎn)生 22H的狀態(tài)信號(hào)
= SETUPDAT[1];
+ 1) = 0xaa;
+ 2) = PStatus; EP0BCH = 0; EP0BCL = 3; EP0CS |= bmHSNAK; //確認(rèn)器件請(qǐng)求握手信號(hào) SYS_MODE = PStatus; //通過 PE口發(fā)出相應(yīng)的狀態(tài)信號(hào) Break;}
5結(jié)論
在彈載測(cè)量系統(tǒng)地面測(cè)試臺(tái)的研制中,利用 CY7C68013實(shí)現(xiàn)了 USB接口的數(shù)據(jù)傳輸,本設(shè)計(jì)采用的端口模式,雖然與 GPIF模式和 Slave fifo模式相比,傳輸速率比較低,但對(duì)于具備一定單片機(jī)基礎(chǔ)的開發(fā)人員而言,這種模式開發(fā)周期短,穩(wěn)定性強(qiáng),不失為一種有效的數(shù)據(jù)傳輸方式。該固件程序已成功應(yīng)用到某彈載測(cè)量系統(tǒng)地面測(cè)試臺(tái)中,多次試驗(yàn)證明固件運(yùn)行可靠,數(shù)據(jù)回讀誤碼率低,滿足系統(tǒng)技術(shù)要求。
北京2022年10月18日 /美通社/ -- 10月14日,國(guó)際數(shù)據(jù)公司(IDC)發(fā)布《2022Q2中國(guó)軟件定義存儲(chǔ)及超融合市場(chǎng)研究報(bào)告》,報(bào)告顯示:2022年上半年浪潮超融合銷售額同比增長(zhǎng)59.4%,近5倍于...
關(guān)鍵字: IDC BSP 數(shù)字化 數(shù)據(jù)中心東京2022年10月18日 /美通社/ -- NIPPON EXPRESS HOLDINGS株式會(huì)社(NIPPON EXPRESS HOLDINGS, INC.)旗下集團(tuán)公司上海通運(yùn)國(guó)際物流有限公司(Nipp...
關(guān)鍵字: 溫控 精密儀器 半導(dǎo)體制造 BSP要問機(jī)器人公司哪家強(qiáng),波士頓動(dòng)力絕對(duì)是其中的佼佼者。近來年該公司在機(jī)器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開發(fā)的機(jī)器人會(huì)后空翻,自主爬樓梯等。這不,波士頓動(dòng)力又發(fā)布了其機(jī)器人組團(tuán)跳男團(tuán)舞的新視頻,表演的機(jī)器人包括...
關(guān)鍵字: 機(jī)器人 BSP 工業(yè)機(jī)器人 現(xiàn)代汽車