• 
    

    
    

      99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

      利用FPGA來實現(xiàn)UART的設(shè)計

      2014-08-30 20:03:52招展明
      無線互聯(lián)科技 2014年8期
      關(guān)鍵詞:發(fā)送器接口通信

      招展明

      摘 要:計算機通信有串行和并行通信。串行通信雖然使設(shè)備之間的連線很少,但會帶來串/并轉(zhuǎn)換和位計數(shù)等問題,這使串行通信技術(shù)比并行通信技術(shù)更為復(fù)雜。串/并轉(zhuǎn)換既可用軟件實現(xiàn),也可用硬件來實現(xiàn)。

      關(guān)鍵詞:接口;發(fā)送器;接收器;通信

      1 總體設(shè)計

      整個設(shè)計包括兩部分:基于FPGA的UART的設(shè)計和基于VB6.0的上位機程序設(shè)計。UART的設(shè)計采用模塊化的設(shè)計思想,可分為3個模塊:FPGA數(shù)據(jù)發(fā)送模塊、數(shù)據(jù)接收模塊以及波特率發(fā)生器控制模塊。上位機程序采用VB6.0的Mscomm控件,可分為畫面設(shè)計和功能設(shè)計兩部分。串口采用標(biāo)準(zhǔn)的RS-232協(xié)議,主要參數(shù)選擇為:波特率9600bit/s,8位有效位,無奇偶校驗位,1位停止位。

      2 UART的結(jié)構(gòu)和幀格式

      UART主要包括接收器和發(fā)送器。從異步接收輸入信號SIN接收到的異步信號通過接收器完成串行/并行的轉(zhuǎn)換,形成異步數(shù)據(jù)幀;發(fā)送器將CPU發(fā)出的8位數(shù)據(jù)進行并行/串行轉(zhuǎn)換,從SOUT發(fā)送出去。功能包括微處理器接口、TBR(發(fā)送緩沖器)、TSR(發(fā)送移位寄存器)、幀產(chǎn)生、并轉(zhuǎn)串、RBR(接收緩沖器)、RSR(接收移位寄存器)、幀產(chǎn)生、串轉(zhuǎn)并。

      3 UART的設(shè)計與實現(xiàn)

      下面分別給出UART的3個模塊(發(fā)送器、接收器和波特率產(chǎn)生器)的方框圖。

      3.1 發(fā)送器

      UART串行發(fā)送器模塊框圖如圖2所示。DIN為8位數(shù)據(jù),其余為1位。

      從圖1的框圖可以看出,串行發(fā)送器中包含有一個8位THR(發(fā)送保持寄存器)和TSR(發(fā)送移位寄存)。復(fù)位時,引腳TRE為高電平,當(dāng)數(shù)據(jù)載入到TSR之后,引腳TRE變?yōu)榈碗娖?。發(fā)送完畢,TRE變?yōu)楦唠娖?。?dāng)偵測到輸入WRN變?yōu)榈碗娖綍r,自動使能串行數(shù)據(jù)發(fā)送過程。首先傳送1位的起始位(邏輯電平0),同時THR中的數(shù)據(jù)自動地并行載入到TSR中。然后,定長的數(shù)據(jù)位從TSR中移出,接著是校驗位。最后,產(chǎn)生停止位(邏輯電平1),標(biāo)志著一幀的結(jié)束。串行數(shù)據(jù)幀將以內(nèi)部時鐘頻率的1/16傳送。如果THR中內(nèi)容不空,當(dāng)一個串行數(shù)據(jù)幀傳送結(jié)束后,緊接著發(fā)送下一個數(shù)據(jù)幀。這種自動的流程使得數(shù)據(jù)幀以背靠背的方式發(fā)送,提高了數(shù)據(jù)傳輸?shù)膸挕.?dāng)沒有數(shù)據(jù)發(fā)送時,SDO引腳保持高電平。

      發(fā)送器每隔16個時鐘周期輸出1位,順序遵循1位起始位、8位數(shù)據(jù)位(假定數(shù)據(jù)位為8位)、1位校驗位(可選)、1位停止位。

      3.2 接收器

      UART串行接收器模塊框圖如圖2所示。DOUT為8位數(shù)據(jù),其余為1位。接收器包含一個8位RBR和RSR。RBR的狀態(tài)可以通過引腳DATA_READY米表示。當(dāng)RBR中的數(shù)據(jù)有效時,DATA_READY變?yōu)楦唠娖?,向CPU表明可以取同數(shù)據(jù)。

      本設(shè)計只要求實現(xiàn)簡單的收發(fā)功能,故未設(shè)計檢錯程序,程序在偵測到起始位后,計16個時鐘周期,便開始接收數(shù)據(jù),移位輸入RSR,最后輸出數(shù)據(jù)DOUT。還要輸出一個數(shù)據(jù)接收標(biāo)志信號標(biāo)志數(shù)據(jù)接收完。

      串行輸入RXD為0010101101,每一位占16個時鐘周期,一旦檢測到輸入RXD為0,計數(shù)器開始計數(shù),開始接收數(shù)據(jù),接收完畢,標(biāo)志位變?yōu)楦唠娖健?/p>

      3.3 波特率發(fā)生器

      UART的接收和發(fā)送是按照相同的波特率進行收發(fā)的。波特率發(fā)生器產(chǎn)生的時鐘頻率不是波特率時鐘頻率,而是波特率時鐘頻率的16倍,目的是為在接收時進行精確地采樣,以提出異步的串行數(shù)據(jù)。根據(jù)給定的晶振時鐘和要求的波特率算出波特率分頻數(shù)。

      4 上位機程序設(shè)計

      本文使用VB 6.0進行上位機程序的設(shè)計,實現(xiàn)PC與FPGA的串行通信。下面是1個上位機收發(fā)測試通信程序的設(shè)計過程,通過該程序可以與FPGA進行串行通信。波特率默認(rèn)值是“9600,N,8,1”,其意為所使用的通信端口是以9600 bit/s的速度傳輸,不作字符校驗,每次的數(shù)據(jù)是8位,而停止位是1位。波特率(單位為bit/s)可為110、300、600、1200、2400、9600、14400、19200、28800。校驗位為:E偶校驗,N無校驗,O奇校驗,S空白。正確的數(shù)據(jù)位值有:4、5、6、7、8(默認(rèn)值)。正確的停止位值有:1(默認(rèn)值)、1.5、2。

      將UART的程序編譯、仿真后,下載到FPGA的EPlK30TC144-3芯片上。引入20MHz的晶振頻率;發(fā)送使能端和復(fù)位端分別接一個開關(guān);狀態(tài)輸出標(biāo)志TRE和DATA-READTY分別接一個二極管,指示狀態(tài);設(shè)置波特率為“9800,N,8,1”。串行數(shù)據(jù)幀的格式為:起始位0,8位數(shù)據(jù)位,無校驗位,1位停止位。將UART的串行發(fā)送、接收端口分別與計算機的RS-232的串行接收、發(fā)送端口連接,以便與PC機進行串行通信;并行輸入DIN接入并行輸出DOUT;連好線后,執(zhí)行發(fā)送測試程序。

      5 結(jié)束語

      在實現(xiàn)FPGA與PC的串行通信中,將程序下載到芯片中驗證設(shè)計的正確性,通過串行通信,可以向FPGA發(fā)控制命令讓其執(zhí)行相應(yīng)的操作,同時把需要的數(shù)據(jù)通過串口發(fā)到PC上進行相應(yīng)的數(shù)據(jù)處理和分析,以此來判斷FPGA是否按設(shè)計要求工作。

      猜你喜歡
      發(fā)送器接口通信
      移頻發(fā)送器冗余切換設(shè)計研究
      用于獲取車輛中的旋轉(zhuǎn)構(gòu)件的旋轉(zhuǎn)角度的傳感器組件
      傳感器世界(2017年4期)2017-03-23 10:50:49
      某電站工程設(shè)計管理與施工、質(zhì)量控制接口關(guān)系研究
      脫硝數(shù)據(jù)傳輸系統(tǒng)遠(yuǎn)程無線監(jiān)控技術(shù)的研發(fā)與應(yīng)用
      中文信息(2016年10期)2016-12-12 12:56:55
      西門子SPPA—T3000在委內(nèi)瑞拉燃機電廠中的應(yīng)用與接口
      中國市場(2016年32期)2016-12-06 11:16:14
      簡述計算機通信網(wǎng)絡(luò)安全與防護策略
      Android環(huán)境下主UI線程與子線程通信機制研究
      無線自組網(wǎng)在野戰(zhàn)防空通信系統(tǒng)中的應(yīng)用
      對數(shù)字微波通信技術(shù)的研究
      中俄網(wǎng)絡(luò)語言編碼接口問題的研究
      科技視界(2016年3期)2016-02-26 10:14:32
      禄劝| 文水县| 喀喇沁旗| 民和| 望江县| 疏勒县| 道孚县| 长春市| 汉中市| 蒙阴县| 江都市| 轮台县| 昌邑市| 本溪| 宜城市| 卢龙县| 崇州市| 陵川县| 天门市| 读书| 通化市| 哈巴河县| 铜陵市| 嘉鱼县| 克山县| 万盛区| 克拉玛依市| 高平市| 云龙县| 武清区| 孙吴县| 浙江省| 临泉县| 连平县| 秦安县| 哈密市| 贵德县| 江津市| 襄城县| 高安市| 浙江省|