當(dāng)前位置:首頁 > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]自1994年11月提出通用串行總線(USB)以來,USB以其傳輸速率高、支持熱插拔、易于擴展的突出優(yōu)勢,發(fā)展速度驚人,迅速席卷電子產(chǎn)品世界。在市場需求的強力驅(qū)動下,從1998年開

自1994年11月提出通用串行總線(USB)以來,USB以其傳輸速率高、支持熱插拔、易于擴展的突出優(yōu)勢,發(fā)展速度驚人,迅速席卷電子產(chǎn)品世界。在市場需求的強力驅(qū)動下,從1998年開始,USB接口進入測量儀器領(lǐng)域,并逐步被許多著名儀器公司接納。在測量儀器中擴展USB接口已經(jīng)成為一種發(fā)展趨勢。針對不同的測量儀器,尋求一種普遍適用的USB接口解決方案,對于測量儀器的開發(fā)設(shè)計有十分重要的意義。

方案選擇

開發(fā)USB設(shè)備一般有三種方式:一種是使用帶USB接口的專用微控制器(MCU),這類MCU有自己的系統(tǒng)結(jié)構(gòu)和指令,從底層專用于USB控制,比如Cypress公司的CY7C63xxx和CY7C64013,這類MCU的開發(fā)需要用專用工具,且性能有限;第二種方式是使用帶USB接口的通用MCU,這類MCU只是基于一般芯片內(nèi)核增加了USB接口,比如Intel公司的8x931、8x930以及Cypress公司的EZUSB等,這類 MCU的開發(fā)語言和開發(fā)工具都和一般MCU相似,因而較易入手,但其缺點是成本較高;第三種方式是使用純粹的USB接口芯片,通過外加MCU對其控制。如 Philips公司的PDIUSBD12、ISP1581以及National公司的USBN9602、南京沁恒公司的CH372、CH375等。這類 USB接口芯片價格較低、接口方便、靈活性高,針對不同的硬件環(huán)境可以配合多種MCU使用,如單片機、DSP、FPGA都可以。綜合各方面因素考慮,本設(shè)計選用第三種方式,即采用專用USB接口芯片為測量儀器擴展USB接口。

硬件設(shè)計

USB控制器

USB控制器通過控制USB接口芯片實現(xiàn)協(xié)議處理和數(shù)據(jù)交換。在本設(shè)計中選用DSP芯片TMS320VC33作為微控制器,這主要是基于兩方面的考慮:一是其運算速度較快,指令周期僅為13nS,可以最大限度地發(fā)揮USB接口芯片的潛力;二是該DSP芯片性價比高,且具有浮點運算功能,擴展浮點精度可達(dá)40位。

USB接口芯片

USB接口芯片用以完成USB通信底層的數(shù)據(jù)鏈路級交換,并對本地微控制器提供一個并行接口。

本文選用PHILIPS公司的PDIUSBD12作為USB接口芯片。該芯片可與任何微控制器實現(xiàn)高速并行接口(2Mb/s),允許使用現(xiàn)存的體系結(jié)構(gòu)并使固件投資減到最小。這種靈活性減少了開發(fā)時間、風(fēng)險和成本,是開發(fā)高效低成本的USB外圍設(shè)備的一種快捷途徑。

PDIUSBD12一共有三組端點:端點0完成控制傳輸;端點1可以配置成中斷傳輸;端點2有128B的緩沖區(qū),是主要的數(shù)據(jù)傳輸端點。

接口電路

采用單獨地址/數(shù)據(jù)總線配置,即用DSP的某地址線控制PDIUSBD12的A0引腳,實現(xiàn)命令數(shù)據(jù)的選擇。A0=1表示傳送命令,A0=0表示傳送數(shù)據(jù)。片選(CS )及掛起(SUSPEND)信號分別由DSP的I/O口控制。讀寫選通信號WR 、RD 可以用DSP的R/W引腳及其取反后控制。但這樣需要在電路中增加反相器,為了節(jié)約器件從而縮小電路體積,可以另外選擇一個I/O口控制 PDIUSBD12的讀選通RD。本設(shè)計中選用PAGE1,通過對不同地址的訪問來區(qū)分對PDIUSBD12的讀寫操作。這樣PDIUSBD12只占用微控制器的三個地址資源,其一用來向PDIUSBD12寫命令,其二用來向PDIUSBD12寫數(shù)據(jù),另外一個用來從PDIUSBD12讀數(shù)據(jù)。對DSP而言,PDIUSBD12就相當(dāng)于一個有8位數(shù)據(jù)總線和3個地址的存儲器件。

設(shè)備采用自供電方式,需要將EOT 通過一個10k?的電阻接至USB電纜的VCC(+5V)端,并加1M?下拉電阻,借此檢測USB設(shè)備是否已經(jīng)連接到USB口。

軟件設(shè)計

USB軟件設(shè)計包括固件(firmware)程序、PC端的驅(qū)動程序和應(yīng)用程序。其中固件程序要求編寫者對復(fù)雜的USB通信協(xié)議有深刻的理解,編程難度較高,在本論文中將詳細(xì)介紹。

固件編程

固件程序是寫入MCU內(nèi)的程序,使MCU可以完全按照USB協(xié)議,識別接收到的信息包類型,對包的內(nèi)容、意義進行分析,并按照要求完成相應(yīng)的動作。通過這些不同類型包的傳遞,完成MCU與接口芯片的命令及數(shù)據(jù)交換,進而實現(xiàn)主機與設(shè)備間的通信。

固件程序設(shè)計成中斷驅(qū)動模式,采用模塊化設(shè)計。

主循環(huán)

主循環(huán)中主要完成DSP的寄存器及端口初始化,向PDIUSBD12發(fā)送設(shè)置模式命令,接通SoftConnect。判斷是否接收到建立包(setup package),若收到則調(diào)用標(biāo)準(zhǔn)請求處理程序進行處理,若收到主機請求信號,則調(diào)用數(shù)據(jù)發(fā)送程序發(fā)送數(shù)據(jù)。

中斷處理程序

中斷處理程序是整個固件程序設(shè)計的重點。將DSP設(shè)置為下降沿觸發(fā),當(dāng)PDIUSBD12接收到主機發(fā)送的信息包時,觸發(fā)DSP進入中斷。首先通過讀取PDIUSBD12的中斷寄存器判斷所發(fā)生中斷的類型,然后根據(jù)具體的中斷類型進入相應(yīng)的處理子程序。

標(biāo)準(zhǔn)請求處理程序

USB協(xié)議中規(guī)定了11條所有USB設(shè)備都必須支持的標(biāo)準(zhǔn)請求,這些請求都是通過端點0發(fā)送的。標(biāo)準(zhǔn)請求處理程序?qū)χ鳈C發(fā)出的標(biāo)準(zhǔn)請求進行響應(yīng),獲取設(shè)備的性能及狀態(tài),并給設(shè)備分配地址且進行相應(yīng)配置,最終完成枚舉過程。

硬件接口及PDIUSBD12命令操作程序

硬件接口程序集成了DSP對PDIUSBD12的讀寫操作,是整個固件程序中最底層也是使用最頻繁的部分,將它獨立成一個模塊編寫極大地方便了程序在不同硬件平臺上的移植。值得注意的是:PDIUSBD12要求數(shù)據(jù)線上的數(shù)據(jù)建立時間和保持時間必須大于40nS,因此編程時需要插入至少4個軟件等待狀態(tài)。另外,因為PDIUSBD12的最小讀寫周期為500nS,所以在每次對其進行讀寫操作后必須增加適當(dāng)?shù)难訒r。

數(shù)據(jù)發(fā)送及接收程序

當(dāng)用戶通過主機端應(yīng)用程序向設(shè)備索要數(shù)據(jù)時,DSP調(diào)用數(shù)據(jù)發(fā)送子程序完成數(shù)據(jù)發(fā)送,針對發(fā)送數(shù)據(jù)量的大小,可以選擇使用端點1或者端點2完成。對于主機發(fā)送數(shù)據(jù)的接收,在端點0及端點1的IN中斷子程序中即可完成。發(fā)送數(shù)據(jù)子程序如下:

 


調(diào)試

固件程序?qū)r間敏感,所以編程時要特別注意時序問題。由于USB枚舉過程很快,如果連續(xù)三次接收不到應(yīng)答包就結(jié)束枚舉,所以調(diào)試時要注意不能采用CCS的單步調(diào)試,可以采用斷點調(diào)試。調(diào)試過程之初經(jīng)常會遇到的一種狀況是指示燈閃爍三次以后熄滅,這說明主機檢測到了設(shè)備連接,但無法和設(shè)備進行對話來了解設(shè)備的信息。這表明固件程序還沒有開始正常工作,需仔細(xì)檢查程序中的錯誤之處。[!--empirenews.page--]

調(diào)試過程之初,可以使用以下兩種方法檢測硬件連接是否正確:

1. 使用命令字FDh讀取PDIUSBD12的ID號,正常狀態(tài)下讀出的兩個字節(jié)應(yīng)該為12H和10H。

2. 通過設(shè)置PDIUSBD12工作模式,改變輸出時鐘頻率。在CLKout引腳測量輸出波形,觀察是否與設(shè)置值相符。

若以上兩條滿足,則說明硬件連接基本沒有問題。

PC端軟件

PC端軟件包括設(shè)備驅(qū)動程序和應(yīng)用程序兩部分。

系統(tǒng)驅(qū)動程序是基于WDM (Windows Driver Model) 驅(qū)動程序模型設(shè)計的,包括四個模塊:初始化模塊、即插即用管理模塊、電源管理模塊和I/O功能模塊。本設(shè)計選用輔助工具DriverStudio,它能很好地和DDK結(jié)合,編程思路也比較清晰。首先使用驅(qū)動向?qū)?DriverWizard)建立項目,設(shè)置驅(qū)動程序類型,設(shè)置USB設(shè)備的 VID(Vendor ID)和PID(Product ID)及其各端點的屬性。給端點2增加讀寫函數(shù)代碼。這樣就創(chuàng)建了一個驅(qū)動程序的總體框架。再對生成的代碼進行修改編譯和測試,完成USB驅(qū)動程序的開發(fā)。

應(yīng)用程序是為了實現(xiàn)用戶和設(shè)備的接口,基本功能包括檢測USB設(shè)備、開啟或閉合USB設(shè)備、設(shè)置USB數(shù)據(jù)傳輸管道、實時從USB接口采集數(shù)據(jù)以及顯示數(shù)據(jù)等。程序使用VC++編寫,調(diào)用Win32的應(yīng)用程序接口(API)函數(shù),實現(xiàn)應(yīng)用程序和設(shè)備驅(qū)動的通信。使用PHILIPS公司提供的 EasyD12.dll動態(tài)鏈接庫可以使開發(fā)過程更加輕松快捷。

結(jié)束語

系統(tǒng)測試結(jié)果表明:主機與設(shè)備間的數(shù)據(jù)傳輸平均速率達(dá)到130kb/s,完全可以滿足一般測量儀器的需要。此項接口設(shè)計方案具有良好的可移植性,針對不同的硬件平臺僅需做少許修改即可應(yīng)用。隨著USB技術(shù)的進一步發(fā)展,USB2.0和USB OTG規(guī)范的推出以及無線USB的出現(xiàn),USB儀器將成為測量儀器的發(fā)展方向,并推動傳統(tǒng)儀器向小型化和微型化方向發(fā)展。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(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ā)耗時1.5...

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

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

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

8月30日消息,據(jù)媒體報道,騰訊和網(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 手機 衛(wèi)星通信

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

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

北京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ù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

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