《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FT245BM和FPGA的USB接口設計
基于FT245BM和FPGA的USB接口設計
摘要: 介紹了USB 協議芯片FT245BM的工作原理,設計了FT245BM與FPGA的接口電路,給出了FPGA發送和接收數據幀狀態機的Verilog語言的描述,并介紹了PC機軟件的設計方法。該電路被成功地應用到光纖陀螺多路測試系統中,簡化了電路設計,提高了測試效率。該設計具有很強的通用性。
Abstract:
Key words :

摘要:介紹了USB 協議芯片FT245BM的工作原理,設計了FT245BM與FPGA的接口電路,給出了FPGA發送和接收數據幀狀態機的Verilog語言的描述,并介紹了PC機軟件的設計方法。該電路被成功地應用到光纖陀螺多路測試系統中,簡化了電路設計,提高了測試效率。該設計具有很強的通用性。

一、引言

        USB總線因其傳輸速度快、占用資源少以及真正的即插即用等諸多優點,受到了廣大開發者的青睞,已經成為很多計算機設備的一種基本配置。目前被廣泛采用的USB設備開發方案主要有以下兩種(1)利用USB設備端接口芯片加微控制器結構。如國內用的比較多的Philips公司的PDIUSBD12/ISP1581等。(2)采用USB單片機。采用這兩種方案要求開發者徹底理解USB協議的細節,并編寫出固件程序。固件的運行要占用微控制器的時間和空間資源,實際通信效率不會很高。也有人用FPGA實現固件的功能,但這種方案開發和調試的難度很大。本人在實際工作中用FPGA外部直接連接一片USB協議芯片FT245BM,實現了FPGA與PC機的USB通信,該方法不用微控制器,減少了元器件的個數,并且占用FPGA資源很少,FPGA仍然可以實現其他邏輯功能,系統設計的靈活性很大。

二、FT245BM簡介

        FT245BM由FTDI (Future Technology Devices Int. Ltd.)公司推出,該芯片的主要功能是進行USB和并行I/O口之間的協議轉換。芯片一方面可從主機通過USB串行總線接收數據,并將其轉換為并行I/O口的數據流格式發送給外設;另一方面外設可通過并行I/O口將數據轉換為USB串行數據格式傳回主機。中間的轉換工作全部由芯片自動完成,開發者無須考慮固件的設計。該芯片提供了通用的并行I/O口方便與微控制器、FPGA或其他外設接口。在PC機端安裝了FTDI公司提供的驅動程序,只需熟悉簡單的VB、VC編程,就可很容易地進行上位機軟件開發。

        關于FT245BM的內部結構及詳細地引腳介紹讀者可以參考其他相關資料,在此僅對與本設計相關的內容作一個介紹。FT245BM內含兩個FIFO數據緩沖區,一個是128字節的接收緩沖區,另一個是384字節的發送緩沖區。它們用作USB數據與并行I/O口數據的交換緩沖區。FIFO實現與外界(微控制器、FPGA或其它器件)的接口,主要通過8根數據線D0~D7、讀寫控制線RD#和WR#以及FIFO發送緩沖區空標志TXE#和FIFO接收緩沖區非空標志RXF#來完成數據交互。TXE#為低表示當前FIFO發送緩沖區為空,為高表示當前FIFO發送緩沖區滿或者正在存儲前一個字節,禁止向緩沖區中寫數據。RXF#為低表示當前FIFO的接收緩沖區非空。RD#信號由低變高將從FIFO緩沖區中讀取數據。當RD#變低時將數據送到數據總線。RXF#為高不能從FIFO讀數據。讀寫時序見圖1和圖2。
 

三、 FT245BM與FPGA的接口設計

3.1 硬件電路設計

        圖3是FT245BM的USB與FPGA的接口電路,FPGA選用ALTERA EPF1K50TC-144,其中D0~D7是FT245BM與FPGA交換數據的數據總線,USB_RD#、USB_WR、USB_TXE#、USB_RXF#是相關的控制總線。
 

圖3  FT245BM與FPGA的接口電路

 

3.2 FPGA收發狀態機設計

        下面是用Verilog HDL 描述的FPGA收發狀態機,為便于讀者理解FPGA對FT245BM的讀寫過程,本文將接收和發送狀態機分開給出。當然在實際應用中也可以將接收和發送操作合成一個狀態機來實現。

3.2.1 接收狀態機

        接收狀態機主要功能是查詢USB_RXF引腳的狀態,當檢測到USB_RXF變低,即可獲知上位機已經將數據寫入到FT245BM的緩沖區,然后產生讀控制時序,將FT245BM接收緩沖區中的數據讀入到FPGA的緩沖區。重復以上步驟直到將一幀數據讀完,然后執行相應的幀處理操作。下面是用Verilog HDL描述的接收狀態機。

@always (posedge clk ) /*clk為FPGA工作時鐘。

if(rst && USB_RXF==0)

begin

case(Rstate)

Rstate0:

begin

USB_RD<=0; /*產生讀信號的下降沿

Rstate<=Rstate1;

end

Rstate1:

begin

RframeBuf[Rpointer]<=USB_DATA; /*讀FT245BM芯片FIFO的當前字節

Rstate<=Rstate2;

end

Rstate2:

begin

if(Rpointer== FrameLen-1) /*如果已經接收到完整的一幀,則轉Rstate3,

begin

Rstate<=Rstate3;

Rpointer<=0;

end

else /*一幀未接收完,轉Rstate0繼續接收

begin

Rstate<=Rstate0;

Rpointer<=Rpointer+1;

end

USB_RD<=1;

end

Rstate3: /*處理收到的幀

begin

Rstate<=Rstate0;

/*在此添加處理幀的代碼,本文略*/

end

end

else

begin

Rstate<=Rstate0;

USB_RD<=1;

End

3.2.2 發送狀態機

        發送狀態機完成的主要功能是將外設產生的數據通過FT245BM和USB總線傳送到PC機。外設將數據準備好后,將發送允許信號(SendEN)置為有效,當狀態機檢測到SendEN=1時,即啟動發送操作。首先狀態機從外設的緩沖區按字節將待發送的數據讀到FPGA的緩沖區,并產生寫FT245BM發送緩沖區的時序,將數據寫到FT245BM發送緩沖區。直到將一幀數據發送完畢。下面是FPGA向FT245BM發送數據的狀態機。

@always (posedge clk ) /*clk為FPGA工作時鐘。

if(rst && USB_TXE==0&& SendEN==1) /*rst為異步復位信號, SendEN為發送允許信號,由給Pc機發送數據的邏輯電路置位,數據發送完成由發送狀態機將其清除。

begin

case(Sstate)

Sstate0:

begin

USB_WR<=1; /*產生寫信號的上升沿

Sstate<=Sstate1;

end

Sstate1:

begin

USB_DATA <=SframeBuf[Spointer]; /*寫一個字節到FIFO,SframeBuf為發送緩沖區

Sstate<=Sstate2;

end

Sstate2:

begin

if(Spointer == FrameLen-1) /*如果已經發送完一幀,則轉Sstate3,

begin

Sstate<=Sstate3;

Spointer <=0;

end

else /*未完,轉Sstate0繼續發送

begin

Sstate<=Sstate0;

Spointer <= Spointer +1;

end

USB_WR<=0; /*產生寫usb FIFO信號的下降沿

end

Sstate3:

begin

Sstate<=Sstate0;

/*在此添加處理幀發送完畢的代碼和清除SendEN 信號的代碼,本文略*/

end

end

else

begin

Sstate<=Sstate0;

USB_WR<=0;

End

        限于篇幅,以上狀態機只給出了幀收發的基本操作,因為在不同的應用場合,幀處理的方法也不相同,所以本文沒有給出幀處理代碼。另外,在實際應用時需要注意以下內容:由于FPGA讀寫FT245BM共用一組數據總線,狀態機不能同時對FT245BM進行讀寫操作,當所以當兩個狀態機分開編寫時,為避免沖突需分出讀寫的優先級,此時只需對以上狀態機稍加修改即可。比如當若令讀的優先級高,則在寫的狀態機中將if(rst && USB_TXE==0&& SendEN==1)語句的條件改為if(rst && USB_TXE==0&& SendEN==1&& USB_RXF==1)即可。寫優先級高的情況可以仿照此方法修改。

四、PC機軟件設計

         PC機軟件的設計有兩種方法:一種是在PC機上安裝一個由FTDI公司免費提供的虛擬串行口VCP(Virtual COM Port)驅動程序,將USB口虛擬成一個串口,像一個標準的串口那樣進行進行外設和PC機的通信??杀举|上所有針對虛擬串口的數據通信都是通過USB總線完成的。另外一種方法是利用FTDI公司提供的D2XX驅動程序,通過調用驅動程序的動態鏈接庫直接訪問USB。由于人們對串口的操作比較熟悉,通常用前一種方法訪問USB。比如,在PC端,應用VB對VCP(通常設置為COM3)進行編程??梢灾苯討肕SComm控件,將MSComm.CommPort置為3,MSComm.Setings置為“9600,n,8,1”(該速率為默認設置,實際上VCP驅動程序總是使數據以最快速率傳輸);通過MSComm.PortOpen設置COM3的開關狀態;通過MSComm.Input和MSComm.Output讀入或輸出數據。在讀取數據時,設置MSComm.Rthreshold的值為1。只要有數據傳到PC機,就立即觸發MSComm.CommEvent事件,自動讀取COM3的數據;而發送數據則可自動或手動發送,由用戶自己設置。以上操作與操縱標準的串行口完全一致。

五、結語

        以上狀態機在MaxPlusII10.2下調試并下載到FPGA運行通過,軟件在Windows 2000,VB6.0環境下調試通過。該電路成功應用到光纖陀螺多路測試系統中,實現了同時對4路陀螺信號的同時測試,簡化了電路設計,提高了測試效率。

參考文獻:

[1] FT245BM data sheet. Future Technology Devices Int. Ltd.

[2] 夏宇聞. Verilog 數字系統教程[M]. 北京:北京航空航天大學出版社,2004

[3] 張俊安. 用VB實現windows 9x環境下的串口通信[J]. 山東煤炭科技, 2000年增刊:73~74
 

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲一二三级电影| 欧美制服丝袜| 欧美成年人视频网站欧美| 午夜精品亚洲一区二区三区嫩草| 亚洲高清视频在线观看| 这里只有视频精品| 欧美日韩激情网| 老司机凹凸av亚洲导航| 午夜一区二区三区不卡视频| 国产精品美女久久久久av超清| 美女国产精品| 在线视频欧美日韩精品| 欧美中文字幕视频在线观看| 久热精品视频在线免费观看| 国产综合色产在线精品| 欧美日韩一二三区| 欧美国产日韩一区二区三区| 狠狠色香婷婷久久亚洲精品| 免费一级欧美片在线观看| 一区二区av在线| 亚洲一区二区三区精品动漫| 欧美视频中文一区二区三区在线观看| 国产一区二区在线观看免费| 欧美激情一区二区三区在线视频| 亚洲福利久久| 国产亚洲欧美一区二区| 久久蜜桃资源一区二区老牛| 亚洲欧美日韩爽爽影院| 最近中文字幕mv在线一区二区三区四区| 韩国成人福利片在线播放| 欧美日韩精品一区视频| 一区二区日韩免费看| 国产精品青草综合久久久久99| 欧美电影免费观看大全| 国产精品免费一区豆花| 牛人盗摄一区二区三区视频| 日韩视频在线免费观看| 亚洲一区二区黄色| 亚洲国产成人精品久久久国产成人一区| 一区二区三区视频观看| 欧美亚日韩国产aⅴ精品中极品| 久久精品国产亚洲5555| 欧美日韩在线亚洲一区蜜芽| 欧美电影在线| 国产乱码精品一区二区三区忘忧草| 久久亚洲精品网站| 欧美激情按摩| 免费高清在线视频一区·| 国产欧美日韩综合| 欧美色区777第一页| 午夜激情久久久| 亚洲高清久久网| 欧美亚洲第一页| 在线亚洲免费| 亚洲午夜久久久久久久久电影网| 揄拍成人国产精品视频| 久久精品91久久香蕉加勒比| 免费久久久一本精品久久区| 久久视频精品在线| 欧美综合国产精品久久丁香| 亚洲大片在线| 一区二区电影免费在线观看| 欧美亚洲第一页| 极品尤物久久久av免费看| 欧美伦理一区二区| 欧美日韩一区在线| 亚洲欧美欧美一区二区三区| 国产精品99久久久久久久久久久久| 国产一区二区三区在线观看网站| 9色国产精品| 亚洲国产高清一区二区三区| 久久久91精品国产| 一区二区三区国产精品| 国内精品美女在线观看| 国产精品乱子久久久久| 欧美午夜精品久久久久久人妖| 欧美日韩p片| 欧美成人一区二区三区| 欧美激情精品| 国产视频一区免费看| 欧美午夜电影网| 欧美色大人视频| 最新成人在线| 久久免费的精品国产v∧| 国产欧美日韩一区二区三区| 久久精品成人欧美大片古装| 激情综合激情| 亚洲精品美女久久7777777| 欧美午夜精品理论片a级按摩| 亚洲一区免费观看| 欧美日韩国产高清视频| 国产精品男gay被猛男狂揉视频| 欧美日韩免费一区二区三区| 欧美在线视频免费观看| 国产欧美日韩一区二区三区在线| 久久在线91| 乱中年女人伦av一区二区| 欧美激情久久久久久| 国产精品系列在线播放| 国产精品扒开腿做爽爽爽视频| 久久久久久亚洲精品杨幂换脸| 麻豆国产精品777777在线| 久久夜色精品| 中文一区二区在线观看| 亚洲精品极品| 亚洲电影欧美电影有声小说| 国产欧美日韩亚州综合| 国产精品三级久久久久久电影| 欧美高清视频| 精品动漫3d一区二区三区免费| 国产一区二区精品丝袜| 亚洲在线观看| 欧美激情第三页| 精品成人久久| 欧美国产在线视频| 久久久一本精品99久久精品66| 玖玖玖免费嫩草在线影院一区| 久久偷看各类wc女厕嘘嘘偷窃| 欧美日本不卡| 伊人精品成人久久综合软件| 激情欧美一区二区| 亚洲高清在线播放| 欧美成人精精品一区二区频| 夜夜嗨av一区二区三区免费区| 欧美日韩中文字幕综合视频| 欧美高清视频www夜色资源网| 国产精品揄拍500视频| 国产精品免费观看在线| 亚洲黄色一区二区三区| 国产精品福利网站| 欧美极品欧美精品欧美视频| 欧美日韩一区二区在线观看视频| 欧美激情一区二区久久久| 奶水喷射视频一区| 亚洲精品乱码久久久久久| 欧美日韩国产成人在线免费| 欧美日韩国产高清视频| 欧美aⅴ99久久黑人专区| 欧美日韩少妇| 欧美大尺度在线| 久久婷婷蜜乳一本欲蜜臀| 99精品久久久| 欧美第一黄网免费网站| 一卡二卡3卡四卡高清精品视频| 国产亚洲第一区| 一色屋精品视频在线观看网站| 一本在线高清不卡dvd| 欧美日韩综合不卡| 欧美日韩国产成人高清视频| 欧美在线三级| 91久久夜色精品国产网站| 亚洲国产成人在线| 久久综合九色欧美综合狠狠| 最新日韩精品| 亚洲美女精品一区| 在线观看国产一区二区| 羞羞漫画18久久大片| 国产精品视频精品视频| 国产精品免费区二区三区观看| 免费毛片一区二区三区久久久| 国内综合精品午夜久久资源| 欧美jizz19hd性欧美| 国产麻豆午夜三级精品| 欧美亚洲第一区| 午夜精品福利一区二区蜜股av| 久久精品一区二区三区中文字幕| 欧美影片第一页| 国产一区二区无遮挡| 欧美多人爱爱视频网站| 香蕉国产精品偷在线观看不卡| 欧美~级网站不卡| 国产精品久久777777毛茸茸| 国产精品久久久久久久久久妞妞| 免费精品视频| 亚洲欧洲免费视频| 国产精品久久91| 欧美日韩亚洲精品内裤| 欧美日韩一区二区国产| 久久精品成人一区二区三区蜜臀| 一区久久精品| 国产三级精品在线不卡| 精品动漫3d一区二区三区| 另类酷文…触手系列精品集v1小说| 欧美日韩亚洲一区二区三区在线观看| 雨宫琴音一区二区在线| 久久精品视频免费| 在线成人h网| 亚洲一级二级| 国产精品亚洲精品| 国产日本欧洲亚洲| 欧美午夜一区二区| 亚洲电影免费在线观看| 亚洲精品免费网站| 亚洲精品日韩一| 999在线观看精品免费不卡网站| 欧美日韩在线一区| 狠狠色狠狠色综合日日五| 亚洲精品一区二区网址| 欧美有码在线视频| 亚洲精品免费在线观看| 亚洲精品三级| 欧美久久久久中文字幕| 亚洲男人的天堂在线| 国产精品乱码一区二三区小蝌蚪| 免费成人高清在线视频| 最近中文字幕日韩精品| 亚洲美女色禁图| 国产精品无人区| 99国产精品私拍| 亚洲一区影院| 激情视频亚洲| 欧美精品久久久久久久久老牛影院| 亚洲影院免费观看| 国产精品一区二区男女羞羞无遮挡| 国产精品综合av一区二区国产馆| 99热免费精品在线观看| 欧美3dxxxxhd| 亚洲免费在线电影| 欧美日韩另类字幕中文| 国产精品欧美日韩一区二区| 久久高清免费观看| 国产欧美精品在线观看| 亚洲欧洲一区二区三区| 国产精品久久久久毛片软件| 99天天综合性| 久久国产精品一区二区三区四区| 欧美日韩一区三区| 欧美视频在线播放| 一区二区日韩免费看| 久久亚洲一区二区三区四区| 亚洲国产精品999| 久久久爽爽爽美女图片| 亚洲欧美激情四射在线日| 免费在线观看日韩欧美| 你懂的视频一区二区| 欧美日韩国产成人在线观看| 在线欧美不卡| 国产综合精品一区| 一本色道久久综合一区| 欧美另类99xxxxx| 久久综合久色欧美综合狠狠| 在线日韩精品视频| 99国产精品国产精品久久| 精品二区视频| 欧美日韩国产色综合一二三四| 国产精品久久久一区二区三区| 在线看视频不卡| 亚洲国产成人91精品| 亚洲一区免费在线观看| 亚洲精品一区中文| 欧美久久一级| 亚洲精品乱码久久久久久按摩观| 久久成人这里只有精品| 亚洲精品久久| 国产精品一区二区三区四区| 欧美aaaaaaaa牛牛影院| 欧美国产成人精品| 开心色5月久久精品| 国产欧美日韩一区二区三区| 怡红院精品视频| 在线视频欧美日韩精品| 国产精品日韩在线播放| 欧美少妇一区二区| 国产精品99久久99久久久二8| 欧美日韩一区二区免费视频| 久久久青草青青国产亚洲免观| 欧美亚洲在线观看| 欧美日韩国产成人| 久久免费视频网站| 亚洲高清视频在线观看| 国产农村妇女精品| 国产亚洲制服色| 国产亚洲一级高清| 国产亚洲欧美日韩美女| 国产精品欧美久久| 在线观看一区| 久久综合伊人| 国产日本欧美一区二区三区| 欧美日韩国产在线播放网站| 亚洲国产成人精品视频| 狠狠色综合日日| 在线国产精品播放| 欧美日韩高清在线| 亚洲小说春色综合另类电影| 亚洲欧洲一区| 国产精品亚洲аv天堂网| 国产精品网站视频| 亚洲欧洲精品一区二区精品久久久| 久久一区视频| 中文高清一区| 亚洲激情图片小说视频| av成人免费在线观看| 国产精品免费在线| 国产精品―色哟哟| 欧美一区二区视频网站| 日韩视频免费看| 亚洲激情图片小说视频| 国产精品久久久久毛片软件| 亚洲天堂av在线免费观看| 欧美日韩国产在线| 国产亚洲精品久久久久婷婷瑜伽| 亚洲第一区中文99精品| 久久精品国产一区二区三区| 夜夜嗨av色一区二区不卡| 欧美精品videossex性护士| 中国成人在线视频| 99精品视频免费观看视频| 在线观看欧美黄色| **性色生活片久久毛片| 国内久久精品视频| 国产麻豆日韩欧美久久| 欧美精品 国产精品| 亚洲看片网站| 久久蜜桃香蕉精品一区二区三区| 国产精品日产欧美久久久久| 亚洲精选久久| 在线看欧美视频| 国产精品青草久久| 狠狠色综合网| 日韩一级视频免费观看在线| 影音先锋一区| 国产欧美一区在线| 99精品国产热久久91蜜凸| 亚洲男人av电影| 亚洲欧美日韩天堂一区二区| 99riav1国产精品视频| 国产精品久久久久久久久久ktv| 国产精自产拍久久久久久蜜|