


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、利用FPGA實(shí)現(xiàn)UART的設(shè)計(jì) 摘要:實(shí)現(xiàn)了一種全集成可變帶寬中頻寬帶低通濾波器,討論分析了跨導(dǎo)放大器-電容(OTAC)連續(xù)時(shí)間型濾波器的結(jié)構(gòu)、設(shè)計(jì)和具體實(shí)現(xiàn),使用外部可編程電路對(duì)所設(shè)計(jì)濾波器帶寬進(jìn)行控制,并利用ADS軟件進(jìn)行電路設(shè)計(jì)和仿真驗(yàn)證。仿真結(jié)果表明,該濾波器帶寬的可調(diào)范圍為126 MHz,阻帶抑制率大于35 dB,帶內(nèi)波紋小于05 dB,采用18 V電源,TSMC 018m CMOS工藝庫仿真,功耗小于21 mW,頻響曲線接近理想狀態(tài)。關(guān)鍵詞:Butte引 言隨著計(jì)算機(jī)技術(shù)的發(fā)展和廣泛應(yīng)用,尤其是在工業(yè)控制領(lǐng)域的應(yīng)用越來越廣泛,
2、計(jì)算機(jī)通信顯的尤為重要。串行通信雖然使設(shè)備之間的連線大為減少,但隨之帶來串并轉(zhuǎn)換和位計(jì)數(shù)等問題,這使串行通信技術(shù)比并行通信技術(shù)更為復(fù)雜。串并轉(zhuǎn)換可用軟件實(shí)現(xiàn),也可用硬件實(shí)現(xiàn)。用軟件實(shí)現(xiàn)串行傳送大多采用循環(huán)移位指令將一個(gè)字節(jié)由高位到低位(或低位到高位)一位一位依次傳送,這種方法雖然簡單但速度慢,而且大量占用CPU的時(shí)間,影響系統(tǒng)的性能。更為方便的實(shí)現(xiàn)方法是用硬件,目前微處理器串行接口常用的LSI 芯片是UART(通用異步收發(fā)器)、USART(通用同步異步收發(fā)器)和ACIA(異步通信接口適配器)等。不論是哪一種芯片,它們的一種基本功能是實(shí)現(xiàn)串并轉(zhuǎn)換。正是這些串行接口芯片彌補(bǔ)了串行通信較為復(fù)雜這一缺
3、陷。本文應(yīng)用EDA(電子設(shè)計(jì)自動(dòng)化)技術(shù),基于FPGA(現(xiàn)場可編程門陣列)CPLD(復(fù)雜可編程邏輯器件)設(shè)計(jì)與實(shí)現(xiàn)UART。1 總體設(shè)計(jì)整個(gè)設(shè)計(jì)包括兩部分:基于FPGA的UART的設(shè)計(jì)和基于VB6.0的上位機(jī)程序設(shè)計(jì)。UART的設(shè)計(jì)采用模塊化的設(shè)計(jì)思想,可分為3個(gè)模塊:FPGA數(shù)據(jù)發(fā)送模塊、FPGA波特率發(fā)生器控制模塊及數(shù)據(jù)接收模塊。上位機(jī)程序采用VB 6.0的Mscomm控件,可分為畫面設(shè)計(jì)和功能設(shè)計(jì)兩部分。串口采用標(biāo)準(zhǔn)的RS-232協(xié)議,主要參數(shù)選擇為:波特率9 600 bits,8位有效位,無奇偶校驗(yàn)位,1位停止位。2 UART的結(jié)構(gòu)和幀格式UART主要包括接收器和發(fā)送器。從異步接收輸入
4、信號(hào)SIN接收到的異步信號(hào)通過接收器完成串行并行的轉(zhuǎn)換,形成異步數(shù)據(jù)幀;發(fā)送器將CPU發(fā)出的8位數(shù)據(jù)進(jìn)行并行串行轉(zhuǎn)換,從SOUT發(fā)送出去。功能包括微處理器接口、TBR(發(fā)送緩沖器)、TSR(發(fā)送移位寄存器)、幀產(chǎn)生、并轉(zhuǎn)串、RBR(接收緩沖器)、RSR(接收移位寄存器)、幀產(chǎn)生、串轉(zhuǎn)并。UART的結(jié)構(gòu)如圖1所示。UART的幀格式包括線路空閑狀態(tài)(idle,高電平)、起始位(start bit,低電平)、5位8位數(shù)據(jù)位(da-ta bits)、校驗(yàn)位(parity bit,可選)和停止位(stop bit,位數(shù)可為1、1.5、2位)。這種格式是由起始位和停止位來實(shí)現(xiàn)字符的同步。UART內(nèi)部一般有
5、配置寄存器,可以配置數(shù)據(jù)位數(shù)(5位8位)、是否有校驗(yàn)位和校驗(yàn)的類型、停止位的位數(shù)(1,1.5,2位)等設(shè)置。3 UART的設(shè)計(jì)與實(shí)現(xiàn)UART是廣泛使用的串行數(shù)據(jù)傳輸協(xié)議。UART允許在串行鏈路上進(jìn)行全雙工的通信。串行外設(shè)使用RS-232-C異步串行接口,一般采用專用集成電路即UART實(shí)現(xiàn)。如8250、8251、NS16450等芯片都是常見的UART器件,這類芯片已經(jīng)相當(dāng)復(fù)雜,有的含有許多輔助的模塊(如FIFO),有時(shí)不需要使用完整的UART的功能和這些輔助功能,或者使用了FPGACPLD,那么就可以將所需要的UART功能集成到FPGA內(nèi)部。使用VHDL將UART的核心功能集成,從而使整個(gè)設(shè)計(jì)更
6、加緊湊、穩(wěn)定且可靠。下面分別設(shè)計(jì)UART的3個(gè)模塊(發(fā)送器、接收器和波特率產(chǎn)生器),并給出其仿真結(jié)果。3.1 發(fā)送器設(shè)計(jì)UART串行發(fā)送器模塊框圖如圖2所示。DIN為8位數(shù)據(jù),其余為1位。從圖2的框圖可以看出,串行發(fā)送器中包含有一個(gè)8位THR(發(fā)送保持寄存器)和TSR(發(fā)送移位寄存)。復(fù)位時(shí),引腳TRE為高電平。當(dāng)數(shù)據(jù)載入到TSR之后,引腳TRE變?yōu)榈碗娖?。發(fā)送完畢,TRE變?yōu)楦唠娖健.?dāng)偵測到輸入WRN變?yōu)榈碗娖綍r(shí),自動(dòng)使能串行數(shù)據(jù)發(fā)送過程。首先傳送1位的起始位(邏輯電平0),同時(shí)THR中的數(shù)據(jù)自動(dòng)地并行載入到TSR中。然后,定長的數(shù)據(jù)位從TSR中移出,接著是校驗(yàn)位。最后,產(chǎn)生停止位(邏輯電平
7、1),標(biāo)志著一幀的結(jié)束。串行數(shù)據(jù)幀將以內(nèi)部時(shí)鐘頻率的116傳送。如果THR中內(nèi)容不空,當(dāng)一個(gè)串行數(shù)據(jù)幀傳送結(jié)束后,緊接著發(fā)送下一個(gè)數(shù)據(jù)幀。這種自動(dòng)的流程使得數(shù)據(jù)幀以背靠背的方式發(fā)送,提高了數(shù)據(jù)傳輸?shù)膸挕.?dāng)沒有數(shù)據(jù)發(fā)送時(shí),SDO引腳保持高電平。發(fā)送器每隔16個(gè)時(shí)鐘周期輸出1位,順序遵循1位起始位、8位數(shù)據(jù)位(假定數(shù)據(jù)位為8位)、1位校驗(yàn)位(可選)、1位停止位。引入發(fā)送字符長度和發(fā)送次序計(jì)數(shù)器no_bits_sent,實(shí)現(xiàn)的部分VHDL程序如下:發(fā)送器功能仿真結(jié)果如圖3所示。并行輸入DIN十六進(jìn)制數(shù)56,WRN輸入由1變?yōu)?,肩動(dòng)發(fā)送程序,計(jì)數(shù)器開始計(jì)數(shù),串行輸出SDO為0010101101,發(fā)
8、送完畢,TRE變?yōu)楦唠娖健F鹗嘉?,8位數(shù)據(jù)位,1位停止位,證明了發(fā)送模塊的正確性。3.2 接收器設(shè)計(jì)UART串行接收器模塊框圖如圖4所示。DOUT為8位數(shù)據(jù),其余為1位。接收器包含一個(gè)8位RBR和RSR。RBR的狀態(tài)可以通過引腳DATA_READY米表示。當(dāng)RBR中的數(shù)據(jù)有效時(shí),DATA_READY變?yōu)楦唠娖剑駽PU表明可以取同數(shù)據(jù)。本設(shè)計(jì)只要求實(shí)現(xiàn)簡單的收發(fā)功能,故未設(shè)計(jì)檢錯(cuò)程序,程序在偵測到起始位后,計(jì)16個(gè)時(shí)鐘周期,便開始接收數(shù)據(jù),移位輸入RSR,最后輸出數(shù)據(jù)DOUT。還要輸出一個(gè)數(shù)據(jù)接收標(biāo)志信號(hào)標(biāo)志數(shù)據(jù)接收完。實(shí)現(xiàn)的部分VHDL程序如下:接受器功能仿真結(jié)果圖略。串行輸入RXD為00
9、10101101,每一位占16個(gè)時(shí)鐘周期,一旦檢測到輸入RXD為0,計(jì)數(shù)器開始計(jì)數(shù),開始接收數(shù)據(jù),接收完畢,標(biāo)志位變?yōu)楦唠娖健7抡娼Y(jié)果證明了接收模塊的正確性。3.3 波特率發(fā)生器的設(shè)計(jì)UART的接收和發(fā)送是按照相同的波特率進(jìn)行收發(fā)的。波特率發(fā)生器產(chǎn)生的時(shí)鐘頻率不是波特率時(shí)鐘頻率,而是波特率時(shí)鐘頻率的16倍,目的是為在接收時(shí)進(jìn)行精確地采樣,以提出異步的串行數(shù)據(jù)。根據(jù)給定的晶振時(shí)鐘和要求的波特率算出波特率分頻數(shù)。實(shí)現(xiàn)的部分VHDL程序如下:波特率功能仿真結(jié)果圖略。輸入頻率為20 MHz,波形周期為50 ns,20 MHz(9 600 bits×16 bit)=130,由仿真結(jié)果可知輸出波
10、形的半個(gè)周期為65倍的輸入時(shí)鐘周期,從而證明了波特率產(chǎn)生器模塊的正確性。4 上位機(jī)程序設(shè)計(jì)本文使用VB 6.0進(jìn)行上位機(jī)程序的設(shè)計(jì),實(shí)現(xiàn)PC與FPGA的串行通信。下面是1個(gè)上位機(jī)收發(fā)測試通信程序的設(shè)計(jì)過程,通過該程序可以與FPGA進(jìn)行串行通信。波特率默認(rèn)值是“9600,N,8,1”,其意為所使用的通信端口是以9 600 bits的速度傳輸,不作字符校驗(yàn),每次的數(shù)據(jù)是8位,而停止位是1位。波特率(單位為bits)可為110、300、600、1200、2400、9 600、14 400、19 200、28 800。校驗(yàn)位為:E偶校驗(yàn),N無校驗(yàn),O奇校驗(yàn),S空白。正確的數(shù)據(jù)位值有:4、5、6、7、8
11、(默認(rèn)值)。正確的停止位值有:1(默認(rèn)值)、15、2。將UART的程序編譯、仿真后,下載到FPGA的EPlK30TC144-3芯片上。引入20 MHz的晶振頻率;發(fā)送使能端和復(fù)位端分別接一個(gè)開關(guān);狀態(tài)輸出標(biāo)志TRE和DATA-READTY分別接一個(gè)二極管,指示狀態(tài);設(shè)置波特率為“9 800,N,8,1”。串行數(shù)據(jù)幀的格式為:起始位0,8位數(shù)據(jù)位,無校驗(yàn)位,1位停止位。將UART的串行發(fā)送、接收端口分別與計(jì)算機(jī)的RS-232的串行接收、發(fā)送端口連接,以便與PC機(jī)進(jìn)行串行通信;并行輸入DIN接入并行輸出DOUT;連好線后,執(zhí)行發(fā)送測試程序。5 結(jié)束語在實(shí)現(xiàn)FPGA與PC的串行通信中,將程序下載到芯片中驗(yàn)證設(shè)計(jì)的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 網(wǎng)絡(luò)游戲平臺(tái)用戶數(shù)據(jù)安全保護(hù)與隱私權(quán)保護(hù)協(xié)議
- 爆炸性物品抗震防震泡沫供應(yīng)合同
- 電子商務(wù)物流效率提升補(bǔ)充協(xié)議
- 游戲IP跨界合作:與知名品牌聯(lián)合舉辦活動(dòng)協(xié)議
- 智能自習(xí)室會(huì)員體系共建與資源共享合作協(xié)議
- 海外醫(yī)療信息存儲(chǔ)與租賃管理協(xié)議
- 繼子女撫養(yǎng)權(quán)解除與監(jiān)護(hù)權(quán)變更協(xié)議
- 《慢性病毒性心肌炎》課件
- 《OLED產(chǎn)業(yè)鏈概述》課件
- 《崗位分析的基礎(chǔ)技術(shù)與工具教學(xué)課件》
- 麻醉鎮(zhèn)靜藥與阿片類
- 調(diào)兵山市招聘社區(qū)工作者真題2024
- 2025-2030中國臘味行業(yè)發(fā)展趨勢及發(fā)展前景研究報(bào)告
- 2025-2030中國手機(jī)外殼行業(yè)市場發(fā)展現(xiàn)狀及競爭格局與投資前景研究報(bào)告
- 《中型餐飲企業(yè)組織結(jié)構(gòu)》課件
- 2025年浙江紹興諸暨新城投資開發(fā)集團(tuán)有限公司招聘筆試參考題庫含答案解析
- 安徽卓越縣中聯(lián)盟2024-2025學(xué)年高三下學(xué)期5月份檢測政治試卷+答案
- 初中美育考試試題及答案
- 2025年福建省福州市電子信息集團(tuán)有限公司招聘30人筆試參考題庫附帶答案詳解
- 國際貿(mào)易基礎(chǔ)試題庫與答案
- 2025年北京市豐臺(tái)區(qū)九年級(jí)初三一模語文試卷(含答案)
評(píng)論
0/150
提交評(píng)論