基于SOPC技術(shù)的異步串行通信IP核的設(shè)計(jì)與實(shí)現(xiàn)
摘要:介紹了SoPC(System on a Programmable Chip)系統(tǒng)的概念和特點(diǎn),給出了基于PLB總線的異步串行通信(UART)IP核的硬件設(shè)計(jì)和實(shí)現(xiàn)。通過(guò)將設(shè)計(jì)好的UART IP核集成到SoPC系統(tǒng)中加以驗(yàn)證,證明了所設(shè)計(jì)的UARTIP核可以正常工作。該設(shè)計(jì)方案為其他基于SoPC系統(tǒng)IP核的開(kāi)發(fā)提供了一定的參考。
關(guān)鍵詞:SoPC;UKRT;PLB;IPIF;FPGA
隨著嵌入式技術(shù)的發(fā)展,基于SoPC技術(shù)的嵌入式系統(tǒng)所具有的軟硬件可裁減、可擴(kuò)充、可升級(jí)以及可在線修改的特點(diǎn)越來(lái)越受到人們的重視。SoPC系統(tǒng)通常具有以下基本特征:采用大容量可編程邏輯器件來(lái)實(shí)現(xiàn),單芯片、低功耗;至少包含1個(gè)以上的嵌入式處理器IP核;具有一個(gè)或多條片上總線作為系統(tǒng)擴(kuò)展功能的接口;具有充足的片上可編程邏輯資源,用戶可以根據(jù)需要擴(kuò)充功能部件。
異步串行通信協(xié)議(UART)以低成本、高可靠性等優(yōu)點(diǎn)而廣泛應(yīng)用于嵌入式系統(tǒng)中,多篇文獻(xiàn)也討論了UART協(xié)議的硬件設(shè)計(jì)方法,但多數(shù)只限于討論UART協(xié)議的硬件實(shí)現(xiàn),缺少?gòu)腟oPC系統(tǒng)的角度論述UART IP核的設(shè)計(jì)方法。本文以UART IP核和PLB總線為例,討論了在SoPC系統(tǒng)下UART IP核的設(shè)計(jì)方法,該方法對(duì)其他IP核的設(shè)計(jì)有一定的參考作用。
1 UART協(xié)議介紹
UART是一種串行異步通信方式,它采用RS232電平在串行鏈路上進(jìn)行全雙工的通信,其數(shù)據(jù)傳輸格式如圖1所示:UART協(xié)議在空閑時(shí)為高電平,通過(guò)發(fā)送起始位提示接收方數(shù)據(jù)傳輸即將開(kāi)始,接著傳輸8位有效數(shù)據(jù)位和奇偶檢驗(yàn)位,最后發(fā)送停止位表示一個(gè)字符傳輸完成。
2 SOPC UART通信系統(tǒng)介紹
本文設(shè)計(jì)的SOPC UART通信系統(tǒng)主要包括MicroBlaze處理器、PLB總線、UART IP核和DDR2控制器IP核,如圖2所示。
MicroBlaze處理器是Xilinx公司針對(duì)其FPGA器件優(yōu)化的32位微處理器核,它采用RISC(Reduced Instruction System Computer)架構(gòu)和哈佛總線結(jié)構(gòu),具有獨(dú)立32位數(shù)據(jù)和指令總線,能夠高速執(zhí)行和訪問(wèn)片上存儲(chǔ)器和片外存儲(chǔ)器上的程序與數(shù)據(jù);提供本地塊存儲(chǔ)器總線(LMB)、處理器本地總線(PLB)等總線接口。
PLB總線作為IBM CoreConnect總線協(xié)議簇中的一部分,廣泛的應(yīng)用于IBM PowerPC處理器架構(gòu)中。該總線具有總線地址空間大,總線吞吐率高,能支持多個(gè)主從設(shè)備連接等特點(diǎn)。如圖3所示,MicroBlaze處理器通過(guò)PLB總線與UARTIP核、DDR2控制器相互連接,各部件之間通過(guò)PLB總線協(xié)議進(jìn)行交互。其中,MicroBlaze處理器作為主設(shè)備完成系統(tǒng)控制和UART通信流程控制,UART IP核作為從設(shè)備在主設(shè)備的控制下完成異步串行通信,DDR2存儲(chǔ)指令和數(shù)據(jù)。
MicroBlaze處理器和DDR2控制器采用Xilinx公司提供的IP核,UART IP核由用戶編寫邏輯,它是文中設(shè)計(jì)的主要內(nèi)容,對(duì)此模塊的設(shè)計(jì)將在下一節(jié)進(jìn)行詳細(xì)闡述。
3 UART IP核設(shè)計(jì)
3.1 PLB Slave Single模塊介紹
如上,UABT IP核作為PLB總線的從設(shè)備,必須提供PLB總線接口。但由于PLB總線協(xié)議復(fù)雜,實(shí)現(xiàn)其接口難度較大,Xilinx公司為了使用戶編寫的邏輯能夠方便的連結(jié)到PLB總線上,提供了一種PLB總線與用戶邏輯之間的接口模塊(IPIF,IP Interface),利用它簡(jiǎn)化了PLB總線接口信號(hào)、總線協(xié)議和其他接口相關(guān)問(wèn)題。IPIF接口邏輯中最簡(jiǎn)單的模塊稱為PLB Slave Single模塊,它提供了一種輕量級(jí)的PLB總線接口,為PLB總線主設(shè)備提供了解析從設(shè)備地址空間,讀寫從設(shè)備寄存器/存儲(chǔ)空間等基本服務(wù)。本文設(shè)計(jì)的UARTIP核與MicroBlaze處理器之間僅通過(guò)寄存器的讀寫進(jìn)行交互,PLB Slave Single模塊很好的滿足了該設(shè)計(jì)要求,因此采用PLB Slave Single模塊與UART邏輯共同構(gòu)成了UART IP核。PLB Slave Single模塊與UART邏輯之間的連接關(guān)系如圖3所示,接口信號(hào)說(shuō)明如表1所示。
在系統(tǒng)中,UART IP核的內(nèi)部寄存器組映射為處理器的某段地址空間,MicroBlaze處理器通過(guò)對(duì)該段地址的讀寫實(shí)現(xiàn)對(duì)UART IP核的訪問(wèn)。當(dāng)MicroBlaze處理器訪問(wèn)UART IP核的某個(gè)寄存器時(shí),PLB總線會(huì)產(chǎn)生相應(yīng)的地址信號(hào)和讀寫信號(hào),該信號(hào)被UART IP核中的PLB Slave Single模塊解析并生成相應(yīng)的IPIF信號(hào),UART IP核中的UABT邏輯響應(yīng)該IPIF信號(hào),完成寄存器的讀寫。
3.2 UART IP核寄存器組設(shè)計(jì)
文中設(shè)計(jì)的UART IP核提供了5個(gè)寄存器,如表2所示。其中發(fā)送寄存器和讀接收寄存器完成UART數(shù)據(jù)的發(fā)送和接收。狀態(tài)寄存器提供了UART IP核內(nèi)部狀態(tài),包括接收數(shù)據(jù)有效,發(fā)送FIFO滿,接收FIFO滿,奇偶校驗(yàn)錯(cuò)等狀態(tài)??刂萍拇嫫魈峁┝薝ART IP核復(fù)位功能。配置寄存器提供了波特率設(shè)置,奇偶校驗(yàn)位設(shè)置等功能。
3. 3 UART協(xié)議邏輯模塊設(shè)計(jì)
本文設(shè)計(jì)的UART協(xié)議邏輯模塊主要包括波特率產(chǎn)生模塊,發(fā)送模塊,接收模塊,寄存器組等幾個(gè)部分,其結(jié)構(gòu)如圖4所示。寄存器組說(shuō)明如表2,其他幾個(gè)模塊的設(shè)計(jì)如圖4所示。
3. 3.1 波特率模塊
波特率模塊根據(jù)PLB總線提供的時(shí)鐘產(chǎn)生需要的發(fā)送時(shí)鐘和接收時(shí)鐘。由于UABT在發(fā)送數(shù)據(jù)時(shí)只需要按照發(fā)送波特率將數(shù)據(jù)串行地發(fā)出就可以了,因此發(fā)送時(shí)鐘就等于發(fā)送波特率。而當(dāng)UART在接收數(shù)據(jù)時(shí),需要對(duì)串行數(shù)據(jù)進(jìn)行采樣以判斷接收數(shù)據(jù)。由于接收方和發(fā)送方的時(shí)鐘不可能完全同步,所以需要對(duì)每一位接收數(shù)據(jù)持續(xù)電平的時(shí)間進(jìn)行分段。分段越多,接收出現(xiàn)誤判的概率就越低,但系統(tǒng)開(kāi)銷也越大。在實(shí)際的設(shè)計(jì)中通常采用發(fā)送時(shí)鐘的16倍作為接收時(shí)鐘。波特率模塊的分頻功能由兩個(gè)16位計(jì)數(shù)器實(shí)現(xiàn),它將PLB總線時(shí)鐘按配置寄存器的設(shè)定進(jìn)行分頻,產(chǎn)生發(fā)送時(shí)鐘和接收時(shí)鐘。
3.3.2 發(fā)送模塊
發(fā)送模塊主要包括發(fā)送FIFO和發(fā)送單元兩部分,如圖5(a)所示。發(fā)送FIFO數(shù)據(jù)位寬度為8bit,深度為16字節(jié)。發(fā)送FIFO緩存MicroBlaze處理器需要發(fā)送的數(shù)據(jù)。當(dāng)FIFO空間滿時(shí),發(fā)送模塊將狀態(tài)寄存器中“發(fā)送FIFO滿”標(biāo)志位置1,MicroBlaze處理器通過(guò)查詢?cè)撐灰耘袛郩ART IP核是否可以接收下一個(gè)發(fā)送數(shù)據(jù)。
發(fā)送單元的設(shè)計(jì)用有限狀態(tài)機(jī)的方法實(shí)現(xiàn),其狀態(tài)轉(zhuǎn)換圖如圖5(b)所示。系統(tǒng)在復(fù)位后,發(fā)送單元處于空閑狀態(tài)。當(dāng)FIFO有發(fā)送數(shù)據(jù)時(shí)(Empty管腳為低),發(fā)送單元發(fā)出讀FIFO操作,并進(jìn)入數(shù)據(jù)準(zhǔn)備狀態(tài)。當(dāng)數(shù)據(jù)從FIFO中讀出,發(fā)送單元首先發(fā)送起始位,進(jìn)入發(fā)送狀態(tài)。在發(fā)送狀態(tài)下,發(fā)送單元依次串行發(fā)送8比特?cái)?shù)據(jù),并計(jì)算當(dāng)前的奇偶校驗(yàn)碼。在數(shù)據(jù)發(fā)送結(jié)束后,若配置寄存器中奇偶校驗(yàn)位為1,則發(fā)送奇偶校驗(yàn)位。最后發(fā)送單元發(fā)送停止位,回到空閑狀態(tài),完成次數(shù)據(jù)發(fā)送。
3.3.3 接收模塊
接收模塊由接收FIFO和接收單元兩部分組成,如圖6(a)所示。接收FIFO數(shù)據(jù)位寬度為8bit,深度16字節(jié),它負(fù)責(zé)緩存接收單元收到的數(shù)據(jù),并在收到數(shù)據(jù)后將狀態(tài)寄存器中“接收數(shù)據(jù)有效”標(biāo)志位置1。MicroBlaze處理器通過(guò)查詢?cè)撐粊?lái)判斷是否有數(shù)據(jù)到達(dá)。
接收單元的設(shè)計(jì)同樣采用了有限狀態(tài)機(jī)的方法,其狀態(tài)轉(zhuǎn)換圖如圖6(b)所示。系統(tǒng)在復(fù)位后接收單元處于就緒狀態(tài)。當(dāng)接收單元在接收管腳連續(xù)檢測(cè)到8個(gè)低電平時(shí)認(rèn)為起始位有效,進(jìn)入接收狀態(tài)。在接收狀態(tài)下,接收單元每16個(gè)接收時(shí)鐘采集一次接收數(shù)據(jù)。8個(gè)接收數(shù)據(jù)都采集完成后,接收單元根據(jù)配置寄存器中“奇偶校驗(yàn)位”是否為1決定是否進(jìn)行奇偶校驗(yàn)。若奇偶校驗(yàn)通過(guò),接收單元將接收到的數(shù)據(jù)寫入接收FIFO。若奇偶校驗(yàn)未通過(guò)接收FIFO滿,接收單元丟棄收到的數(shù)據(jù),并在狀態(tài)寄存器中置“奇偶校驗(yàn)出錯(cuò)”位或“接收FIFO滿”位為1。
4 實(shí)驗(yàn)驗(yàn)證
4. 1 系統(tǒng)硬件介紹
本文采用Xilinx公司提供的ML505 V5 FPGA Demo板作為SoPC系統(tǒng)硬件平臺(tái)。ML505 FPGA演示驗(yàn)證板主要由一塊Virtex-5 XC5VLX50T FPGA構(gòu)成,此外還包括RAM、Flash、以太網(wǎng)接口芯片、USB接口芯片以及ADM3202 RS-232電平轉(zhuǎn)換芯片等外圍擴(kuò)展芯片,其中ADM3202電路原理圖如圖7所示。
實(shí)驗(yàn)采用Xilinx公司ISE工具完成UART IP核的邏輯綜合和仿真,仿真波形如圖8所示,發(fā)送數(shù)據(jù)為0x01。
UART IP核仿真通過(guò)后,用EDK工具提供的Peripheral Import Wizard生成一個(gè)采用PLB Slave Single模塊的自定義IP核框架。在該IP核目錄下的user_logic.v文件中例化波特率模塊、發(fā)送模塊、接收模塊和寄存器組,并增加相應(yīng)總線訪同邏輯后即生成了本文設(shè)計(jì)的UART IP核。
用EDK工具中的Base System Builder wizard新建一個(gè)如圖3所示的SoPC系統(tǒng),如圖9所示。在Port界面下將UART IP核的收發(fā)管腳定義為External,并在UCF文件中加入收發(fā)管腳的管腳映射描述。在Address界面下生成UART IP核的地址空間,UART通信測(cè)試程序?qū)⑼ㄟ^(guò)該地址空間訪問(wèn)UART IP核。用EDK工具中Hardware菜單下Generate Bit Stream命令生成該SoPC系統(tǒng)的FPGA配置文件。用該配置文件配置ML505板載FPGA后,即生成了SoPC UART通信系統(tǒng)硬件。
用EDK工具中的Xilinx SDK軟件開(kāi)發(fā)工具編寫相應(yīng)的UART通信測(cè)試程序,編譯后將程序下載至MicroBlaze處理器程序空間。將ML505板串口與PC機(jī)串口連接后運(yùn)行UART通信測(cè)試程序,在PC機(jī)上可以觀察到此UART通信系統(tǒng)可以正確的發(fā)送和接收UART數(shù)據(jù),證明了該UART IP核工作正常。
5 結(jié)論
文中詳細(xì)介紹了一種基于SoPC概念的UART IP核的設(shè)計(jì)。通過(guò)將Xilinx公司提供的PLB Slave Single模塊和本文設(shè)計(jì)的UART邏輯模塊結(jié)合,快速搭建了一個(gè)滿足PLB總線接口要求的UART IP核,仿真與綜合結(jié)果表明該UART IP核各項(xiàng)功能均達(dá)到預(yù)期要求。該設(shè)計(jì)方法既采用了成熟的商業(yè)IP核,也利用總線接口模塊將用戶自定義IP核與商業(yè)IP核連接成為一個(gè)完整的SoPC系統(tǒng)。該方法增加了系統(tǒng)的靈活性、擴(kuò)展性,同時(shí)縮短了系統(tǒng)開(kāi)發(fā)時(shí)間,降低了系統(tǒng)開(kāi)發(fā)難度,可為其他嵌入式系統(tǒng)的開(kāi)發(fā)提供有益的參考。