999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

slaveFIFO模式下USB和FPGA的數據通信

2014-08-04 12:44:28周瑩鄒連英
中國新通信 2014年10期

周瑩 鄒連英

【摘要】 本文介紹了基于USB2.0的EZ-USB FX2系列接口芯片之一CY7C68013,為解決PC與FPGA的高速數據傳輸,利用芯片的SlaveFIFO主從模式將CIS傳感器采集的紙幣數據準確無損地傳給PC機,利用verilog HDL語言在FPGA中產生相應的控制信號,最終實現對數據的快速傳輸,在上位機得到CIS采集的清晰的紙幣畫面。

【關鍵詞】 FPGA CY7C68013 SlaveFIFO模式 USB 紙幣圖像數據

一、引言

USB全稱為通用串行總線,是一種作為外圍設備與計算機之間通信的標準接口,具有可熱插拔、即插即用、快速、雙向、以及價格低廉等特性,獲得了越來越多用戶的接受。本文使用支持USB2.0協議的CY7C68013接口芯片,作為FPGA與PC之間的傳輸接口。

二、系統總設計

本文利用FPGA芯片作為系統的邏輯控制核心,控制CIS傳感器采集紙幣數據,并通過A/D將數字信號最終存入SDRAM。USB接口與上位機通信,只需將SDRAM中的數據通過USB傳輸到上位機顯示。整體設計如圖1所示:

2.1 USB枚舉過程

當集線器端口懸空時,被電阻下拉,當設備插入到集線器時,接了上拉電阻那條數據線的電壓對集線器來說,是一個高電平信號,集線器檢測到此狀態后,報告給USB主控制器,此時便檢測到設備。USB的枚舉過程是主機獲取USB設備信息的過程。

(1)USB主機檢測到有設備插入后對其復位,使用缺省地址發送獲取設備描述符的標準請求,主機獲取到一個數據包的設備描述符并確認無誤后,開始進入設置地址階段。(2)USB主機向缺省地址發送設置地址的請求,設備受到該請求后,直接進入到等待主機輸入令牌包,主機確認收到后發送ACK,設備收到ACK之后開始啟用新地址。以后主機就通過這個唯一的地址訪問該設備。(3)主機使用新地址再次獲取配置描述符。枚舉完成。

2.2 USB批量傳輸

本文設備和主機的數據傳輸采用批量傳輸,批量傳輸由建立包、數據包、握手包構成事務。用在數據量大,對數據的實時性要求不高的場合。傳輸過程如圖2所示:

2.3 系統硬件結構

本文采用了USB的slaveFIFO模式,利用FPGA產生CY7C68013的控制信號。USB與FPGA的接口信號FLAGB、FLAGC用來指示FIFO的空滿狀態,SLOE、SLRD、SLWR信號分別為輸出使能信號、讀寫控制信號,FIFOADD[1:0]的4個位用于選擇芯片內部的4個緩沖區之一。FD[15:0]為雙向數據端口。

三、軟件設計

系統的軟件設計包括三部分:FPGA控制器的verilog程序,USB的固件程序、上位機的控制程序。

3.1 同步SlaveFIFO寫的狀態機如下

IDLE:空閑,此時寫事件如果發生,轉入狀態1;

狀態1:觸發FIFOADD[1:0]指向IN FIFO,轉向狀態2;

狀態2:如果FIFO滿,則保持本狀態,否則轉向狀態3;

狀態3:驅動數據到總線上,觸發SLWR有效,轉向狀態4;

狀態4:若還有數據寫,則轉向狀態2,否則轉向IDLE;

3.2 USB的固件程序

USB固件是運行在CY7C68013芯片中的代碼,只有將固件程序完整的下載入芯片中,芯片才可以被外圍信號控制。SlaveFIFO模式中,USB內嵌的8051固件的功能只是配置SlaveFIFO相關的寄存器以及控制USB何時工作在SlaveFIFO模式下。一旦8051固件將相關的寄存器配置完畢,FPGA即可按照SlaveFIFO的傳輸時序,高速的與主機進行通訊,而在通訊過程中不需要固件的參與。在固件程序中,TD_Init函數只會在USB啟動后調用一次。在這個函數里添加自己的初始化代碼,也就是傳輸數據前要處理的,例如USB工作模式、CPU時鐘頻率、端點選擇、端點傳輸方向、FIFO大小配置等。TD_Poll函數就是用戶調度程序,USB會在空閑的時候反復調用該函數,所以我們把自己需要反復執行的代碼放在這里。本文在初始化函數TD_Poll中,改動的部分如下:

Void TD_Init(void)

{...

IFCONFIG = 0x03;// 設置外部時鐘源、同步傳輸、slave fifo模式

EP2CFG = 0xE2;//2端點IN、批量傳輸、512字節雙緩沖

EP6CFG = 0xE2;//2端點IN、批量傳輸、512字節雙緩沖

AUTOPTRSETUP |= 0x01 //使用自動指針,使用自動指針

....

}

3.3 上位機應用程序設計

上位機應用程序的作用就是提供一個人機交互的顯示界面,體現系統的運行狀態。這里采用MicrosoftVisual C++ 6.0 進行上位機應用程序的設計,程序中采用CYAPI 控制函數類。CyAPI 控制函數類為EZ-USB FX2LP系列USB接口芯片提供了十分精細的控制接口。在使用Cypress 公司提供的驅動程序基礎上,只需在主機程序中加入頭文件CyAPI.h 和庫文件CyAPI.lib 即可調用相應的控制函數。

四、測試結果

主機與設備之間通過USB的數據傳輸,實現對SDRAM中紙幣數據的上位機圖像顯示。顯示如圖3所示:

五、結束語

本文主要利用USB與FPGA的通信進行紙幣數據采集的驗證,能高速的將CIS采集的數據在上位機上進行顯示,便于觀察與調試。USB通信與其他串口擴展技術相比具有較大的優越性。其設置比較靈活,應用受限制少,在各種分布式控制領域部有推廣使用的價值。

主站蜘蛛池模板: 久久精品娱乐亚洲领先| 91色在线视频| 欧美精品另类| 中国一级特黄大片在线观看| 色哟哟国产精品一区二区| 91精品国产麻豆国产自产在线| 国产资源免费观看| 欧美精品啪啪| а∨天堂一区中文字幕| 日本亚洲国产一区二区三区| 精品人妻AV区| 亚洲成年人片| 国产91熟女高潮一区二区| 无码人中文字幕| 亚洲国产成人无码AV在线影院L| 国产精品极品美女自在线| 国产成人福利在线| 另类欧美日韩| 亚洲免费福利视频| 国产精品99一区不卡| 精品国产污污免费网站| 91久久夜色精品国产网站| 国产精品无码一区二区桃花视频| 在线播放国产99re| 中文字幕永久在线观看| 国产综合精品一区二区| 亚洲av无码专区久久蜜芽| 亚洲一区二区三区香蕉| 亚洲αv毛片| 国产av一码二码三码无码| 久久久久久午夜精品| 国产精品永久久久久| 日韩在线2020专区| 国产无码在线调教| 国产99欧美精品久久精品久久 | 999国内精品视频免费| 亚洲欧美日本国产专区一区| 亚洲欧美自拍一区| 亚洲AV人人澡人人双人| 午夜天堂视频| 三上悠亚一区二区| 91麻豆精品视频| 四虎国产精品永久在线网址| 中国精品久久| 亚洲国产日韩在线观看| 青青青草国产| 午夜国产理论| 国产91av在线| 国产大全韩国亚洲一区二区三区| 国产精品免费p区| 无码国内精品人妻少妇蜜桃视频| 久久国产香蕉| a级毛片免费网站| 91久久精品日日躁夜夜躁欧美| 欧美亚洲另类在线观看| 成年女人a毛片免费视频| 国产第一页免费浮力影院| 国产av色站网站| 久久久久人妻一区精品色奶水| 中文字幕 欧美日韩| 亚洲国产欧洲精品路线久久| 特级做a爰片毛片免费69| 99re在线免费视频| 亚洲狠狠婷婷综合久久久久| 免费视频在线2021入口| 欧美国产日韩在线| 欧美中文字幕第一页线路一| 国产全黄a一级毛片| 国产原创第一页在线观看| 欧美日韩精品在线播放| 在线看片中文字幕| 亚洲国产精品日韩欧美一区| 国产幂在线无码精品| 成年人国产视频| 精品国产美女福到在线直播| 国产色婷婷| 欧美h在线观看| 美女国内精品自产拍在线播放| 欧美精品1区| 国产午夜看片| 亚洲国产天堂久久综合| 高清无码一本到东京热|