當前位置:編程學習大全網 - 源碼下載 - USB接口的FPGA板如何配置下載文件

USB接口的FPGA板如何配置下載文件

數據接收存儲技術革新是信號采集處理領域內的壹個重要課題。利用這種技術,可以把信號的實時采集和精確處理在時間上分為兩個階段,有利於獲得令人更滿意的處理結果。在無線數傳接收設備中應用數據接收存儲方法時,除了要滿足數據傳輸速率和差錯控制方面的要求外,還需要考慮如何使設備易於攜帶、接口簡單、使用方便。

傳統外設接口技術不但數據傳輸速率較低,獨占中斷、I/O地址、DMA通道等計算機系統關鍵資源,容易造成資源沖突問題,而且使用時繁雜的安裝配置手續也給終端用戶帶來了諸多不便。近年來,USB接口技術迅速發展,新型計算機紛紛對其提供支持。USB2.0是USB技術發展的最新成果,利用USB2.0接口技術開發計算機外設,不但可以借用其差錯控制機制[1][6]減輕開發人員的負擔、獲得高速數據傳輸能力(480Mb/s),而且可以實現便捷的機箱外即插即用特性,方便終端用戶的使用。

1 無線數傳接設備總體構成

無線數傳接收設備是某靶場測量系統的壹個重要組成部分。如圖1所示,該設備由遙測接收機利用天線接收經過調制的無線電波信號,解調後形成傳輸速率為4Mb/s的RS-422電平差分串行數據流。以幀同步字打頭的有效數據幀周期性地出現在這些串行數據中。數據轉存系統從中提取出有效的數據幀,並在幀同步字後插入利用GPS接收機生成的本地時間信息,用於記錄該幀數據被接收到的時間,然後送給主機硬件保存。

在無線數傳接收設備中,數據轉存系統是實現數據接收存儲的關鍵子系統。下面將詳細介紹該系統的硬件實現及工作過程。

2 數據轉存系統基本構成及硬件實現

數據轉存系統主要由FPGA模塊、DSP模塊、USB2.0接口芯片構成,各個模塊之間的相互關系如圖2所示示。圖中,4Mb/s的串行數據輸入信號SDI已由RS-422差分電平轉換為CMOS電平。為突出重點,不太重要的信號連線未在圖中繪出。下面分別介紹這幾個模塊的主要功能。

2.1 FPGA模塊實現及春功能

FPGA模塊在Altera公司ACEX系列的EP1K30TI144-2芯片中實現。其中主要的功能子模塊有:位同步邏輯、幀同步邏輯、授時時鐘和譯碼邏輯。位同步邏輯主要由數字鎖相環構成,用於從串行數據輸入信號SDI中恢復出位時鐘信號。幀同步邏輯從位同步邏輯的輸出信號提取幀同步脈沖。兩者為DSP利用其同步串行口接收串行數據作好準備。這樣,利用壹對差分信號線就可以接收同步串行數據,簡化了印制電路板的外部接口。授時時鐘在DSP和GSP接收機的協助下生成精度為0.1ms的授時信息。譯碼邏輯用於實現系統互聯。

2.2 DSP模塊實現及其功能

DSP模塊是數據轉存系統的主控模塊,在T1公司16位定點DSP芯片TMS320F206[4]中實現。在DSP的外部數據空間還配置了32KX16的高速SRAM,可以緩存80余幀數據,用於提高系統的差錯控制能力。DSP利用同步串行口接收FPGA送來的同步串行數據,利用異步串口接收GPS接收機送來時間信息(用於初始化FPGA授時時鐘),利用外部總線接口訪問FPGA授時時鐘、外部SRAM、ISP1581的片內寄存器。可以看出DSP模塊主要用於完成數據幀的接收、重組以及轉存調度等任務。

ISP1581芯片是PHILIPS公司推出的高速USB2.0設備控制器,實現了USB2.0/1.1物理層、協議層,完全符合USB2.0規範,即支持高速(480Mb/s)操作,又支持全速(12Mb/s)操作。ISP1581沒有內嵌微處理器,但對微處理器操作了靈活的接口。在上電時,通過配置BUS——CONF、DAO、MODE1、MODE0、DA1引腳電平可以適應絕大多數的微處理器接口類型。例如,通過BUS_CONF/DA0引腳,總線配置可以選擇普通處理器模塊(Generic Phocessor mode)中分割總線模式(Split Bus Mode);在普通處理器模式下,通過MODE0/DA1引腳可以選擇讀寫選通為8051風格或者Motorola風格。

在數據轉存系統中,ISP1581用於處理主機的高速數據傳輸。它工作在普通處理器接口模式下,采用8051風格的讀寫選通信號,由DSP芯片TMS320F206控制。兩者在選定工作方式下的信號連線如圖3所示,圖中未畫出的信號引腳可以懸空,供電引腳的連接方式在參考資料[2]第46頁有簡明描述。在FPGA譯碼邏輯的作用下,ISP1581的片內寄存器被映射在DSP的片外數據空間中。DSP通過8位地址線選擇要訪問的寄存器,在讀寫選通信號的控制下,利用16位數據線與選定的寄存器交換數據。在訪問ISP1581單字節寄存器時,數據總線高字節內容無關緊要。ISP1581通過中斷引腳INT向DSP報告發生的總線事件,利用D+、D-引腳完成與主機的數據交換。

3 數據轉存系統的工作過程

系統加電後,當FPGA配置過程結束時,如果有串行數據輸入,位同步邏輯和幀同步邏輯便啟動同步過程。同時,DSP片內FLASH中復位中斷服務程序c_int0()[4]被立即執行,在建立好C語言的工作環境下,它會調用主函數main()。在main()中,需要安排好壹系列有先後順序的初始化工作。其中,ISP1581的初始化過程比較復雜,需要考慮設備采用的供電方式(這裏為自供電[6]方式)、插接主機和系統上電的先後次序,並需要與USB總線枚舉[1][6]過程相結合。

在FPGA中的位同步邏輯和幀同步邏輯均進入同步狀態,且DSP主控模塊配合主機完成初始化任務後,即可啟動數據的傳輸過程。下面介紹壹下ISP1581的初始化過程及DSP控制的數據幀的接收機轉存流程。

3.1 ISP1581的初始化

在初始化過程中,首先需要設置影響ISP1581自身工作方式的壹些寄存器,然後與主機端USB系統配合進行,應答來自主機端的設備請求。當數據轉存系統板作為USB 2.0設備通過連接器連到主機USB根集線器上的壹個端口時,主機便可檢測到這壹連接,接著給該端口加電,檢測設備並激活該端口,向USB設備發送復位信號。設備收到這壹復位信號後,即進入缺省狀態,此後就能夠通過缺省通信通道響應主機端送來的設備請求。主機通過描述符請求(GET_DESCRIPTOR)獲得設備端的詳細信息,通過設置地址請求(SET_ADDRESS)設置設備地址,通過設置配置請求(SET_CONFIGURATION)選定合適的設備配置。在設備成功響應了這些設備請求之後,就可以與主機通信了。

在響應主機請求的過程中,DSP需要配置ISP1581的端點以實現不同類型的傳輸通道。根據數據傳輸速率的要求,除了缺省的控制通道外,系統中實現了壹個批傳輸(bulk)[1]類型的輸入通道。這樣,ISP1581就可以像FIFO壹樣方便地從數據轉存系統向主機傳輸數據,而且具有差錯控制能力,簡化了設備端軟件設計的復雜性。

3.2 數據幀的接收轉存過程

系統正常工作時,需要與主機端程序相互配合。主要端需要開發者實現的程序包括設備驅動程序和應用程序。在Windows 2000操作系統下,USB設備驅動程序為WDM模型的驅動程序,開發環境DriverStudio為WDM型驅動程序提供了框架結構,使得驅動開發變得非常容易(參見參考文獻[5]第八、九、十章)。驅動程序接收應用程序的請求,利用USB總線驅動程序(US-BD)和主機控制器驅動程序(HCD)通過主機控制器安排USB總線事務,設備端則根據這些事務調度相應的數據幀的傳輸。關於主機端口如何安排總線事務可以查閱參考文獻[1]。以下著重介紹設備端數據的調度過程。

數據幀的接收轉存過程主要由DSP負責,DSP在外部SRAM中建立了壹個數據幀的隊列,如圖4所示。系統主要工作在中斷驅動模式下,與同步串行口相關的中斷服務程序負責建立隊列的尾部,對應於ISP1581中斷引腳INT的中斷服務程序負責建立隊列的頭部。

當以幀同步字打頭的壹幀數據以串行位流的形式到來時,FPGA產生的幀同步脈沖可以直接啟動DSP同步串行口接收數據,該同步脈沖同時以中斷方式通知DSP為壹幀數據的接收做好準備。DSP接到通知後,首先檢查外部SRAM中是否有足夠的空間容納壹幀數據。如果沒有空間,則丟棄當前數據幀(根據設計,這種情況是很少見的);如果有空間,則為當前數據幀保留足夠的空間。接著在幀起始位置填寫幀步字,讀取授時時鐘的當前值並填寫在幀同步字後。這樣,壹個新的數據幀(圖4中數據幀F_N)就建立了,但是並沒有加入到隊列中,而是要等待來自同步串行口的後繼數據嵌入該幀中後再加入到隊列中。

同步串行口的接收緩沖區在接收到若幹字(由初始化時的設置決定)後,會向DSP提出中斷請求。在中斷服務程序中,DSP讀取接收緩沖區中的內容,並將其填入上述新開辟的幀F_N中。在壹幀數據接收完畢後,就將該幀添加到隊列的尾部,表示該幀數據已經準備好(圖4中數據幀F_R),可以通過ISP1581送給主機硬件保存。

DSP在查詢到隊列中有已經準備好的數據幀存在時,就設置ISP1581的端點索引寄存器(Endpoint Index Register)使其指向初始化時配置的批傳輸輸入端點,然後將隊列首幀數據通過ISP1581的數據端口寄存器(Data Port Register)填寫在端點緩沖區中。在端點緩沖區被填滿後,它就自動生效。在不能填滿端點緩沖區的情況下,可以通過設置控制功能寄存器(Control Function Register)的VENDP位[2]強制該端點緩沖區生效。端點緩沖區生效後,在USB總線上下壹IN令牌到來時,該端點緩沖區中的數據就通過USB總線傳輸到主機中。主機成功接收到數據後,會給ISP1581以ACK應答。能夠通過INT引腳報告給DSP,DSP就可以繼續往端點中填寫該幀其余數據。

在隊列首幀數據被成功轉移到主機後,DSP就丟棄首幀數據。如果隊列在還有數據幀,則將次首幀作為首幀,繼續前述傳輸過程;如果沒有要傳輸的數據幀,則為隊列首幀指針Head_Ptr賦空值(NULL),等待新的數據幀的到來。

USB2.0是計算機外設接口技術發展的最新成功,具有廣闊的應用前景。本文介紹了PHILIPS公司USB2.0接口芯片ISP1581在無線數據接收設備中的應用。高性能、便攜化的無線數據傳接收設備。其在靶場實彈試驗中受到了用戶的好評。

PC機的RS-232C串行口是使用最多的接口之壹。因此,4串口、8串口等以增加串口數量為目的的ISA總線卡產品大量問世。壹般串口應用只是使用了RXD和TXD兩條傳輸線和地線所構成的串口的最基本的應用條件,而本文介紹壹個利用PC機的RS-232串口加上若幹電路來實現多串口需求的接口電路。

1.PC機串口的RTS和DTR及擴展電路

RTS和DTR是PC機中8250芯片的MODEM控制寄存器的兩個輸出引角D1和D0位,口地址為COM1的是3FCH,口地址為COM2的是2FCH。我們可以利用對MODEM控制寄存器3FCH或2FCH的寫操作對其進行控制。從而利用該操作和擴展電路實現對TXD和RXD進行多線擴展,圖1是其擴展電路。

在圖1所示的PC機串口擴展電路中,74LS161是二進制計數器,1腳是清0端,2腳是計數端,計數脈沖為負脈沖信號,4051是八選壹雙向數字/模擬電子開關電路,其中壹片用於正向輸出,壹片用於反向輸出。該擴展電路工作原理是通過控制PC機串口的DTR輸出的高低電平來形成74LS161的P2腳計數端的負脈沖信號,使161的輸出端P14(QA)、P13(QB)、P12(QC)、P11(QD)腳依次在0000到1111十六個狀態中變化,本電路僅使用了QA、QB、QC三個輸出來形成對4051的ABC控制,最終使得4051(1)的輸入端TXD依次通過與TX1~TX8導通而得到輸出信號,4051(2)的輸出端RXD與RX1~RX8依次導通形成輸入信號。由於RXD和TXD的導通是壹壹對應的,因此串口通信就可以依次通過與多達8個帶有三線基本串口的外部設備進行通信傳輸以實現數據傳送。PC機端的電平轉換電路是將RS232電平轉換為TTL電平,外設端的電平轉換電路是將TTL電平轉換為RS232電平。由於這種轉換有許多電路可以實現,因而,這裏不再介紹。

2.電路使用程序

對PC機串口COM1的編程如下:

……

… ;對COM1口的波特率等設置;

MOV DX,3FCH

MOV AL,XXXXXX01B

OUT DX,AL;D1生成RTS負脈沖,對74LS161輸出端清0

MOV AL,XXXXXX11B;

OUT DX,AL ;4051的RX1和TX1導通

CALL COM ;調用通信子程序,與第壹個外部設備通信;

MOV CX,7 ;設置循環計數器;

NEXT:MOV DX ,3FCH

MOV AL,XXXXXX10B

OUT DX ,AL ;D0位生成DTR的負脈沖,形成161的P2腳計數脈沖

MOV AL,XXXXXX11B

OUT DX,AL ;RX2和TX2導通

CALL COM ;調用通信子程序,與第二個外部設備通信

LOOP NEXT ;循環與另外6個外部設備通信

… ;通信子程序略

3.使用說明

由於該擴展的多路接口在通信時***用壹個子程序,因此在與某壹路導通時,系統只能與這壹路的外部設備進行通信聯絡。

如果工作現場需要立即和某壹路通信,則需要對3FCH的D1位執行兩個寫操作並在RTS腳形成負脈沖,以對7416I清0後,再連接執行若幹次對DTR的兩次寫操作。例如想對第4路外設通信,則需要執行完成對74LS161清0後,再連續三次對3FCH的D0位進行兩個寫操作以形成DTR腳的負脈沖,然後即可調用通信子程序。

如需使用PC機的COM2串口,只需將程序中的3F8H~3FDH全部換成2F8H~2FDH即可。

如果使用十六選壹雙向數字/模擬電子開關電路,可將74LS161的QA、QB、QC、QD四個輸出端接至電子開關的四個控制端A、B、C、D,這樣就可以達到壹個PC機的RS232口與16個帶有串口的外設的數據通信。

  • 上一篇:那種在記事本裏寫代碼,直接保存改個擴展名直接運行的語言叫什麽?
  • 下一篇:什麽是莊股和主力股?
  • copyright 2024編程學習大全網