當前位置:首頁 > 嵌入式 > 嵌入式硬件

數(shù)據(jù)采集在現(xiàn)代工業(yè)生產(chǎn)及科學研究中的重要地位日益突出,對實時高速數(shù)據(jù)采集的要求也不斷提高。在信號測量、圖像處理、音頻信號處理等一些高速、高精度的測量中,都要求進行高速、高精度的數(shù)據(jù)采集。這就對數(shù)據(jù)采集系統(tǒng)的設計提出兩個方面的要求:一方面,要求接口簡單靈活且有較高的數(shù)據(jù)傳輸率;另一方面,由于數(shù)據(jù)量通常都較大,要求主機能夠?qū)?shù)據(jù)做出快速反應,并及時分析和處理。

實現(xiàn)數(shù)據(jù)采集與傳輸,可選擇如下3種方法:

①使用傳統(tǒng)的串/并口。傳統(tǒng)的串口(如RS232),其傳輸速率為幾十kb/s到100 kb/s,而系統(tǒng)所要求的數(shù)據(jù)傳輸速率很高,而且還要實現(xiàn)數(shù)據(jù)的采集與傳輸同步進行,串口的速率遠遠達不到實時要求;對于并口,雖然它的傳輸速率可達到1 Mb/s以上,但由于探測器與主機相距較遠,因此走線比較復雜。

②采用通用的高速數(shù)據(jù)采集卡。高速數(shù)據(jù)采集卡(如ISA或PCI卡)雖然在數(shù)據(jù)存取速度上可滿足系統(tǒng)要求,但仍然存在很多缺點,比如安裝復雜,價格昂貴,兼容性不好,受計算機插槽數(shù)量、地址和中斷資源的限制,可擴展性較差等。

③使用USB2.0通用串行接口總線。USB接口是一種重要的計算機外設接口,它支持熱插拔和即插即用,使用非常方便。USB2.0支持高達480 Mbps的數(shù)據(jù)傳輸速率。USB接口可實現(xiàn)計算機與多個外圍設備的簡單、高速互聯(lián),將USB技術(shù)應用于數(shù)據(jù)采集是非常適合的。經(jīng)綜合考慮,本文選擇采用USB2.0接口來完成對數(shù)據(jù)的采集與傳輸。

1 數(shù)據(jù)采集和傳輸系統(tǒng)方案設計

數(shù)據(jù)采集和傳輸系統(tǒng)主要由3部分組成,USB2.0通道、FPGA和A/D轉(zhuǎn)換器組成,如圖1所示。

CY7C68013是Cypress公司推出的EZ-USB FX2系列智能USB接口芯片。其作用是將主機所發(fā)送的命令序列經(jīng)USB2.0端口輸出,實現(xiàn)對數(shù)據(jù)采集系統(tǒng)的控制;同時把A/D轉(zhuǎn)換器采集的數(shù)據(jù)以高速的數(shù)據(jù)序列形式發(fā)送到主機。其中,USB2.0端口提供一個能和計算機連接的數(shù)據(jù)傳輸接口。

FPGA利用內(nèi)部的SRAM提供數(shù)據(jù)輸入/輸出的雙緩沖功能。采用雙緩沖的原因同USB中的大端點所配置的雙緩沖類似,均是防止數(shù)據(jù)的溢出和保證數(shù)據(jù)傳輸?shù)倪B續(xù)性。本文選用Altera公司的CycIone系列芯片EP1C3T144。

A/D轉(zhuǎn)換器將所要采集的模擬量轉(zhuǎn)換成數(shù)字量,通過濾波和放大后,由FPGA接收、緩沖、存儲,經(jīng)USB2.0端口傳回至主機工作站。高速A/D轉(zhuǎn)換器采用轉(zhuǎn)換速率為20 MHz的MAX1425。

系統(tǒng)工作過程為:主機通過CY7C68013給數(shù)據(jù)采集系統(tǒng)一個采樣控制命令,存入FPGA的控制寄存器中。FPGA根據(jù)該命令向A/D轉(zhuǎn)換器發(fā)出相應控制信號。由于ADC采樣頻率為10 MHz,為和PC運行速度相匹配,在FPGA內(nèi)部生成一個FIFO緩存器。A/D轉(zhuǎn)換器在FPGA的ADC接口控制電路控制下,把模擬信號轉(zhuǎn)換成數(shù)字信號,并將指定通道的采樣數(shù)據(jù)存入FPGA內(nèi)部FIFO緩存。同時,F(xiàn)PGA的USB接口控制邏輯查詢CY7C68013是否空閑,如果空閑,那么由FPGA的USB接口控制邏輯將指定通道的采樣結(jié)果,從FPGA內(nèi)部FIFO緩存送入CY7C68013的內(nèi)部FIFO。當內(nèi)部的FIFO容量達到一定程度后,CY7C68013自動將數(shù)據(jù)打包傳送到PC機。由于固件程序把CY7C68013設置為特定的自動模式,因此CY7C68013把數(shù)據(jù)送往PC機期間的所有操作無需CY7C68013中CPU的干預,從而保證足夠的數(shù)據(jù)傳輸速率。采樣過程中FPGA的USB接口控制邏輯依次取走批量數(shù)據(jù),在USB接口打包傳送時A/D轉(zhuǎn)換持續(xù)進行,F(xiàn)PGA內(nèi)部FIFO也被持續(xù)寫入轉(zhuǎn)換結(jié)果。

2 硬件設計

系統(tǒng)的硬件由A/D轉(zhuǎn)換電路、數(shù)據(jù)采集與傳輸控制電路和接口電路構(gòu)成。

2.1 A/D轉(zhuǎn)換電路

A/D轉(zhuǎn)換電路是整個系統(tǒng)的重要組成部分。由低通濾波器、多路選擇開關和A/D轉(zhuǎn)換器構(gòu)成,如圖2所示。本文選用Maxim公司的A/D轉(zhuǎn)換芯片MAX1425。

8路模擬輸入信號分別經(jīng)過由運放THS4052構(gòu)成的抗混疊低通濾波器去除高頻成分,防止信號產(chǎn)生“混疊現(xiàn)象”。1/8模擬信號選擇器根據(jù)來自FPGA板的地址碼,控制模擬信號選擇器74HC4051選通8路輸入中的1路到輸出端,送到A/D轉(zhuǎn)換器MAX1425將模擬信號轉(zhuǎn)換為數(shù)字信號。MAX1425的控制信號由FPGA板提供,在控制信號的作用下以適當?shù)臅r序完成轉(zhuǎn)換工作。

2.2 數(shù)據(jù)采集與傳輸控制電路

數(shù)據(jù)采集與傳輸控制電路的開發(fā)工作主要集中在FPGA上。FPGA負責CY7C68013與ADC芯片之間的緩沖與控制,一邊與ADC接口,另一邊與USB接口,產(chǎn)生數(shù)據(jù)采集、通道切換、A/D轉(zhuǎn)換、FIFO所需的全部控制信號;實現(xiàn)對傳輸數(shù)據(jù)的緩存、讀/寫控制、時鐘、輸出使能、端點的選擇,以及對ADC的控制等功能。

如圖3所示,數(shù)據(jù)采集與傳輸控制電路由FIFO、USB接口控制狀態(tài)機、ADC接口控制狀態(tài)機、三態(tài)門緩沖器、控制寄存器組幾部分構(gòu)成。圖中,由右向左的寬箭頭表示數(shù)據(jù)流;FD[9:0]是與USB接口芯片連接的雙向數(shù)據(jù)總線;由左向右的寬箭頭表示傳送來自PC機的控制信號;單線箭頭表示輸入/輸出,以及FPGA內(nèi)部各個模塊間的控制信號線。

從數(shù)據(jù)流向看,數(shù)據(jù)在ADC接口控制狀態(tài)機的協(xié)調(diào)下通過ADC接口送入FPGA的FIFO中。經(jīng)過FIFO的緩沖后,在USB接口控制狀態(tài)機的協(xié)調(diào)下,當USB接口控制狀態(tài)機對三態(tài)門的輸出為高時,三態(tài)門開啟,數(shù)據(jù)通過三態(tài)門傳輸?shù)紽PGA外部的USB接口;當對三態(tài)門的輸出為低時,三態(tài)門呈現(xiàn)高阻態(tài),F(xiàn)PGA的這幾個引腳作為輸入引腳。此狀態(tài)下,來自PC機的控制信號通過CY7C68013從FD[15:0]送人FPGA中。在USB接口控制狀態(tài)機的控制下,來自PC機的控制信息存人控制寄存器組,并由ADC接口控制狀態(tài)機來控制送往FPGA外的ADC接口,作為對ADC的控制(如通道的選擇)。

  2.3 接口電路

  2.3.1 FPGA內(nèi)的ADC接口模塊

  MAX1425和74HC4051的控制信號都由FPGA產(chǎn)生,接口電路如圖4所示。


  FPGA的工作時鐘為60 MHz,該時鐘經(jīng)過分頻后,提供20 MHz給MAX1425作為工作時鐘,同時也作為FP-GA內(nèi)其他邏輯的工作時鐘。由FPGA內(nèi)狀態(tài)機控制,當CS為低和ADC_Convst為高時,MAX1425進入采樣保持狀態(tài)。當Clock的第一個上升沿到來,MAX1425開始轉(zhuǎn)換。RD輸出為低時,MAX1425把轉(zhuǎn)換結(jié)果放到數(shù)據(jù)總線上,F(xiàn)PGA開始讀入10位數(shù)據(jù)(FD[15:0]中的10~15六位數(shù)據(jù)線懸空,使數(shù)據(jù)線和A/D的位數(shù)匹配)。FPGA控制寄存器的Sel[2:O]信號作為74Hc4051的通道選擇信號,從8路模擬輸入入信號中選擇1路作為MAX1425的輸入。完成一次轉(zhuǎn)換后,當ADC_Convst:再次為高時,開始下一輪轉(zhuǎn)換。

  2.3.2 FPGA內(nèi)的USB接口模塊

  圖5是Slave模式下CY7C68013與FPGA的連接示意圖。中間是FPGA中USB接口模塊部分對應的信號。


  2.3.3 FPGA內(nèi)的USB接口控制狀態(tài)機

  FPGA內(nèi)USB接口控制狀態(tài)機的狀態(tài)轉(zhuǎn)移圖如圖6所示。共有6個狀態(tài),復位信號的模式設置為異步復位。狀態(tài)機主要分為讀、寫兩部分:讀取EP2中所包含的命令,存到FPGA的控制寄存器組中;將FPGA的FIFO中的數(shù)據(jù)讀出,寫入EP6端點緩沖區(qū)。


  該狀態(tài)機工作過程為:

 ?、傧到y(tǒng)加電或復位后,狀態(tài)機進入空閑狀態(tài)(idle)。

  ②在空閑狀態(tài)下,當EP2不為空時進入read_0狀態(tài),從EP2中讀出PC機傳來的控制命令。隨后進入read_1狀態(tài),把命令存到FPGA內(nèi)控制寄存器中,并把FPGA內(nèi)的FIFO清空(fifo_ach1='1'),以準備存儲采樣數(shù)據(jù)。之后再回到idle狀態(tài)。

  ③在空閑狀態(tài)下,當EP2為空(FX2_empty='0'),而FPGA的FIFO不為空(empty='0'),且EP6不滿時,進入write_0狀態(tài)。之所以要看EP2是否為空,是想優(yōu)先處理PC機通過EP2傳來的命令。在write_0狀態(tài)下,選中對CY7C68013的EP6操作(ADDR=2'h2),同時從FPGA內(nèi)部的FIFO中讀出一個數(shù)據(jù)。之后進入write_1狀態(tài),把數(shù)據(jù)寫入CY7C68013。然后進入write_2狀態(tài),write_2狀態(tài)的輸出與idle狀態(tài)相同,目的是提供一個時鐘周期的延遲。因為FPGA工作于60 MHz的時鐘下,比CY7C68013快,所以加入一個延遲以保證可靠的數(shù)據(jù)傳輸。

  3 軟件設計

  如圖7所示,數(shù)據(jù)采集系統(tǒng)的軟件設計包括3部分;CY7C68013的固件程序、Windows平臺上USB設備驅(qū)動程序和應用程序。在Windows操作平臺下,當有新的設備接入時,操作系統(tǒng)就會依據(jù)設備回送的有關信息自動地調(diào)用相應的設備驅(qū)動程序。當USB設備的設備驅(qū)動程序裝載后,主機應用程序通過USB設備驅(qū)動程序與系統(tǒng)USBDI(USB Device InteRFace)進行通信,然后由系統(tǒng)產(chǎn)生USB數(shù)據(jù)的傳送動作。固件則是運行在外設接口芯片中的代碼,用于響應各種來自系統(tǒng)的USB標準請求,完成各種數(shù)據(jù)的交換工作和事務處理。


  固件架構(gòu)實現(xiàn)了與USB兼容的外圍設備所需的基本功能。經(jīng)過鏈接(Iink)最小的描述符表文件,并對該架構(gòu)作適當?shù)男薷幕蛱砑硬糠执?,就可以?gòu)建出完全兼容的設備固件架構(gòu)。通過鏈接Cypress公司所提供的子程序,就有可能逐漸地構(gòu)建出完全兼容功能的設備。固件程序的流程如圖8所示。

  4 結(jié) 論

  基于FPGA和USB2.0的高速實時數(shù)據(jù)采集系統(tǒng),采用計算機的USB接口作為數(shù)據(jù)傳輸接口。軟件設計工作包括MCU的固件程序設計、計算機上USB接口驅(qū)動程序設計、計算機上應用程序設計等幾部分。MCU在FPGA和計算機之間起橋梁的作用,既要對USB接口進行控制,實現(xiàn)與計算機的通信,接受計算機的控制,又要對它與FPGA的接口進行設置和控制,還會與FPGA進行對話以實現(xiàn)對FPGA的工作模式進行設置。

本站聲明: 本文章由作者或相關機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術(shù)
關閉
關閉