《電子技術應用》
您所在的位置:首頁 > 其他 > 業界動態 > USB接口的高速數據采集卡的設計與實現

USB接口的高速數據采集卡的設計與實現

2008-09-25
作者:崔巖松

??? 摘? 要: 討論了基于USB接口的高速數據采集卡" title="高速數據采集卡">高速數據采集卡的實現。該系統采用TI公司的TUSB3210芯片作為USB通信及主控芯片,完全符合USB1.1協議,是一種新型的數據采集卡。

??? 關鍵詞: USB? A/D" title="A/D">A/D? FIFO? 固件

?

  現代工業生產和科學研究對數據采集的要求日益提高,在瞬態信號測量、圖像處理等一些高速、高精度的測量中,需要進行高速數據采集。現在通用的高速數據采集卡一般多是PCI卡或ISA卡,存在以下缺點:安裝麻煩;價格昂貴;受計算機插槽數量、地址、中斷資源限制,可擴展性差;在一些電磁干擾性強的測試現場,無法專門對其做電磁屏蔽,導致采集的數據失真。

  通用串行總線USB是1995年康柏、微軟、IBM、DEC等公司為解決傳統總線不足而推廣的一種新型的通信標準。該總線接口具有安裝方便、高帶寬、易于擴展等優點,已逐漸成為現代數據傳輸的發展趨勢。基于USB的高速數據采集卡充分利用USB總線的上述優點,有效解決了傳統高速數據采集卡的缺陷。

1 USB數據采集卡原理

1.1 USB簡介

  通用串行總線適用于將USB外圍設備連接到主機上,通過PCI總線與PC內部的系統總線連接,實現數據傳送。同時USB又是一種通信協議,支持主系統與其外設之間的數據傳送。USB器件支持熱插拔,可以即插即用。USB1.1支持兩種傳輸速度,既低速1.5Mbps和高速12Mbps,在USB2.0中其速度提高到480Mbps。USB具有四種傳輸方式" title="傳輸方式">傳輸方式,既控制方式(Control mode)、中斷傳輸方式(Interrupt mode)、批量傳輸方式(Bulk mode)和等時傳輸方式(Iochronous mode)。

  考慮到USB傳輸速度較高,如果用只實現USB接口的芯片外加普通微控制器(如8051),其處理速度就會很慢而達不到USB傳輸的要求;如果采用高速微處理器(如DSP),雖然滿足了USB傳輸速率,但成本較高。所以選擇了TI公司內置USB接口的微控制器芯片TUSB3210,開發了具有USB接口的高速數據采集卡。

1.2 系統原理圖

  系統原理圖如圖1所示。

?

  整個系統以TUSB3210為核心,負責啟動A/D轉換,控制FIFO的讀寫及采樣頻率的設定,與主機之間的通信及數據傳輸。

2 USB數據采集卡硬件

2.1 TUSB3210芯片

  TUSB3210是TI公司推出的內嵌8052內核并帶有USB接口的微控制器芯片。TUSB3210有256字節的內部RAM,8K字節的程序RAM,512字節的USB數據緩沖和端點描述塊EDB(Endpoint Descriptor Blocks),4個通用的GPIO端口P0、P1、P2、P3,I2C接口電路,看門狗電路等。

  TUSB3210的USB接口符合USB1.1協議,有4個輸入端點(Input Endpoint)和4個輸出端點(Output Endpoint),支持全速和低速傳輸速率,并具有USB協議所規定的4種傳輸方式。TUSB3210的USB接口采用串行接口引擎(SIE)編碼和解碼串行數據,并且進行校驗、位填充,執行USB所需要的其他信號。這樣采用硬件完成USB協議,簡化了固件" title="固件">固件代碼的編制。

  TUSB3210采用基于內部RAM的解決方案,允許通過I2C總線從串行EEPROM中讀入固件或從主機中下載固件程序。這項功能便于設備的開發與在線升級。

2.2 A/D芯片MAX1449

  MAX1449是MAXIM公司生產的10位、105MSPS、單3.3V電源、低功耗的高速A/D芯片。它采用差分輸入,帶有高寬帶采樣/保持(T/H)的10階段流水線(pipeline)型結構的ADC,如圖2。采樣信號每半個時鐘周期通過一個流水線階段,完成連續轉換到數據輸出共需5.5個時鐘周期。

?

?

  每個流水線首先通過一個1.5位的閃速ADC對輸入電壓量化,由DAC產生一個對應于量化結果的電壓并與輸入電壓作差,輸出電壓放大2倍后送到下一級流水線處理。每級流水線提供1位的分辨率,并進行差錯校正,得到良好的線性和低失調。

MAX1449提供一個2.048V的精確帶隙基準源,用來設定ADC滿量程范圍,也可以用外部基準源改變量程范圍。MAX1449的最大差分輸入電壓范圍為2V。

2.3 輸入信號處理電路

  MAX1449芯片的輸入信號為差分輸入時有最佳的采樣效果。在本系統中用TI的THS4503作為單端輸入到差分輸出的轉換電路。THS4503高性能的全差分運放,帶寬可達270MHz,具有非常好的線性,在100MHz下可支持11位的A/D轉換要求,適合作為A/D變換的前端接口電路。具體電路見圖3所示。

?

?

2.4 FIFO和時鐘發生電路

  高速A/D變換的數據不能直接通過USB送入主機,系統中通過FIFO來緩沖數據。本系統采用TI公司的SN74V293芯片。它的容量為65536×18或131072×9,最快讀寫周期為6ns,可以滿足100MHz采樣數據的存儲。用戶可以選擇輸入、輸出寬度,當選擇輸入、輸出寬度為18時,可存儲64K×10位的數據。如果選擇輸入、輸出為9位,則可使存儲容量擴大到128K×9位,這樣對精度要求不高的用戶可以獲得更多數據。

  SN74V293有獨立的讀寫時鐘控制電路,允許讀寫操作同時進行。SN74V293內部有滿、空、半滿輸出信號以及可編程設定的幾乎滿和幾乎空輸出信號,通過這些信號控制器可以靈活控制FIFO的讀寫操作。

  對于高速數據采集系統,時鐘信號很重要。在本系統中選用DALLAS公司的DS1073時鐘芯片。DS1073是無需外部元件的頻率振蕩器。通過DALLAS獨有的1-wire技術,可以設定內部的分頻器數值,實現輸出頻率從27.3kHz~100MHz可調,從而方便地改變采樣時鐘,簡化電路設計。MAX1449數據輸出時下降沿有效,而FIFO寫入時上升沿鎖存數據。系統中采用DS90LC028A實現對時鐘信號的取反。

2.5 PCB板制作

  由于是高速A/D采集,在制作PCB板時有一些需要注意的地方。電路板最好使用多層板,元件盡量選用表面封裝器件。這樣可以減小元器件之間的距離,減小寄生電感、寄生電容,同時減小電路板的尺寸。所有的旁路電容都要盡量靠近芯片的電源管腳。模擬公共地和數字公共地要分開,選一點通過低值表貼電阻(1~5Ω)、磁珠或直接連接,以免數字地電流干擾模擬地。電源最好用線性穩壓電源,A/D和前端處理電路要用同一電源地輸出,減小電源波動對采集的影響。

3 USB高速數據采集卡的軟件

  開發一個USB設備,軟件設計是必不可少的。USB應用系統軟件設計分為三部分:USB外設端的固件(Firmware)、主機操作系統上的客戶驅動程序以及主機應用軟件。主機應用軟件通過客戶驅動程序與系統USBI(USB Device Interface)進行通信,由系統產生USB數據的傳送動作;固件則響應各種來自系統的USB標準請求,完成各種數據的交換工作和事件處理。

3.1 USB接口編程

  固件程序主要是實現USB通信。TUSB3210采用SIE來管理USB通信。當主機與芯片進行USB通信時,會產生外部中斷0,通過中斷矢量寄存器判斷。Setup_packed_Int、Input_endpoint0_Int、Output_endpoint0_Int 這三個中斷主要用于與主機建立連接、進行控制傳輸或中斷傳輸;Input_endpoint1_Int、Output_endpoint1_Int這兩個中斷主要在批量傳輸時使用。在固件中分別執行不同的中斷程序來實現USB的數據傳輸。

  void EX0_int(void) interrupt 0 // 外部中斷0

  {

?????? EA=DISABLE; // 關中斷

?????? switch (bVECINT){ // 確定中斷ID

????????????? case VECINT_OUTPUT_ENDPOINT0:

????     ???? bVECINT=0x00;

?????????????????? Ep0OutputInterruptHandler();

?????????????????? break;

????????????? case VECINT_INPUT_ENDPOINT0:

?????????????????? bVECINT=0x00;

?????????????????? Ep0InputInterruptHandler();

?????????????????? break;

????????????? case VECINT_OUTPUT_ENDPOINT1:

?????????????????? bVECINT=0x00;

?????????????????? Ep1OutputInterruptHandler();

?????????????????? break;

????????????? case VECINT_INPUT_ENDPOINT1:

?????????????????? bVECINT=0x00;

????????      Ep1InputInterruptHandler();

?????????????????? break;

????????????? case VECINT_SETUP_PACKET_RECEIVED:

?? ?????????????? SetupPacketInterruptHandler();

 ???????????????? bUSBSTA=USBSTA_SETUP;

?????????????????? bVECINT=0x00;

?????????????????? break;

????????????? default: break; //不知道中斷ID

?????? }

?????? EA=ENABLE; // 開中斷

  }

3.2 主機軟件設計

  筆者首先開發TUSB3210在主機中的驅動程序。用WinDK3.0開發了Win2000下的驅動程序,實現了控制傳輸、中斷傳輸和批量傳輸的標準接口函數。

  在應用程序開發中,可用VC++編制應用程序。可以把USB設備當成文件來操作,利用CreateFile得到USB句柄" title="句柄">句柄,用DeviceIoControl來進行控制傳輸,用ReadFile、WriteFile進行批量傳輸。程序實例如下:

  HANDLE m_hUsbSample;?? //USB句柄

  m_hUsbSample=CreateFile(″\.USBSampl0″, GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ|FILE_SHARE_

    WRITE, NULL,OPEN_EXISTING,0,NULL);????????????????????????????????????????  ?? //打開USB句柄

  DeviceIoControl(m_hUsbSample,IOCTL_USBSAMPL_REBOOT,NULL,0,NULL,0,&length,NULL);????? //控制傳輸

  WriteFile(m_hUsbSample,pBuffer,writelength,&writelength,NULL);

????? ????????????????????????????????????????????? //批量輸出傳輸

  ReadFile(m_hUsbSample,pBuffer,64,&length,NULL);?

???? ?????????????????????????????????????????????? //批量輸入傳輸

  CloseHandle(m_hUsbSample); ??   ????????????? //關閉USB句柄

  使用上述函數編制USB高速數據采集卡的主機軟件。

  通過以上設計實現了基于USB數據采集卡的基本功能。但還有一些如信號的觸發、事件的捕獲功能還需完善;需開發基于USB2.0的系統,進一步提高數據傳輸的速率。

?

參考文獻

1 TUSB3210 Datasheet. SLLS466. http://www.ti.com,2001

2 MAX1449 Datasheet. http://www.maxim-ic.com.cn,2000

3 SN74V293 Datasheet.SCAS669C. http://www.ti.com,2002

4 Jan Axelson. USB大全[M]. 北京:中國電力出版社,1999

5 Chirs,Cant.WindowsWDM設備驅動程序開發指南[M].北京:機械工業出版社, 2000

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 九九精品视频在线播放8 | 中文有码| 男女爱视频免费高清在线观看 | 欧美激情一区二区三区不卡 | 我想看一级毛片免费的 | 久久精品国产欧美日韩99热 | 精品久久久久久综合日本 | 成人影视在线观看 | 午夜免费视频网站 | 国产精品视频久久久久久 | 日本经典在线三级视频 | 久久国产成人午夜aⅴ影院 久久国产欧美日韩精品 | 欧美成人在线免费观看 | 又大又粗又爽的三级小视频 | 国产高清av在线播放 | 手机看片1024久久精品你懂的 | xx欧美 | 欧美日本一区二区 | 深夜福利视频网站 | 欧美中文在线视频 | 国产欧美日韩在线 | 久操色| xxxx中国hdxxxx| 欧美高清在线精品一区二区不卡 | 黄色一级小视频 | 欧美日本一本 | 污免费观看 | 亚洲福利精品 | 两个人免费视频www 两个人看的www中文字幕 | 手机看片1024国产 | 日韩欧美1区| 亚洲免费黄色 | 日韩在线操 | 老湿影院免费在线观看 | 国产精久久一区二区三区 | 中国免费一级片 | 成人在线视频观看 | 2019免费视频 | 5g影院天天爽爽 | 黄色一级片欧美 | 两个人看的www免费 两个人看的www高清免费视频 |