當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]介紹一款USB接口的虛擬示波器的設(shè)計(jì)方案,重點(diǎn)介紹了USB總線接口芯片CH371的原理及應(yīng)用,降低了USB系統(tǒng)開發(fā)的門檻,并達(dá)到令人滿意的效果。

 作者Email:  violit@netease.com

    摘要:本文介紹一款USB接口虛擬示波器的設(shè)計(jì)方案,重點(diǎn)介紹了USB總線接口芯片CH371的原理及應(yīng)用,降低了USB系統(tǒng)開發(fā)的門檻,并達(dá)到令人滿意的效果。

    關(guān)鍵詞:USB接口,虛擬示波器,CH371,高速數(shù)據(jù)采集

    一、引言

    對于學(xué)校教學(xué)實(shí)驗(yàn)以及某些特定需求來說,目前市場上的模擬及數(shù)字示波器也許并不適用,價(jià)格高昂、體積較大且很多專業(yè)功能并不實(shí)用。而現(xiàn)在電腦的普及程度也達(dá)到了相當(dāng)?shù)囊?guī)模,利用電腦以及附加的數(shù)采模塊實(shí)現(xiàn)一個(gè)靈活便捷的虛擬示波器能夠滿足大多數(shù)的工作、學(xué)習(xí)和開發(fā)需要,并且可以通過較低代價(jià)的硬件和軟件升級實(shí)現(xiàn)相當(dāng)復(fù)雜的信號處理功能,能夠以較低的成本、較小的體積實(shí)現(xiàn)配置靈活的智能儀器組合;完全可以與便攜電腦結(jié)合,構(gòu)成便攜式檢測維修工作站。目前已經(jīng)有計(jì)算機(jī)并口通信的數(shù)據(jù)采集器,但是USB的應(yīng)用日趨廣泛和深入,如果將USB功能融合在里面則可以實(shí)現(xiàn)更高的數(shù)據(jù)傳輸率、更方便的使用方式,更為優(yōu)越的體現(xiàn)出虛擬儀器的性能。

    二、硬件設(shè)計(jì)

    此虛擬示波器的數(shù)據(jù)采集器由以下功能模塊組成:前端信號變換模塊、高速模數(shù)轉(zhuǎn)換模塊、高速數(shù)據(jù)緩沖模塊、單片機(jī)控制模塊、USB接口模塊和電源模塊。前端信號變換、高速數(shù)據(jù)采集有成熟的方案并且可根據(jù)需要的指標(biāo),譬如采樣率、量程控制、采樣深度等進(jìn)行設(shè)計(jì),我們這里主要討論USB接口部分的開發(fā)。

    USB接口的開發(fā)以往都是一個(gè)令人頭痛的問題,盡管很多設(shè)計(jì)者向往USB接口高速傳輸、自主供電、即插即用的優(yōu)點(diǎn),但較難逾越它的協(xié)議固件開發(fā)和驅(qū)動程序開發(fā)的障礙。在這個(gè)方案里,筆者選用了一款不需要開發(fā)協(xié)議固件和驅(qū)動程序的USB總線接口芯片。

    南京沁恒公司(www.winchiphead.com)推出的CH371是一個(gè)USB總線的通用接口芯片,它利用硬件邏輯屏蔽了USB 通訊中的所有協(xié)議,在計(jì)算機(jī)應(yīng)用層與本地端控制器之間提供端對端的連接?;贑H371,設(shè)計(jì)者不需要了解任何USB協(xié)議、固件程序以及驅(qū)動程序,可以輕松地將原來的并口、串口的產(chǎn)品升級到USB接口,以較低的風(fēng)險(xiǎn)和成本享用USB接口帶來的優(yōu)越性。

    使用時(shí)在本地端,CH371具有8位數(shù)據(jù)總線和讀、寫、片選控制線以及中斷輸出,就像操作一般外設(shè)芯片一樣方便地掛接到DSP、MCU等控制器的系統(tǒng)總線上;在計(jì)算機(jī)端,CH371的配套軟件包括通用驅(qū)動程序以及應(yīng)用軟件包,提供了簡潔易用的操作接口,與本地端的單片機(jī)通訊就如同讀寫硬盤中的文件一樣簡單,開發(fā)者可以使用VB、VC、C++Builder等高級語言進(jìn)行開發(fā)。一般情況下,基于CH371設(shè)計(jì)USB產(chǎn)品不必考慮USB通訊協(xié)議、固件程序、驅(qū)動程序、配置過程、底層數(shù)據(jù)傳輸過程。設(shè)計(jì)者所要做的工作與設(shè)計(jì)并口、串口的產(chǎn)品一樣,包括兩件事:一是從計(jì)算機(jī)的應(yīng)用層發(fā)出數(shù)據(jù)傳輸請求并接收應(yīng)答;二是當(dāng)USB 產(chǎn)品的控制器被通知有數(shù)據(jù)傳輸請求時(shí),作出應(yīng)答。

    同時(shí),CH371在提供了透明的USB協(xié)議的基礎(chǔ)上還提供了I2C器件的直接管理、16個(gè)地址的直接讀寫以及復(fù)位、看門狗等功能,本地端甚至不使用單片機(jī)就可完成簡單的控制功能,因此具有較強(qiáng)的功能適應(yīng)性,能夠滿足不同場合的需要,有效的降低系統(tǒng)成本。

    在本系統(tǒng)中使用的是SOP28封裝的產(chǎn)品,他的管腳定義如下表:

   

    根據(jù)不同的工作方式,芯片的接口類型可以有以下幾種:被動并行接口、I2C主接口、主控方式接口。其中被動并行接口是最常用的方式,它提供單片機(jī)與計(jì)算機(jī)的連接,CH371作為單片機(jī)的一個(gè)被動外設(shè);I2C主接口是CH371在計(jì)算機(jī)端程序的控制下不經(jīng)過單片機(jī)直接讀寫一個(gè)EEPROM器件(譬如24C04等),經(jīng)常用于USB外設(shè)的產(chǎn)品信息紀(jì)錄;主控方式接口是不使用單片機(jī),由計(jì)算機(jī)端程序直接控制CH371提供的16個(gè)地址的8位數(shù)據(jù)讀寫或者是十幾根IO口線,此方式主要用于完成相對簡單的外部控制任務(wù)。這幾種接口方式并非完全對立的,可以根據(jù)需要靈活配置。在此虛擬示波器中則將其使用為單片機(jī)的一個(gè)外設(shè)器件,同時(shí)將A3~A0用于主控方式由計(jì)算機(jī)控制四只LED。

    單片機(jī)對于CH371的控制依靠對其內(nèi)部的16個(gè)寄存器的操作來實(shí)現(xiàn)。這16個(gè)寄存器的地址有兩種定義方式。一種是上電復(fù)位后默認(rèn)為直接地址方式,A3~A0四個(gè)管腳為寄存器地址,這種方式較為簡單,但是需要使用單片機(jī)較多的IO口資源;另一種是當(dāng)CH371檢測到ALE腳上的上升沿信號后,切換到復(fù)用地址方式,寄存器地址由數(shù)據(jù)總線的D3~D0來控制,根據(jù)ALE的跳變來判斷是寄存器操作還是數(shù)據(jù)讀寫。在此設(shè)計(jì)中由于大容量數(shù)據(jù)緩沖需要使用到74373作為地址鎖存,所以即使使用直接地址方式也無需多占用單片機(jī)資源,但是為了將A3~A0節(jié)省出來驅(qū)動LED所以選用復(fù)用地址方式。

    根據(jù)系統(tǒng)的要求我們設(shè)計(jì)硬件如下。

    USB接口提供數(shù)據(jù)交換及電源供應(yīng)(經(jīng)適當(dāng)變換后供高速AD使用),CH371在12M晶振下倍頻工作,提供與單片機(jī)接口的同時(shí)提供看門狗復(fù)位輸出功能,I2C主控功能沒有使用,A3~A0可以由計(jì)算控制驅(qū)動4只LED作為工作顯示信號。單片機(jī)89C52的P1口組用于控制數(shù)據(jù)采集模塊,包括量程轉(zhuǎn)換控制、AD觸發(fā)信號、采集數(shù)據(jù)溢出信號等;高速緩存62256通過低功耗的CPLD控制存放高速AD采集的結(jié)果,單片機(jī)定時(shí)將其中數(shù)據(jù)讀出經(jīng)CH371傳送到計(jì)算機(jī)的數(shù)據(jù)顯示和分析軟件,實(shí)現(xiàn)虛擬示波器功能。單片機(jī)、CH371和RAM部分原理圖如下:

圖三 單片機(jī)、CH371和RAM部分原理圖

    三、軟件設(shè)計(jì)

    單片機(jī)端軟件:

    單片機(jī)端軟件主要完成數(shù)據(jù)采集控制、數(shù)據(jù)報(bào)告這兩個(gè)功能。其中數(shù)據(jù)采集控制根據(jù)計(jì)算機(jī)端軟件設(shè)定的增益、時(shí)基、觸發(fā)等參數(shù)控制數(shù)據(jù)采集模塊,這里面要用到計(jì)算機(jī)向單片機(jī)發(fā)送少量的控制信息;數(shù)據(jù)報(bào)告功能則需要單片機(jī)將緩存中的一個(gè)采集周期的所有數(shù)據(jù)傳送給計(jì)算機(jī)端軟件,這屬于大批量數(shù)據(jù)的傳輸。我們把介紹的重點(diǎn)放在單片機(jī)與計(jì)算機(jī)的通信上面。

    單片機(jī)與計(jì)算機(jī)通信是通過對CH371的寄存器操作實(shí)現(xiàn)的,有關(guān)其寄存器定義的具體情況請參考數(shù)據(jù)手冊。

    在應(yīng)用中需要注意的是,CH371提供的單片機(jī)接收緩沖區(qū)為8個(gè)字節(jié),多于8個(gè)字節(jié)的計(jì)算機(jī)下傳數(shù)據(jù)被切分;而單片機(jī)的發(fā)送緩沖區(qū)也是8個(gè)字節(jié),多于8個(gè)字節(jié)的上傳數(shù)據(jù)需要分多次上傳。另外,CH371的中斷包括了上傳及接受成功,中斷發(fā)生后具體的情況需要由傳輸狀態(tài)寄存器來辨別;同時(shí)其中斷電平是單穩(wěn)態(tài)的,一個(gè)事件發(fā)生后中斷信號跳變,但僅維持一個(gè)短暫的脈沖便恢復(fù),這是為了配合不同速度的處理器而作的處理。

    單片機(jī)與計(jì)算機(jī)的USB通信主要功能子程序示例如下:(請?jiān)谑褂脮r(shí)加入CH371的相應(yīng)寄存器的地址定義)
file://********** CH371初始化程序******************************
void ch371_init()   
{   
   CH371_INT_SET=0;  file://CH371中斷數(shù)據(jù)設(shè)定寄存器的地址偏移   
   CH371_LENGTH=0X0F;  file://置上傳數(shù)據(jù)長度寄存器為15,表示暫時(shí)沒有數(shù)據(jù)上傳
   save_length=0;   file://保存下傳數(shù)據(jù)長度
   IT0=1;      file://外部信號為下降沿觸發(fā)
   IE0=0;      file://清中斷標(biāo)志
   PX0=1;      file://置高優(yōu)先級
   EX0=1;      file://允許中斷
}
file://***********上傳數(shù)據(jù)子程序********************************
void ch371_upload(unsigned char len) file://參數(shù)傳入數(shù)據(jù)長度
{
   unsigned char i;
   unsigned char *up_buf;
   unsigned char *ch371_buf;
   if(len!=0)
{
     up_buf=&ret_buffer;    file://指向數(shù)據(jù)的地址                  
     ch371_buf=&CH371_BUFFER;  file://指向數(shù)據(jù)緩沖區(qū)
     for(i=0;i{
       *ch371_buf=*up_buf;   file://寫入上傳數(shù)據(jù)緩沖區(qū)
       ch371_buf++;       up_buf++;
     }
   }
   CH371_LENGTH=len;     file://寫入本次數(shù)據(jù)的長度
}
file://********中斷子程序  使用中斷0 寄存器組2********
void ch371_inter() interrupt 0 using 2{
   unsigned char *down_buf;
   unsigned char *ch371_buf;
   unsigned char i;
   IE0=0;         file://清中斷標(biāo)志
   if( (CH371_STATUS&0x01) ==0 ){
file://讀取狀態(tài)信息寄存器,判斷數(shù)據(jù)傳輸狀態(tài)
    save_length=CH371_LENGTH;  file://保持下傳數(shù)據(jù)長度
    down_buf=&save_buffer;
    ch371_buf=&CH371_BUFFER;
    for(i=0;ifile://判斷下傳數(shù)據(jù)長度并處理
{
      *down_buf=*ch371_buf;   file://讀取一字節(jié)的下傳數(shù)據(jù)
      down_buf++;      ch371_buf++;
    }
  }
  else CH371_LENGTH=0x0f;   file://置上傳數(shù)據(jù)長度寄存器為15
}

    計(jì)算機(jī)端軟件:

    計(jì)算機(jī)端軟件主要功能是模擬一個(gè)示波器的界面,實(shí)現(xiàn)數(shù)據(jù)的顯示以及滿足不同需要的分析功能,同時(shí)完成對數(shù)據(jù)采集硬件的參數(shù)設(shè)定。在這個(gè)設(shè)計(jì)中已經(jīng)實(shí)現(xiàn)了基本的功能,虛擬示波器的界面如下圖。進(jìn)一步開發(fā)后可以實(shí)現(xiàn)量程的自動轉(zhuǎn)換、數(shù)據(jù)的深度分析(譬如波形測量、頻譜分析等),甚至可以結(jié)合硬件的升級實(shí)現(xiàn)波形發(fā)生器、邏輯分析儀、掃頻儀、網(wǎng)絡(luò)分析儀等功能。

圖四 虛擬儀器計(jì)算機(jī)軟件面板圖

    計(jì)算機(jī)端有關(guān)USB通信的開發(fā)不需要了解USB底層驅(qū)動,并且芯片生產(chǎn)商已經(jīng)以動態(tài)鏈接庫的形式封裝好了面向功能應(yīng)用的API函數(shù),開發(fā)者可以在多種高級語言中調(diào)用,功能強(qiáng)大且靈活方便。CH371動態(tài)鏈接庫提供的API函數(shù)主要包括:設(shè)備管理API、數(shù)據(jù)傳輸API、中斷查詢API、I2C 操作API和直接控制API。

    其中設(shè)備管理API對于一般產(chǎn)品開發(fā)不需要用到;數(shù)據(jù)傳輸API是最重要最常用的一組函數(shù),他提供了多種數(shù)據(jù)傳輸模式;中斷查詢API一般用于USB設(shè)備使用到中斷傳輸?shù)膱龊?,我們這里沒有用到;I2C 操作API用于對CH371控制的I2C器件進(jìn)行讀寫,一般用于存放產(chǎn)品信息,我們這里也沒有用到;直接控制API是用于CH371直接輸入輸出信號,包括設(shè)置、輸入和輸出三部分組成,我們使用這一組API實(shí)現(xiàn)對LED進(jìn)行控制。
在實(shí)際應(yīng)用中筆者使用VB6作為計(jì)算機(jī)端應(yīng)用軟件的開發(fā)平臺,首先要將沁恒公司提供的驅(qū)動程序、動態(tài)鏈接庫拷貝到計(jì)算機(jī)中,再將動態(tài)鏈接庫的訪問入口及函數(shù)定義入口添加至VB6項(xiàng)目中,就是將提供的VB6實(shí)例程序中的module功能模塊添加到自己的工程項(xiàng)目下即可。此時(shí)對USB設(shè)備的通信編程就幾乎和訪問本地硬盤中的文件差不多了,具體差別可以通過分析實(shí)例程序的句法來解決。下面給出計(jì)算機(jī)接收與發(fā)送數(shù)據(jù)的相關(guān)程序。

Option  Explicit         ' 變量定義
Dim  myReq  As  DEMO_REQ
Dim  mOpen  As  Integer

Private  Sub  Form_Load( )                 ' 窗口加載事件
    Dim  mLength  As  Long
    mIndex = 0
    mOpen = CH371OpenDevice(mIndex)      ' 窗體加載時(shí)打開設(shè)備
    If  mOpen = -1 Then
       MsgBox "無法打開CH371設(shè)備"      ' 加載失敗提示     
End If

myReq.mCommand = &HFF        ' 用戶定義命令
myReq.mBuffer(0) = &H11              ' 用戶定義數(shù)據(jù)
myReq.mBuffer(1) = &H22              ' 用戶定義數(shù)據(jù)
mLength = Len(myReq)
CH371WriteData(mIndex, myReq, mLength)  ' 通過CH371發(fā)送命令數(shù)據(jù)
……
CH371ReadData(mIndex, myReq, mLength)  ' 通過CH371接收應(yīng)答數(shù)據(jù)
……
End  Sub

四、結(jié)束語

    使用CH371設(shè)計(jì)的USB接口虛擬示波器目前已完成基本功能的驗(yàn)證,正在后期完善中,而且可以推出面向多種應(yīng)用的不同級別的系列產(chǎn)品。實(shí)踐表明其技術(shù)性能良好,功能強(qiáng)大、體積小巧、使用簡便、價(jià)格低廉,是廣大電子愛好者、開發(fā)者的有力助手。

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

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

關(guān)鍵字: 阿維塔 塞力斯 華為

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

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

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

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

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

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

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

關(guān)鍵字: 騰訊 編碼器 CPU

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

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

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

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

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

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

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

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

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

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