當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式硬件


USB(通用串行總線(xiàn))是一種新的數(shù)據(jù)通信接口方式,它使得外圍沒(méi)備到計(jì)算機(jī)的連接更加高效、便利。

USB接口不僅具有快速、即插即用、支持熱插拔的特點(diǎn),而且能同時(shí)連接多達(dá)127個(gè)外部設(shè)備,可以有效地解決PC機(jī)外圍接口不足的問(wèn)題。目前USB這一接口形式在微電子控制系統(tǒng)的設(shè)計(jì)中得到了廣泛應(yīng)用。

在近期參與開(kāi)發(fā)的數(shù)控系統(tǒng)中,應(yīng)客戶(hù)要求需要將USB接口引入到數(shù)控系統(tǒng)中。由于該USB數(shù)據(jù)通信接口設(shè)計(jì)僅是系統(tǒng)設(shè)計(jì)的一個(gè)很小的部分,如果仍采用傳統(tǒng)的設(shè)計(jì)方法實(shí)現(xiàn),那么將耗費(fèi)較多的時(shí)間和精力,而且最終也未必能獲得理想的效果。為了擺脫常規(guī)USB數(shù)據(jù)接口設(shè)計(jì)的難度,加快系統(tǒng)開(kāi)發(fā)進(jìn)程,我們引入了基于FT245BM的快速USB接口設(shè)計(jì),使系統(tǒng)開(kāi)發(fā)節(jié)奏加快,保證整套系統(tǒng)設(shè)計(jì)周期的縮短。

1 FT245BM芯片簡(jiǎn)介

FT245BM是FTDI(Future Technology Devices IntlLtd)公司的多種快速USB通信接口解決方案之一。它無(wú)需編寫(xiě)片內(nèi)固件程序,上層PC機(jī)則使用FTDI公司提供的官方驅(qū)動(dòng)程序。

FT245BM芯片的主要功能是在內(nèi)部硬件邏輯的作用下實(shí)現(xiàn)USB串行數(shù)據(jù)格式與并行數(shù)據(jù)格式的雙向轉(zhuǎn)換。PC機(jī)通過(guò)USB接口與FT245BM進(jìn)行數(shù)據(jù)交換,F(xiàn)T245BM則通過(guò)并行方式與下位微控制器通信。FT25BM芯片引腳見(jiàn)圖1。

該芯片有如下特點(diǎn):

單芯片實(shí)現(xiàn)USB與并行FIFO緩沖區(qū)的雙向數(shù)據(jù)傳輸;FTDI公司提供VCP(虛擬串行口)和D2XX兩種驅(qū)動(dòng)程序,使用D2XX驅(qū)動(dòng)程序能獲得更好的數(shù)據(jù)傳輸性能,傳輸速率最大可達(dá)1 MB/s;通過(guò)簡(jiǎn)單的四線(xiàn)握手信號(hào)與MCU、CPLD、FPGA等邏輯器件接口;完整的片內(nèi)USB協(xié)議解決方案,無(wú)需底層固件的編程;完全兼容USB1.1,USB2.0協(xié)議;)附加的EEPROM接口可定制USB接口設(shè)備。

2 USB接口的硬件設(shè)計(jì)

由USB設(shè)計(jì)規(guī)范可知,USB設(shè)備有總線(xiàn)供電和自供電兩種方式??紤]到開(kāi)發(fā)的數(shù)控系統(tǒng)并不屬于移動(dòng)應(yīng)用,無(wú)需通過(guò)總線(xiàn)供電方式來(lái)供給芯片工作所需電源,因此采用自供電方式進(jìn)行設(shè)計(jì)。采用自供電方式的基于FT245BM的USB接口電路原理如圖2所示。

FT245BM通過(guò)8位并行數(shù)據(jù)口D[0..7]和4位讀寫(xiě)狀態(tài)/控制口 RXF#、TXE#、RD#、WR實(shí)現(xiàn)與微控制器交換數(shù)據(jù),而PC機(jī)與FT245BM問(wèn)通過(guò)UISB總線(xiàn)傳輸數(shù)據(jù)。可選的外部EEPROM用于存儲(chǔ)USB設(shè)備的特定信息,呵以通過(guò)EECS、EESK、EEDATA來(lái)完成數(shù)據(jù)寫(xiě)入和讀出。由于設(shè)計(jì)采用自供電的方式,為防止USB主機(jī)或USB HUB(集線(xiàn)器)控制器在斷電情況下USB接口設(shè)備將電流灌入U(xiǎn)SB總線(xiàn)(USB主機(jī)或USB HUB控制器將突然上電而可能導(dǎo)致?lián)p壞),在USBDP的上拉電路中加入檢測(cè)USB總線(xiàn)電流的NPN型晶體管2N3904。當(dāng)總線(xiàn)有電時(shí),2N3904飽和導(dǎo)通,USBDP通過(guò)1.5 kΩ電阻上拉至RSTOUT#3.3 V,USB數(shù)據(jù)通信正常進(jìn)行;當(dāng)USB總線(xiàn)失電時(shí),2N3904因基極無(wú)電流而截止,阻止電流由RSTOUT#進(jìn)入U(xiǎn)SB總線(xiàn),可有效防止USB主機(jī)的突然上電。

3 USB接口的軟件設(shè)計(jì)

USB接口軟件是配合接口硬件實(shí)現(xiàn)USB數(shù)據(jù)的高效快速傳輸,包括微控制器端和PC端兩部分。

3.1 微控制器端軟件的設(shè)計(jì)

微控制器通過(guò)FT245BM提供的數(shù)據(jù)和控制接口實(shí)現(xiàn)數(shù)據(jù)的交換。

讀操作時(shí)序見(jiàn)圖3。當(dāng)RxF#為低,表示當(dāng)前FIFO接收緩沖區(qū)內(nèi)有數(shù)據(jù),可以執(zhí)行讀操作讀取接收緩沖區(qū)數(shù)據(jù)。在RD#電平由高變低,F(xiàn)IFO控制器將接收緩沖區(qū)中的數(shù)據(jù)輸出到8位數(shù)據(jù)端口上,微控制器此時(shí)只需讀取I/O口就可以將數(shù)據(jù)取到內(nèi)部數(shù)據(jù)總線(xiàn)上來(lái),再將RD#信號(hào)拉高完成1個(gè)字節(jié)數(shù)據(jù)的讀取。當(dāng)將FIFO接收緩沖區(qū)中的數(shù)據(jù)全部取出后,RXF#被拉高表示數(shù)據(jù)為空。在RXF#為高時(shí),禁止從FIFO接收緩沖區(qū)讀取數(shù)據(jù)。

寫(xiě)操作時(shí)序見(jiàn)圖4。當(dāng)TXE#為低,表示當(dāng)前FIFO發(fā)送緩沖區(qū)空,可以向發(fā)送緩沖區(qū)寫(xiě)人數(shù)據(jù)。在WR為高電平時(shí),微控制器將8位數(shù)據(jù)D[0..7]送到并行I/O口上,在WR信號(hào)電平由高變低時(shí)數(shù)據(jù)被寫(xiě)入發(fā)送緩沖區(qū)中。當(dāng)TXE#為高時(shí),表示當(dāng)前FIFO發(fā)送緩沖區(qū)已滿(mǎn)或者正在寫(xiě)入上一個(gè)字節(jié),此時(shí)禁止向發(fā)送緩沖區(qū)中寫(xiě)入任何數(shù)據(jù)。微控制器向FT245BM寫(xiě)人數(shù)據(jù)時(shí)應(yīng)確保TXE#為低。

3.2 PC機(jī)端軟件的設(shè)計(jì)

USB設(shè)備插入PC機(jī)時(shí)操作系統(tǒng)會(huì)請(qǐng)求安裝設(shè)備驅(qū)動(dòng)程序,F(xiàn)TDI公司為基于FT245BM的USB接口設(shè)備提供了VCP、D2XX(動(dòng)態(tài)鏈接庫(kù))兩種驅(qū)動(dòng)程序。選擇不同的驅(qū)動(dòng)程序,PC機(jī)端軟件設(shè)計(jì)方法也不同。

3.2.1 基于VCP的PC機(jī)端軟件設(shè)計(jì)

選擇安裝VCP驅(qū)動(dòng)程序時(shí),操作系統(tǒng)將基于FT245BM的USB接口設(shè)備虛擬成為串行通信口,對(duì)這一虛擬的串行口的操作就等同于對(duì)該USB接口設(shè)備的操作,因此在應(yīng)用程序中可以利用串行通信控件來(lái)簡(jiǎn)化PC機(jī)端軟件的設(shè)計(jì)。目前比較成熟的串行通信控件有MSCOMM、SPCOMM、PCCOMM等,本文采用Delphi和SPCOMM來(lái)完成基于VCP的PC端軟件的設(shè)計(jì)。利用SPCOMM編寫(xiě)針對(duì)串行口操作的程序比較容易,它有豐富的與串口通信密切相關(guān)的屬性及事件,提供了對(duì)串口的各種操作。根據(jù)SPCOMM提供的屬性、方法、事件可以完成對(duì)虛擬成串行口的FT245BM的讀寫(xiě),避開(kāi)了對(duì)USB接口本身的操作。

基于VCP的軟件設(shè)計(jì)介紹如下。首先設(shè)置好需要打開(kāi)的VCP的各個(gè)屬性,調(diào)用StartComm方法打開(kāi)VCP,然后通過(guò)WriteCommData將數(shù)據(jù)寫(xiě)人到發(fā)送緩沖區(qū),由計(jì)算機(jī)硬件實(shí)現(xiàn)物理層的數(shù)據(jù)發(fā)送。數(shù)據(jù)到達(dá)PC機(jī)將會(huì)觸發(fā)控件的OnReceiveData事件,在該事件下接收數(shù)據(jù)并轉(zhuǎn)存以供后續(xù)的處理。接收數(shù)據(jù)出錯(cuò)時(shí)將觸發(fā)OnReceiveError事件,在該事件中可進(jìn)行出錯(cuò)處理。數(shù)據(jù)傳輸完畢后調(diào)用StopComm關(guān)閉VCP,結(jié)束一次通信過(guò)程。

3.2.2 基于D2XX的PC機(jī)端軟件設(shè)計(jì)

選擇D2XX作為USB接口的設(shè)備驅(qū)動(dòng)程序,應(yīng)用程序通過(guò)FTD2XX.DLL、FTD2XX.SYS、Windows USBDriver Stack來(lái)實(shí)現(xiàn)對(duì)FT245BM。的讀寫(xiě)。因此,在程序編寫(xiě)時(shí)只需調(diào)用FTD2XX.DLL中的函數(shù),便可完成對(duì)USB接口設(shè)備的讀寫(xiě)操作。

FTD2XX.DLL提供了豐富的接口函數(shù)來(lái)訪(fǎng)問(wèn)FT245BM,主要函數(shù)簡(jiǎn)介如下:

FT_ListDevice:獲取當(dāng)前PC機(jī)上連接的所有的FTDI USB接口設(shè)備的信息;

FT_Open,F(xiàn)T_OpenEx:打開(kāi)FTDI USB接口;

FT_Read:從FTDI USB接口讀取數(shù)據(jù);

FT_Write:向FTDI USB接口寫(xiě)入數(shù)據(jù);

FT_Close:關(guān)閉FTDI USB接口。

使用DLL(動(dòng)態(tài)鏈接庫(kù))函數(shù)首先要在接口單元處重新聲明程序中需要使用到的函數(shù)。FTD2XX中DLL函數(shù)聲明示例如下:

采用Delphi 7編寫(xiě)的數(shù)據(jù)發(fā)送示例程序PcData_To_UsbDevice如下:

4 結(jié)束語(yǔ)

通過(guò)上述的軟硬件設(shè)計(jì),可以快速實(shí)現(xiàn)USB接口的設(shè)計(jì),滿(mǎn)足數(shù)控系統(tǒng)所要求的高速數(shù)據(jù)傳輸任務(wù)。采用這種USB設(shè)計(jì)方案在實(shí)際應(yīng)用中表現(xiàn)良好,達(dá)到了預(yù)期目的,為數(shù)控系統(tǒng)如期交貨創(chuàng)造了條件。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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