FPGA的UART設(shè)計(jì)與實(shí)現(xiàn)_第1頁
FPGA的UART設(shè)計(jì)與實(shí)現(xiàn)_第2頁
FPGA的UART設(shè)計(jì)與實(shí)現(xiàn)_第3頁
FPGA的UART設(shè)計(jì)與實(shí)現(xiàn)_第4頁
FPGA的UART設(shè)計(jì)與實(shí)現(xiàn)_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、【W(wǎng)ord版本下載可任意編輯】 FPGA的UART設(shè)計(jì)與實(shí)現(xiàn) 0 引言 通用異步收發(fā)器(Universal Asynchronous ReceiverTransmitter,UART)可以和各種標(biāo)準(zhǔn)串行接口,如RS 232和RS 485等開展全雙工異步通信,具有傳輸距離遠(yuǎn)、成本低、可靠性高等優(yōu)點(diǎn)。一般UART由專用芯片如8250,16450來實(shí)現(xiàn),但專用芯片引腳都較多,內(nèi)含許多輔助功能,在實(shí)際使用時(shí)往往只需要用到UART的基本功能,使用專用芯片會(huì)造成資源浪費(fèi)和成本提高。 一般而言UART和外界通信只需要兩條信號(hào)線RXD和TXD,其中RXD是UART的接收端,TXD是UART的發(fā)送端,接收與發(fā)送

2、是全雙工形式。由于可編程邏輯器件技術(shù)的快速發(fā)展,F(xiàn)PGA的功能日益強(qiáng)大,其開發(fā)周期短、可重復(fù)編程的優(yōu)點(diǎn)也越來越明顯,在FPGA芯片上集成UART功能模塊并和其他模塊組合可以很方便地實(shí)現(xiàn)一個(gè)能與其他設(shè)備開展串行通信的片上系統(tǒng)。 1 UART功能設(shè)計(jì) 1.1 UART的工作原理 異步通信時(shí),UART發(fā)送接收數(shù)據(jù)的傳輸格式如圖1所示,一個(gè)字符單位由開始位、數(shù)據(jù)位、停止位組成。 異步通信的一幀傳輸經(jīng)歷以下步驟: (1)無傳輸。發(fā)送方連續(xù)發(fā)送信號(hào),處于信息“1”狀態(tài)。 (2)起始傳輸。發(fā)送方在任何時(shí)刻將傳號(hào)變成空號(hào),即“1”跳變到“O”,并持續(xù)1位時(shí)間說明發(fā)送方開始傳輸數(shù)據(jù)。而同時(shí),接收方收到空號(hào)后,開

3、始與發(fā)送方同步,并期望收到隨后的數(shù)據(jù)。 (3)奇偶傳輸。數(shù)據(jù)傳輸之后是可供選擇的奇偶位發(fā)送或接收。 (4)停止傳輸。是發(fā)送或接收的停止位,其狀態(tài)恒為“1”。 發(fā)送或接收一個(gè)完整的字節(jié)信息,首先是一個(gè)作為起始位的邏輯“0”位,接著是8個(gè)數(shù)據(jù)位,然后是停止位邏輯“1”位,數(shù)據(jù)線空閑時(shí)為高或“1”狀態(tài)。起始位和停止位的作用是使接收器能把局部時(shí)鐘與每個(gè)新開始接收的字符再同步。異步通信沒有可參照的時(shí)鐘信號(hào),發(fā)送器可以隨時(shí)發(fā)送數(shù)據(jù),任何時(shí)刻串行數(shù)據(jù)到來時(shí),接收器必須準(zhǔn)確地發(fā)現(xiàn)起始位下降沿的出現(xiàn)時(shí)間,從而正確采樣數(shù)據(jù)。 設(shè)計(jì)時(shí)可參考由專用芯片實(shí)現(xiàn)的UART的功能并開展一定精簡(jiǎn),如可以用FPGA的片內(nèi)RAM替

4、代UART的FIFO,不用單獨(dú)在UART模塊中實(shí)現(xiàn)。設(shè)計(jì)的基本原則是保存主要的功能,基于FPGA的UART系統(tǒng)由波特率時(shí)鐘發(fā)生器、接收器和發(fā)送器3個(gè)子模塊組成,如圖2所示。 1.2 接收器設(shè)計(jì) 比較而言,UART發(fā)送器的設(shè)計(jì)相對(duì)容易,只要每隔一個(gè)發(fā)送周期并按照數(shù)據(jù)幀格式輸出數(shù)據(jù)即可,本文將對(duì)接收器的設(shè)計(jì)和實(shí)現(xiàn)做詳細(xì)說明,發(fā)送器的設(shè)計(jì)方法基本相同。 接收器的工作過程如下,在接收數(shù)據(jù)存放器被讀出一幀數(shù)據(jù)或系統(tǒng)開始工作以后,接收進(jìn)程被啟動(dòng)。接收進(jìn)程啟動(dòng)之后,檢測(cè)起始位,檢測(cè)到有效起始位后,以約定波特率的時(shí)鐘開始接收數(shù)據(jù),根據(jù)數(shù)據(jù)位數(shù)的約定,計(jì)數(shù)器統(tǒng)計(jì)接收位數(shù)。一幀數(shù)據(jù)接收完畢之后,如果使用了奇偶校驗(yàn)

5、,則檢測(cè)校驗(yàn)位,如無誤則接收停止位。停止位接收完畢后,將接收數(shù)據(jù)轉(zhuǎn)存到數(shù)據(jù)存放器中。 為確保接收器可靠工作,在接收端開始接收數(shù)據(jù)位之前,處于搜索狀態(tài),這時(shí)接收端以16倍波特率的速率讀取線路狀態(tài),檢測(cè)線路上出現(xiàn)低電平的時(shí)刻。因?yàn)楫惒絺鬏數(shù)奶攸c(diǎn)是以起始位為基準(zhǔn)同步的。然而,通信線上的噪音也極有可能使傳號(hào)“1”跳變到空號(hào)“0”。所以接收器以16倍的波特率對(duì)這種跳變開展檢測(cè),直至在連續(xù)8個(gè)接收時(shí)鐘以后采樣值仍然是低電平,才認(rèn)為是一個(gè)真正的起始位,而不是噪音引起的,其中若有采樣得到的為高電平則認(rèn)為起始信號(hào)無效,返回初始狀態(tài)重新等待起始信號(hào)的到來。找到起始位以后,就開始接收數(shù)據(jù),可靠的接收應(yīng)該是接收時(shí)鐘的

6、出現(xiàn)時(shí)刻正好對(duì)著數(shù)據(jù)位的中央。由于在起始位檢測(cè)時(shí),已使時(shí)鐘對(duì)準(zhǔn)了位中央,用16倍波特率的時(shí)鐘作為接收時(shí)鐘,就是為了確保在位寬的中心時(shí)間對(duì)接收的位序列開展可靠采樣,當(dāng)采樣計(jì)數(shù)器計(jì)數(shù)結(jié)束后所有數(shù)據(jù)位都已經(jīng)輸入完成。對(duì)停止位的高電平開展檢測(cè),若正確檢測(cè)到高電平,說明本幀的各位正確接收完畢,將數(shù)據(jù)轉(zhuǎn)存到數(shù)據(jù)存放器中,否則出錯(cuò)。 采用有限狀態(tài)機(jī)模型可以更清晰明確地描述接收器的功能,便于代碼實(shí)現(xiàn)。接收器的狀態(tài)轉(zhuǎn)換圖如圖3所示,為突出主要過程,圖中省略了奇偶校驗(yàn)的情況。接收器狀態(tài)機(jī)由5個(gè)工作狀態(tài)組成,分別是空閑狀態(tài)、起始位確認(rèn)、采樣數(shù)據(jù)位、停止位確認(rèn)和數(shù)據(jù)正確,觸發(fā)狀態(tài)轉(zhuǎn)換的事件和在各個(gè)狀態(tài)執(zhí)行的動(dòng)作見圖中

7、的文字說明。 在狀態(tài)機(jī)模型的根底上,使用VHDL來描述接收器功能,其主要代碼如下: 實(shí)現(xiàn)用16倍波特率時(shí)鐘確定起始位的具體方法是設(shè)計(jì)兩個(gè)輸入數(shù)據(jù)位存放器rxd1和rxd2,使用語句“rxd1=rxd;rxd2=rxd1;”接收數(shù)據(jù)并開展判斷。當(dāng)檢測(cè)到rxdl=O并且rxd2=1時(shí)可以確定下降沿發(fā)生,連續(xù)7個(gè)時(shí)鐘rxd2=0即確定檢測(cè)到起始位,之后為了確保在數(shù)據(jù)位中央接收數(shù)據(jù),同樣用16倍波特率時(shí)鐘對(duì)數(shù)據(jù)位開展采樣。接收數(shù)據(jù)的方法是設(shè)計(jì)一個(gè)存放器rxd_buf(7 downto 0),用語句“rxd_buf(7)=rxd2;rxd_buf(6 DOWNTO 0)=rxd_buf(7 DOWNTO

8、 1);”實(shí)現(xiàn)移位存放器右移操作,執(zhí)行8次后接收到一個(gè)完整數(shù)據(jù)。 1.3 波特率發(fā)生器設(shè)計(jì) 波特率發(fā)生器實(shí)質(zhì)是設(shè)計(jì)一個(gè)分頻器,用于產(chǎn)生和RS 232通信同步的時(shí)鐘。在系統(tǒng)中用一個(gè)計(jì)數(shù)器來完成這個(gè)功能,分頻系數(shù)N決定了波特率的數(shù)值。該計(jì)數(shù)器一般工作在一個(gè)頻率較高的系統(tǒng)時(shí)鐘下,當(dāng)計(jì)數(shù)到N2時(shí)將輸出置為高電平,再計(jì)數(shù)到N2的數(shù)值后將輸出置為低電平,如此反復(fù)即可得到占空比50的波特率時(shí)鐘,具體的波特率依賴于所使用的系統(tǒng)時(shí)鐘頻率和N的大小。如系統(tǒng)時(shí)鐘頻率是40 MHz,要求波特率是9 600,則16倍波特率時(shí)鐘的周期約等于260個(gè)系統(tǒng)時(shí)鐘周期,則計(jì)數(shù)器取2602=130時(shí),當(dāng)計(jì)數(shù)溢出時(shí)輸出電平取反就可以

9、得到16倍約定波特率的時(shí)鐘。 使用VHDL來描述波特率發(fā)生器的完整代碼如下: 2 數(shù)據(jù)傳輸測(cè)試 隨著邏輯設(shè)計(jì)復(fù)雜性的不斷增加,僅依賴于軟件方式的仿真測(cè)試來了解系統(tǒng)的硬件功能有很多的局限性,應(yīng)用Quartus集成開發(fā)環(huán)境中提供的SignalTap嵌入式邏輯分析儀,可以將測(cè)試信息隨設(shè)計(jì)文件于目標(biāo)芯片中,用以捕獲目標(biāo)芯片內(nèi)部系統(tǒng)信號(hào)節(jié)點(diǎn)處的信息或總線上的數(shù)據(jù)流,而又不影響原硬件系統(tǒng)的正常工作。測(cè)試信息通過器件的JTAG端口傳出,并送入計(jì)算機(jī)開展顯示和分析,這是一種高效的硬件測(cè)試手段,并很好地結(jié)合了傳統(tǒng)的系統(tǒng)測(cè)試方法。 本設(shè)計(jì)在Altera Cyclone系列的EPlC6Q240C8芯片上開展了驗(yàn)證,

10、使用Quarltus軟件將編譯好的.pof格式文件以AS模式到配置芯片EPCS1中。在計(jì)算機(jī)端運(yùn)行串口調(diào)試助手軟件,將數(shù)據(jù)從計(jì)算機(jī)送出,并利用FPGA上的UART模塊開展接收,將發(fā)送數(shù)據(jù)與SignalTap獲取的波形開展比照,經(jīng)多次測(cè)試說明收發(fā)數(shù)據(jù)完全相同。 以其中的測(cè)試為例開展說明,從PC上輸入ASCII碼的“6”,設(shè)定波特率發(fā)生器時(shí)鐘作為SignalTap的采樣時(shí)鐘,采樣波形如圖4所示,其中“recstart”表示開始接收數(shù)據(jù)幀標(biāo)志;“divl6”表示16倍波特率時(shí)鐘;“cnt_rxd”表示數(shù)據(jù)位采樣計(jì)數(shù)器,完整的采樣計(jì)數(shù)從Oh9h共10次采樣(1個(gè)起始位,8個(gè)數(shù)據(jù)位,1個(gè)停止位);“rx

11、d”表示串口的接收端;“rxd_buf”表示移位存放器,當(dāng)數(shù)據(jù)停止位確認(rèn)后,移位存放器輸出收到的數(shù)據(jù)“36h”,說明了該UART工作穩(wěn)定可靠。 應(yīng)特別注意的是當(dāng)利用SignalTap開展測(cè)試工作結(jié)束后,在生成終產(chǎn)品前,應(yīng)將SignalTap從芯片中除去,以免占用額外的資源,然后再重新編譯。全程編譯后消耗邏輯單元142個(gè),只占芯片總資源的2,沒有占用芯片的存儲(chǔ)單元和PLL單元,對(duì)于一個(gè)中大規(guī)模的FPGA芯片而言這是非常少的資源消耗。 3 結(jié)語 基于FPGA設(shè)計(jì)和實(shí)現(xiàn)UART,可以用片上很少的邏輯單元實(shí)現(xiàn)UART的基本功能。與傳統(tǒng)設(shè)計(jì)相比,能有效減少系統(tǒng)的PCB面積,降低系統(tǒng)的功耗,提高設(shè)計(jì)的穩(wěn)定性和可靠性,并可

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(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)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論