《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > 基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)
基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)
摘要: 基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)[圖],摘要:為實(shí)現(xiàn)智能儀器的遠(yuǎn)程控制,提高控制系統(tǒng)的速度,采用現(xiàn)場(chǎng)可編程門陣列(FPGA)芯片、USB芯片
關(guān)鍵詞: FPGA 智能儀器 遠(yuǎn)程控制
Abstract:
Key words :
 

摘要:為實(shí)現(xiàn)智能儀器遠(yuǎn)程控制,提高控制系統(tǒng)的速度,采用現(xiàn)場(chǎng)可編程門陣列(FPGA)芯片、USB芯片等實(shí)現(xiàn)了智能儀器遠(yuǎn)程控制系統(tǒng)的設(shè)計(jì)。重點(diǎn)介紹RS232與USB的接口轉(zhuǎn)換原理及FPGA程序設(shè)計(jì)和仿真。系統(tǒng)采用先入先出存儲(chǔ)器和有限狀態(tài)機(jī)實(shí)現(xiàn)了RS232與USB的接口轉(zhuǎn)換,并實(shí)現(xiàn)上位機(jī)的控制、數(shù)據(jù)處理等功能。系統(tǒng)可大大減少上位機(jī)的工作量,不僅可以用于實(shí)驗(yàn)室也可應(yīng)用在工業(yè)生產(chǎn)中。

目前智能儀器已廣泛應(yīng)用于科研和工業(yè)生產(chǎn)當(dāng)中,但是許多儀器分散在不同的地理位置上,不易操作和維護(hù),并且實(shí)時(shí)跟蹤性能差,人為誤差大,數(shù)據(jù)無(wú)法保存,另外大量高檔儀表價(jià)格相當(dāng)昂貴。為解決上述難題,在計(jì)算機(jī)的提示下完成操作,可以減少人為因素造成的損壞,并提高測(cè)試數(shù)據(jù)的準(zhǔn)確度。由于智能儀器是RS232接口,上位機(jī)用的是USB接口,所以還需由FPGA實(shí)現(xiàn)RS232與USB之間的接口轉(zhuǎn)換。由于FPGA可以并行處理,集成度高,可用資源豐富,所以利用FPGA進(jìn)行數(shù)據(jù)處理,可以減少上位機(jī)的工作量,減少數(shù)據(jù)處理的時(shí)間,還可以縮短設(shè)計(jì)周期,減小板卡體積,以便于集成到其他板卡上。

1 控制系統(tǒng)及接口簡(jiǎn)介

1.1 系統(tǒng)功能

在整個(gè)系統(tǒng)中,上位機(jī)可以實(shí)時(shí)對(duì)系統(tǒng)進(jìn)行監(jiān)控,并下發(fā)相應(yīng)的命令。智能儀器傳出的數(shù)據(jù)通過(guò)RS232接口傳送到FPGA,F(xiàn)PGA根據(jù)上位機(jī)下發(fā)的命令對(duì)這些數(shù)據(jù)進(jìn)行判決、處理,然后經(jīng)過(guò)USB接口上傳給上位機(jī),再由上位機(jī)對(duì)FPGA處理過(guò)的數(shù)據(jù)進(jìn)行顯示、存儲(chǔ)等操作。

1.2 USB接口芯片簡(jiǎn)介

本設(shè)計(jì)采用的是CYPRESS半導(dǎo)體公司的EZUSBFX2系列芯片CY7C68013。CY7C68013是一款高性能USB 2.0微控制器,它提供了全面的USB 2.0外圍設(shè)備解決方案。工作模式有Port,Slave FIFO和GPIFMaster三種,本方案采用Slave FIFO模式。在該模式下,外部控制器(如FPGA)可像對(duì)普通FIFO一樣對(duì)FX2中端點(diǎn)為2,4,6,8的數(shù)據(jù)緩沖區(qū)進(jìn)行讀/寫。FX2內(nèi)嵌的8051固件的功能只是配置Slave FIFO相關(guān)的寄存器,以及控制FX2何時(shí)工作在Slave FIFO模式下。一旦8051固件將相關(guān)的寄存器配置完畢,且使自身工作在Slave FIFO模式下后,外部邏輯(如FPGA)即可按照Slave FIFO的傳輸時(shí)序,高速地與主機(jī)進(jìn)行通信,而在通信過(guò)程中不需要8051固件的參與。

1.3 RS232接口簡(jiǎn)介

RS232C標(biāo)準(zhǔn)(協(xié)議)的全稱是EIARS232C標(biāo)準(zhǔn)。EIARS232C是用正負(fù)電壓來(lái)表示邏輯狀態(tài)的,與TTL以高低電平表示邏輯狀態(tài)的規(guī)定不同。因此,為了能夠與計(jì)算機(jī)接口或終端的TTL器件連接,必須使EIARS232C與TTL電路之間進(jìn)行電平和邏輯關(guān)系的變換。實(shí)現(xiàn)這種變換的方法可用分立元件,也可用集成電路芯片。該設(shè)計(jì)用的是MAX3232芯片。

RS232的數(shù)據(jù)傳輸格式如圖1所示。

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖1 RS232標(biāo)準(zhǔn)的數(shù)據(jù)傳輸格式

RS232傳輸格式包含起始位(1b)、有效數(shù)據(jù)位(8b)、奇偶校驗(yàn)位(0~2b)、停止位(1b)。傳輸線在空閑時(shí)為高電平,因此起始位為低電平,停止位為高電平。

奇偶校驗(yàn)位可設(shè)置為奇校驗(yàn)、偶校驗(yàn)或不校驗(yàn),有效數(shù)據(jù)位是從低位開始傳送。

2 FPGA設(shè)計(jì)

2.1 USB接口時(shí)序

在Slav e FIFO方式下,外部邏輯與FX2的連接信號(hào)如圖2所示。

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖2 FX2 Slave模式下接口管腳連接圖

在Slav e FIFO模式下,CY7C68013芯片為端口2,4,6,8 提供滿空標(biāo)志位FLAGA,F(xiàn)LAGB,F(xiàn)LAGC,F(xiàn)LAGD。IFCLK為FX2輸出的時(shí)鐘,可作通信的同步時(shí)鐘;SLCS為FIFO的片選信號(hào);SLOE為FIFO輸出使能;SLRD為FIFO讀信號(hào);SLWR為FIFO寫信號(hào)。對(duì)FPGA來(lái)說(shuō),4個(gè)端口分別為4個(gè)FIFO。

FPGA檢測(cè)4個(gè)滿空標(biāo)志位來(lái)分別對(duì)相應(yīng)的FIFO進(jìn)行讀/寫。FPGA可以選擇同步或異步讀/寫,在該設(shè)計(jì)中采用異步讀/寫。在異步Slave FIFO寫時(shí),時(shí)鐘由FPGA提供。數(shù)據(jù)在SLWR的每個(gè)有效-無(wú)效的跳變沿時(shí)被寫入,F(xiàn)IFO寫指針遞增。異步Slave FIFO讀時(shí),F(xiàn)IFO讀指針在SLRD的每個(gè)有效-無(wú)效的跳變沿時(shí)遞增以改變數(shù)據(jù)。

2.2 FPGA程序設(shè)計(jì)

FPGA設(shè)計(jì)是整個(gè)系統(tǒng)的核心部分,由VHDL語(yǔ)言實(shí)現(xiàn)。FPGA實(shí)現(xiàn)了USB與RS232接口的轉(zhuǎn)換、數(shù)據(jù)的處理、命令的傳輸?shù)裙δ堋S辛松厦娴慕涌跁r(shí)序,便可以進(jìn)行FPGA設(shè)計(jì)。FPGA部分的總體設(shè)計(jì)如圖3所示。模塊介紹:

USB與FPGA接口模塊:USB與FPGA之間的接口轉(zhuǎn)換模塊,主要功能為將USB接口傳過(guò)來(lái)的信息緩存到FPGA內(nèi)部FIFO,并將由數(shù)據(jù)處理模塊處理過(guò)的數(shù)據(jù)傳給USB芯片。即產(chǎn)生控制信號(hào)讀/寫USB芯片內(nèi)部FIFO。可以由讀/寫FIFO兩個(gè)有限狀態(tài)機(jī)實(shí)現(xiàn)。

以讀取CY7C68013芯片內(nèi)數(shù)據(jù)為例,根據(jù)異步讀USB內(nèi)的FIFO時(shí)序圖可分為4個(gè)狀態(tài):空閑態(tài)、選擇地址態(tài)、準(zhǔn)備讀數(shù)據(jù)態(tài)、讀數(shù)據(jù)態(tài)、讀取后狀態(tài)[6] 。在空閑態(tài),當(dāng)讀事件發(fā)生時(shí)進(jìn)入選擇地址態(tài);在選擇地址態(tài),使FIFOADR[1: 0] 指向OUT FIFO,進(jìn)入準(zhǔn)備讀數(shù)據(jù)態(tài);在準(zhǔn)備讀數(shù)據(jù)態(tài),如FIFO空,在本狀態(tài)等待,否則進(jìn)入讀數(shù)據(jù)態(tài);在讀數(shù)據(jù)態(tài),使SLOE,SLRD有效,從數(shù)據(jù)線上讀數(shù),再使SLRD無(wú)效,以遞增FIFO讀指針,再使SLOE無(wú)效,進(jìn)入讀取后狀態(tài);在讀取后狀態(tài),如需傳輸更多的數(shù),進(jìn)入準(zhǔn)備讀數(shù)據(jù)態(tài),否則進(jìn)入空閑態(tài)。

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖3 FPGA總體設(shè)計(jì)框圖

USB數(shù)據(jù)緩存模塊:用來(lái)緩存計(jì)算機(jī)發(fā)給智能儀器的指令等信息。是由FPGA芯片的IP核生成的先入先出存儲(chǔ)器FIFO。容量為8b*512depth。占用1個(gè)塊RAM資源。

RS232數(shù)據(jù)緩存模塊:用來(lái)緩存由智能儀器發(fā)出的數(shù)據(jù)。是由FPGA IP核生成的先入先出存儲(chǔ)器FIFO。容量為8b*512depth,占用1個(gè)塊RAM資源。

RS232與FPGA接口模塊:RS232與FPGA之間的接口轉(zhuǎn)換模塊。主要功能為進(jìn)行串/并和并/串轉(zhuǎn)換。

將USB數(shù)據(jù)緩存模塊中緩存的內(nèi)容以合適的速率通過(guò)串口發(fā)給智能儀器,并將智能儀器發(fā)出的數(shù)據(jù)緩存到RS232數(shù)據(jù)緩存模塊中。此模塊也是由兩個(gè)狀態(tài)機(jī)實(shí)現(xiàn)。串口通信必須要設(shè)定波特率,這里采用的波特率為9600Kb/s,采用的時(shí)鐘為50MHz,相當(dāng)于傳送1位數(shù)據(jù)需要約5028個(gè)時(shí)鐘周期,這里采用減法計(jì)數(shù)器來(lái)控制,即計(jì)數(shù)器計(jì)到5028個(gè)時(shí)鐘周期后,就開始傳輸下一位數(shù)據(jù)。

數(shù)據(jù)處理模塊:主要功能為根據(jù)上位機(jī)的指令對(duì)RS232數(shù)據(jù)緩存中的數(shù)據(jù)做出相應(yīng)的處理。處理后再向上位機(jī)傳。主要的處理方式有定時(shí)取數(shù)、平滑處理等。實(shí)現(xiàn)方式由狀態(tài)機(jī)等實(shí)現(xiàn)。FPGA頂層模塊:主要負(fù)責(zé)各模塊間數(shù)據(jù)流的流向。以及與外部芯片相連的輸入輸出信號(hào)的定義。

系統(tǒng)在工作時(shí),在采集數(shù)據(jù)上傳上位機(jī)時(shí),數(shù)據(jù)通道為:智能儀器發(fā)送的數(shù)據(jù)通過(guò)RS232接口模塊存在RS232數(shù)據(jù)緩存模塊中緩存。當(dāng)緩存到一定的數(shù)據(jù)量后,再通過(guò)數(shù)據(jù)處理模塊連續(xù)的讀取FIFO中的數(shù)據(jù)并根據(jù)上位機(jī)發(fā)送的命令進(jìn)行相應(yīng)的數(shù)據(jù)處理,然后將處理的數(shù)據(jù)通過(guò)USB與FPGA接口模塊傳給USB接口。在上位機(jī)下發(fā)控制命令時(shí),數(shù)據(jù)通道為:上位機(jī)發(fā)送的命令通過(guò)USB口傳給FPGA的RS232與FPGA接口模塊,此模塊判斷是數(shù)據(jù)處理指令還是控制儀器指令。如果是數(shù)據(jù)處理指令,則傳向數(shù)據(jù)處理模塊讓其按要求進(jìn)行數(shù)據(jù)處理。如果是控制儀器指令,則將其存入U(xiǎn)SB數(shù)據(jù)緩存模塊中,再由RS232與FPGA接口模塊讀取,轉(zhuǎn)成RS2322格式后傳出。由于RS232接口速度比USB接口慢,用FPGA內(nèi)部的異步時(shí)鐘FIFO解決速率匹配問(wèn)題。

將通過(guò)RS232傳過(guò)來(lái)的數(shù)據(jù)緩存在FIFO中,然后存到一定數(shù)據(jù)量后再全部連續(xù)的取出,如此往復(fù),從而實(shí)現(xiàn)數(shù)據(jù)的連續(xù)采集及上位機(jī)的實(shí)時(shí)顯示。將通過(guò)USB傳過(guò)來(lái)的數(shù)據(jù)放在另一個(gè)FIFO中緩存,讓FPGA按照RS232的速率進(jìn)行讀取。這樣可以防止RS232的速度跟不上USB的速度而產(chǎn)生的數(shù)據(jù)丟失。

3 仿真結(jié)果

FPGA采用的系統(tǒng)時(shí)鐘頻率為50MHz,仿真工具為Modelsim SE 6.5a,仿真用數(shù)據(jù)為連續(xù)的8b數(shù)據(jù)。

仿真結(jié)果如圖4所示。

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖4 FPGA讀USB內(nèi)部FIFO仿真圖

圖4為FPGA讀USB內(nèi)部FIFO的仿真結(jié)果,DATA為模擬從USB口接到的數(shù)據(jù),該數(shù)據(jù)已存在于USB芯片的FIFO中。FIFO DATA為FPGA接到的數(shù)據(jù),由上可以看出,F(xiàn)PGA可以將USB接受到的數(shù)據(jù)解析出來(lái)。

圖5為RS232與FPGA接口部分仿真結(jié)果。可以看出,由RS232接收串行數(shù)據(jù)RXD已經(jīng)轉(zhuǎn)換為并行數(shù)據(jù)din。程序中是在一個(gè)有效字節(jié)結(jié)束后將其存入FIFO中,由圖可以驗(yàn)證。圖6頂層模塊仿真圖,為了驗(yàn)證由FPGA發(fā)出的數(shù)據(jù)能正確的接受到,先由FPGA內(nèi)部發(fā)數(shù)據(jù),然后通過(guò)RS232的TXD端口發(fā)出,讓RXD與TXD相連再接收,可以看出發(fā)出的數(shù)據(jù)可以被正確的接收回來(lái)并傳向USB接口,說(shuō)明時(shí)序正確。

同理可以驗(yàn)證USB端的收發(fā)時(shí)序。

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖5 RS232接收端仿真圖

基于FPGA的智能儀器遠(yuǎn)程控制系統(tǒng)設(shè)計(jì)
圖6 頂層模塊仿真圖

4 結(jié) 語(yǔ)

本文采用FPGA實(shí)現(xiàn)了USB與RS232間的接口轉(zhuǎn)換及數(shù)據(jù)處理的功能。設(shè)計(jì)中先入先出存儲(chǔ)器的運(yùn)用解決了數(shù)據(jù)的緩存的和速率匹配問(wèn)題,有限狀態(tài)機(jī)的運(yùn)用使得程序設(shè)計(jì)更加清晰可靠。該設(shè)計(jì)將復(fù)雜的信號(hào)運(yùn)算集中在FPGA中完成,利用FPGA獨(dú)特的并行處理能力,減小上位機(jī)工作量的同時(shí),提高了系統(tǒng)運(yùn)行速度。

作者:謝燕平 郭靜 延鳳平 北京交通大學(xué)光波技術(shù)研究所   來(lái)源:《現(xiàn)代電子技術(shù)》2011年第4期

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久国产精品高清| 欧美日本在线一区| 亚洲图片欧美午夜| 亚洲麻豆一区| 亚洲国产精品一区二区www| 亚洲欧美综合精品久久成人| 一区二区三区产品免费精品久久75| 亚洲国产日韩精品| 亚洲国产小视频在线观看| 国内久久精品| 激情综合色丁香一区二区| 国产日韩av高清| 国产欧美激情| 国产性猛交xxxx免费看久久| 国产欧美不卡| 国内自拍亚洲| 樱桃视频在线观看一区| 伊人精品久久久久7777| 在线精品国精品国产尤物884a| 韩日午夜在线资源一区二区| 黄色成人在线| 在线观看国产精品淫| 在线日本成人| 亚洲精品免费一区二区三区| 91久久在线观看| 亚洲美女在线看| 亚洲午夜精品久久久久久app| 亚洲视频视频在线| 午夜精品久久久久久| 欧美一区二区三区四区在线观看地址| 欧美一区二区网站| 亚洲第一精品在线| 亚洲日本黄色| 亚洲一区在线播放| 欧美一区二区黄色| 久久久久久久综合日本| 男女激情视频一区| 欧美日韩成人精品| 国产精品久久一卡二卡| 国产欧美一区二区三区视频| 国产一区二区三区在线观看免费视频 | 欧美黄色aaaa| 国产精品电影在线观看| 国产日韩精品一区观看| 一区视频在线播放| 日韩午夜在线视频| 亚洲一区中文| 亚洲狠狠丁香婷婷综合久久久| 日韩午夜三级在线| 亚洲欧美激情诱惑| 久久最新视频| 欧美色欧美亚洲另类二区| 国产美女高潮久久白浆| 亚洲成色www8888| 中国av一区| 久久精品国亚洲| 一区二区三区精密机械公司| 欧美在线观看一二区| 欧美成人精品一区二区| 国产精品高潮呻吟| 激情视频一区二区| 正在播放亚洲| 亚洲经典一区| 欧美亚洲免费电影| 欧美h视频在线| 国产精品青草综合久久久久99| 韩日视频一区| 亚洲一区bb| 亚洲美女诱惑| 久久成人国产| 欧美日韩高清一区| 国产自产2019最新不卡| 一本综合精品| 亚洲三级色网| 久久精品国产99国产精品| 欧美精品一二三| 精品成人一区二区| 亚洲欧美综合另类中字| 一本大道久久a久久精品综合| 久久亚洲精品欧美| 国产精品日韩欧美一区| 亚洲国产另类久久精品| 亚洲欧美伊人| 亚洲一区3d动漫同人无遮挡| 免费在线成人av| 国产亚洲精品久久久久婷婷瑜伽| 99这里有精品| 亚洲精品社区| 久久综合狠狠| 国产区精品在线观看| 99国产一区| 99视频一区二区| 美女精品在线观看| 国产精品最新自拍| 一区二区三区免费网站| 亚洲精品在线免费观看视频| 久久中文在线| 国产欧美一区二区精品性| 一本色道久久综合亚洲精品婷婷 | 91久久在线| 久久久久久午夜| 国产日韩欧美日韩大片| 亚洲午夜精品网| 亚洲先锋成人| 欧美日韩一区精品| 日韩视频在线免费| 夜夜嗨av一区二区三区网站四季av | 在线观看日韩精品| 欧美怡红院视频| 欧美一区二区高清在线观看| 国产精品video| 一本色道久久综合精品竹菊| 一区二区免费看| 欧美精品激情blacked18| 亚洲电影网站| 亚洲人成人77777线观看| 久久综合久久久久88| 精品成人乱色一区二区| 亚洲第一天堂av| 鲁大师成人一区二区三区| 狠狠入ady亚洲精品| 久久av资源网站| 久久综合精品国产一区二区三区| 国产主播一区二区| 亚洲电影第三页| 女同性一区二区三区人了人一| 一区在线播放视频| 亚洲欧洲在线观看| 欧美精品一区二区在线播放| 亚洲人成人99网站| aa日韩免费精品视频一| 欧美日韩伦理在线免费| 一本久久青青| 性久久久久久| 国产一区二区三区四区五区美女| 久久精品国产精品亚洲综合| 狂野欧美性猛交xxxx巴西| 亚洲电影下载| 中文一区二区| 国产精品美女久久久久aⅴ国产馆| 亚洲一级黄色av| 久久久久久久久久久一区| 激情综合色综合久久| 亚洲看片一区| 欧美性猛交xxxx免费看久久久| 亚洲一区二区三区中文字幕| 久久精品国产99| 亚洲高清毛片| 亚洲视频一二区| 国产日产亚洲精品系列| 亚洲国产专区校园欧美| 欧美日韩精品免费观看视频完整| 一区二区三区导航| 久久gogo国模啪啪人体图| 一色屋精品亚洲香蕉网站| 99riav1国产精品视频| 国产精品美女| 亚洲国产精品一区二区第四页av| 欧美国产一区二区| 亚洲香蕉伊综合在人在线视看| 久久久久久久久久久久久女国产乱| 在线观看精品| 亚洲尤物影院| 国产综合香蕉五月婷在线| 亚洲美洲欧洲综合国产一区| 国产精品ⅴa在线观看h| 欧美在线啊v一区| 欧美精品123区| 午夜激情一区| 欧美精品久久久久久久免费观看| 一本色道久久综合| 久久人人爽人人爽爽久久| 亚洲精选国产| 久久久久久久91| 99re6热在线精品视频播放速度| 欧美影视一区| 亚洲狠狠婷婷| 欧美在线中文字幕| 亚洲精品自在在线观看| 久久精品一区蜜桃臀影院| 日韩视频在线观看| 久久综合网络一区二区| 中日韩视频在线观看| 美女成人午夜| 午夜精品理论片| 欧美日韩免费在线| 亚洲国产岛国毛片在线| 国产精品久久久久久亚洲调教| 亚洲国产一区二区a毛片| 国产精品成人一区二区网站软件 | 亚洲狼人精品一区二区三区| 国产女精品视频网站免费| 亚洲精品综合| 国内精品视频在线播放| 亚洲综合视频在线| 亚洲国产高清视频| 久久久青草婷婷精品综合日韩 | 国产精品视频久久| 日韩一本二本av| 一区精品在线|