基于USB的音頻信號分析儀設計
2.3 USB接口
USB接口芯片選用CYPRESS公司的EZ-USBFX2芯片CY7C68013。CY7C68013有Slave FIFO和GPIF兩種接口方式,本設計采用Slave FIFO模式,F(xiàn)PGA與USB硬件接口如圖3所示。本文引用地址:http://cafeforensic.com/article/202010.htm
圖中D0~D7為數(shù)據(jù)總線,用于數(shù)據(jù)傳輸;INTI為中斷標志,當傳輸完一組數(shù)據(jù)時產(chǎn)生一次中斷。IFCLK為外部時鐘輸入;FIFOADR[1:0]選擇四個FIFO中的一個,本設計中FIFOADR[1]直接接+3.3 V,F(xiàn)IFOADR[0]直接接地,選擇用EP6傳輸數(shù)據(jù),4倍緩存;FULL為FIFO滿狀態(tài)標志,低電平有效;SLWR為數(shù)據(jù)寫入FIFO使能,低電平有效;FD[7:0]為8位數(shù)據(jù)線。
如上所述,系統(tǒng)選擇了FIFO的異步模式進行數(shù)據(jù)傳輸?shù)姆绞?。在IFCLK的上升沿,如果SLWR有效(低電平有效),而數(shù)據(jù)有滿足建立保持時間,數(shù)據(jù)就被寫入FIFO,同時,若內部控制器發(fā)現(xiàn)FIFO己滿,經(jīng)過大約為10 ns的延時,F(xiàn)ULL標志會被置成有效。
3 系統(tǒng)軟件設計
3.1 USB固件設計
固件是在USB接口芯片加電后,由其他設備加載到CY7C68013中并在其中運行完成接口數(shù)據(jù)傳輸功能的一段程序,其作用是控制硬件來完成預期的設備功能。固件的主要功能包括:初始化工作、輔助硬件完成設備的重枚舉過程、對主機的設備響應做出適當?shù)捻憫?、對中斷的處理、?shù)據(jù)的接收與發(fā)送、對外圍電路的控制。
本系統(tǒng)固件程序采用Cypress公司提供的固件程序框架,在其初始化函數(shù)中添加了用戶配置代碼。該設計中異步自動從屬FIFO數(shù)據(jù)傳輸?shù)某跏蓟a如下:
3.2 USB驅動程序設計
USB驅動程序處于應用程序和設備端固件之間,使操作系統(tǒng)識別USB設備,并建立起主機端和設備端之間的通信。
VISA(Virtual Instrument SoftWare Architecture)是美國NI公司開發(fā)用來與各種儀器總線進行通信的高級應用程序編程接口(API)。它不受平臺、總線和環(huán)境的限制,可用來對USB、GPIB、串口、VXI、PXI及以太網(wǎng)等進行配置、編程和調試。因此本系統(tǒng)利用LabVIEW的VISA來對USB的底層驅動經(jīng)行開發(fā),具體步驟如下:
(1)使用Driver Development Wizard創(chuàng)建INF文檔。
(2)安裝INF文檔,并安裝使用INF文檔的USB設備。
(3)使用NI-VISA Interactive Control對設備進行測試。
USB底層配置正確以后,選擇VISA類為USBRaw,計算機會自動刷新選擇的USB設備,利用VISAOpen,VISA Close,VISA Write和VISA Read
四個節(jié)點即可實現(xiàn)和USB設備的雙向通信。與USB設備的通信過程分為4個步驟:
(1)由VISAOpen函數(shù)打開VISA resource name端口指定的USB設備;
(2)通過VISA Write函數(shù)向USB設備發(fā)送控制命令啟動設備工作,USB設備接收到控制命令后開始采集數(shù)據(jù)并將采集到的數(shù)據(jù)按要求發(fā)送到數(shù)據(jù)緩沖區(qū);
(3)通過VISA Read函數(shù)將數(shù)據(jù)讀出;
(4)通過VISA Close函數(shù)關閉設備。
3.3 LabVIEW程序設計
LabVIEW是美國NI公司開發(fā)的一種圖形化編程軟件,具有良好的圖形顯示功能,提供種類齊全的各種波形圖和波形圖表控件,能夠以多樣化的方式直觀地顯示各種信號波形。其次LabVIEW擁有數(shù)量眾多、功能齊全的信號分析與處理子VI,供用戶調用,從而組合實現(xiàn)出所需要的信號處理功能。同時LabVIEW具有良好的擴展性,無論是通過附加工具包擴展,還是通過其他平臺(如Matlab/Simulink)的接口擴展,都能很方便地進一步擴展其信號處理功能。
評論