日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > EDA > 電子設(shè)計自動化
[導(dǎo)讀]隨著嵌入式技術(shù)的發(fā)展,基于SoPC技術(shù)的嵌入式系統(tǒng)所具有的軟硬件可裁減、可擴(kuò)充、可升級以及可在線修改的特點越來越受到人們的重視。SoPC系統(tǒng)通常具有以下基本特征:采用大容量可編程邏輯器件來實現(xiàn),單芯片、低功耗

隨著嵌入式技術(shù)的發(fā)展,基于SoPC技術(shù)的嵌入式系統(tǒng)所具有的軟硬件可裁減、可擴(kuò)充、可升級以及可在線修改的特點越來越受到人們的重視。SoPC系統(tǒng)通常具有以下基本特征:采用大容量可編程邏輯器件來實現(xiàn),單芯片、低功耗;至少包含1個以上的嵌入式處理器IP核;具有一個或多條片上總線作為系統(tǒng)擴(kuò)展功能的接口;具有充足的片上可編程邏輯資源,用戶可以根據(jù)需要擴(kuò)充功能部件。

異步串行通信協(xié)議(UART)以低成本、高可靠性等優(yōu)點而廣泛應(yīng)用于嵌入式系統(tǒng)中,多篇文獻(xiàn)也討論了UART協(xié)議的硬件設(shè)計方法,但多數(shù)只限于討論UART協(xié)議的硬件實現(xiàn),缺少從SoPC系統(tǒng)的角度論述UART IP核的設(shè)計方法。本文以UART IP核和PLB總線為例,討論了在SoPC系統(tǒng)下UART IP核的設(shè)計方法,該方法對其他IP核的設(shè)計有一定的參考作用。

1 UART協(xié)議介紹

UART是一種串行異步通信方式,它采用RS232電平在串行鏈路上進(jìn)行全雙工的通信,其數(shù)據(jù)傳輸格式如圖1所示:UART協(xié)議在空閑時為高電平,通過發(fā)送起始位提示接收方數(shù)據(jù)傳輸即將開始,接著傳輸8位有效數(shù)據(jù)位和奇偶檢驗位,最后發(fā)送停止位表示一個字符傳輸完成。

 

 

2 SOPC UART通信系統(tǒng)介紹

本文設(shè)計的SOPC UART通信系統(tǒng)主要包括MicroBlaze處理器、PLB總線、UART IP核和DDR2控制器IP核,如圖2所示。

 

 

MicroBlaze處理器是Xilinx公司針對其FPGA器件優(yōu)化的32位微處理器核,它采用RISC(Reduced Instruction System Computer)架構(gòu)和哈佛總線結(jié)構(gòu),具有獨立32位數(shù)據(jù)和指令總線,能夠高速執(zhí)行和訪問片上存儲器和片外存儲器上的程序與數(shù)據(jù);提供本地塊存儲器總線(LMB)、處理器本地總線(PLB)等總線接口。

PLB總線作為IBM CoreConnect總線協(xié)議簇中的一部分,廣泛的應(yīng)用于IBM PowerPC處理器架構(gòu)中。該總線具有總線地址空間大,總線吞吐率高,能支持多個主從設(shè)備連接等特點。如圖3所示,MicroBlaze處理器通過PLB總線與UARTIP核、DDR2控制器相互連接,各部件之間通過PLB總線協(xié)議進(jìn)行交互。其中,MicroBlaze處理器作為主設(shè)備完成系統(tǒng)控制和UART通信流程控制,UART IP核作為從設(shè)備在主設(shè)備的控制下完成異步串行通信,DDR2存儲指令和數(shù)據(jù)。

MicroBlaze處理器和DDR2控制器采用Xilinx公司提供的IP核,UART IP核由用戶編寫邏輯,它是文中設(shè)計的主要內(nèi)容,對此模塊的設(shè)計將在下一節(jié)進(jìn)行詳細(xì)闡述。

3 UART IP核設(shè)計

3.1 PLB Slave Single模塊介紹

如上,UABT IP核作為PLB總線的從設(shè)備,必須提供PLB總線接口。但由于PLB總線協(xié)議復(fù)雜,實現(xiàn)其接口難度較大,Xilinx公司為了使用戶編寫的邏輯能夠方便的連結(jié)到PLB總線上,提供了一種PLB總線與用戶邏輯之間的接口模塊(IPIF,IP Interface),利用它簡化了PLB總線接口信號、總線協(xié)議和其他接口相關(guān)問題。IPIF接口邏輯中最簡單的模塊稱為PLB Slave Single模塊,它提供了一種輕量級的PLB總線接口,為PLB總線主設(shè)備提供了解析從設(shè)備地址空間,讀寫從設(shè)備寄存器/存儲空間等基本服務(wù)。本文設(shè)計的UARTIP核與MicroBlaze處理器之間僅通過寄存器的讀寫進(jìn)行交互,PLB Slave Single模塊很好的滿足了該設(shè)計要求,因此采用PLB Slave Single模塊與UART邏輯共同構(gòu)成了UART IP核。PLB Slave Single模塊與UART邏輯之間的連接關(guān)系如圖3所示,接口信號說明如表1所示。

 

 

在系統(tǒng)中,UART IP核的內(nèi)部寄存器組映射為處理器的某段地址空間,MicroBlaze處理器通過對該段地址的讀寫實現(xiàn)對UART IP核的訪問。當(dāng)MicroBlaze處理器訪問UART IP核的某個寄存器時,PLB總線會產(chǎn)生相應(yīng)的地址信號和讀寫信號,該信號被UART IP核中的PLB Slave Single模塊解析并生成相應(yīng)的IPIF信號,UART IP核中的UABT邏輯響應(yīng)該IPIF信號,完成寄存器的讀寫。

3.2 UART IP核寄存器組設(shè)計

文中設(shè)計的UART IP核提供了5個寄存器,如表2所示。其中發(fā)送寄存器和讀接收寄存器完成UART數(shù)據(jù)的發(fā)送和接收。狀態(tài)寄存器提供了UART IP核內(nèi)部狀態(tài),包括接收數(shù)據(jù)有效,發(fā)送FIFO滿,接收FIFO滿,奇偶校驗錯等狀態(tài)??刂萍拇嫫魈峁┝薝ART IP核復(fù)位功能。配置寄存器提供了波特率設(shè)置,奇偶校驗位設(shè)置等功能。

 

 

3. 3 UART協(xié)議邏輯模塊設(shè)計

本文設(shè)計的UART協(xié)議邏輯模塊主要包括波特率產(chǎn)生模塊,發(fā)送模塊,接收模塊,寄存器組等幾個部分,其結(jié)構(gòu)如圖4所示。寄存器組說明如表2,其他幾個模塊的設(shè)計如圖4所示。

 

 

3. 3.1波特率模塊

波特率模塊根據(jù)PLB總線提供的時鐘產(chǎn)生需要的發(fā)送時鐘和接收時鐘。由于UABT在發(fā)送數(shù)據(jù)時只需要按照發(fā)送波特率將數(shù)據(jù)串行地發(fā)出就可以了,因此發(fā)送時鐘就等于發(fā)送波特率。而當(dāng)UART在接收數(shù)據(jù)時,需要對串行數(shù)據(jù)進(jìn)行采樣以判斷接收數(shù)據(jù)。由于接收方和發(fā)送方的時鐘不可能完全同步,所以需要對每一位接收數(shù)據(jù)持續(xù)電平的時間進(jìn)行分段。分段越多,接收出現(xiàn)誤判的概率就越低,但系統(tǒng)開銷也越大。在實際的設(shè)計中通常采用發(fā)送時鐘的16倍作為接收時鐘。波特率模塊的分頻功能由兩個16位計數(shù)器實現(xiàn),它將PLB總線時鐘按配置寄存器的設(shè)定進(jìn)行分頻,產(chǎn)生發(fā)送時鐘和接收時鐘。

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空間滿時,發(fā)送模塊將狀態(tài)寄存器中“發(fā)送FIFO滿”標(biāo)志位置1,MicroBlaze處理器通過查詢該位以判斷UART IP核是否可以接收下一個發(fā)送數(shù)據(jù)。

 

 

發(fā)送單元的設(shè)計用有限狀態(tài)機(jī)的方法實現(xiàn),其狀態(tài)轉(zhuǎn)換圖如圖5(b)所示。系統(tǒng)在復(fù)位后,發(fā)送單元處于空閑狀態(tài)。當(dāng)FIFO有發(fā)送數(shù)據(jù)時(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比特數(shù)據(jù),并計算當(dāng)前的奇偶校驗碼。在數(shù)據(jù)發(fā)送結(jié)束后,若配置寄存器中奇偶校驗位為1,則發(fā)送奇偶校驗位。最后發(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處理器通過查詢該位來判斷是否有數(shù)據(jù)到達(dá)。

 

 

接收單元的設(shè)計同樣采用了有限狀態(tài)機(jī)的方法,其狀態(tài)轉(zhuǎn)換圖如圖6(b)所示。系統(tǒng)在復(fù)位后接收單元處于就緒狀態(tài)。當(dāng)接收單元在接收管腳連續(xù)檢測到8個低電平時認(rèn)為起始位有效,進(jìn)入接收狀態(tài)。在接收狀態(tài)下,接收單元每16個接收時鐘采集一次接收數(shù)據(jù)。8個接收數(shù)據(jù)都采集完成后,接收單元根據(jù)配置寄存器中“奇偶校驗位”是否為1決定是否進(jìn)行奇偶校驗。若奇偶校驗通過,接收單元將接收到的數(shù)據(jù)寫入接收FIFO.若奇偶校驗未通過接收FIFO滿,接收單元丟棄收到的數(shù)據(jù),并在狀態(tài)寄存器中置“奇偶校驗出錯”位或“接收FIFO滿”位為1.

4實驗驗證

系統(tǒng)硬件介紹

本文采用Xilinx公司提供的ML505 V5 FPGA Demo板作為SoPC系統(tǒng)硬件平臺。ML505 FPGA演示驗證板主要由一塊Virtex-5 XC5VLX50T FPGA構(gòu)成,此外還包括RAM、Flash、以太網(wǎng)接口芯片、USB接口芯片以及ADM3202 RS-232電平轉(zhuǎn)換芯片等外圍擴(kuò)展芯片,其中ADM3202電路原理圖如圖7所示。

 

 

實驗采用Xilinx公司ISE工具完成UART IP核的邏輯綜合和仿真,仿真波形如圖8所示,發(fā)送數(shù)據(jù)為0x01.UART IP核仿真通過后,用EDK工具提供的Peripheral Import Wizard生成一個采用PLB Slave Single模塊的自定義IP核框架。在該IP核目錄下的user_logic.v文件中例化波特率模塊、發(fā)送模塊、接收模塊和寄存器組,并增加相應(yīng)總線訪同邏輯后即生成了本文設(shè)計的UART IP核。

 

 

用EDK工具中的Base System Builder wizard新建一個如圖3所示的SoPC系統(tǒng),如圖9所示。在Port界面下將UART IP核的收發(fā)管腳定義為External,并在UCF文件中加入收發(fā)管腳的管腳映射描述。在Address界面下生成UART IP核的地址空間,UART通信測試程序?qū)⑼ㄟ^該地址空間訪問UART IP核。用EDK工具中Hardware菜單下Generate Bit Stream命令生成該SoPC系統(tǒng)的FPGA配置文件。用該配置文件配置ML505板載FPGA后,即生成了SoPC UART通信系統(tǒng)硬件。

 

 

用EDK工具中的Xilinx SDK軟件開發(fā)工具編寫相應(yīng)的UART通信測試程序,編譯后將程序下載至MicroBlaze處理器程序空間。將ML505板串口與PC機(jī)串口連接后運行UART通信測試程序,在PC機(jī)上可以觀察到此UART通信系統(tǒng)可以正確的發(fā)送和接收UART數(shù)據(jù),證明了該UART IP核工作正常。

5結(jié)論

文中詳細(xì)介紹了一種基于SoPC概念的UART IP核的設(shè)計。通過將Xilinx公司提供的PLB Slave Single模塊和本文設(shè)計的UART邏輯模塊結(jié)合,快速搭建了一個滿足PLB總線接口要求的UART IP核,仿真與綜合結(jié)果表明該UART IP核各項功能均達(dá)到預(yù)期要求。該設(shè)計方法既采用了成熟的商業(yè)IP核,也利用總線接口模塊將用戶自定義IP核與商業(yè)IP核連接成為一個完整的SoPC系統(tǒng)。該方法增加了系統(tǒng)的靈活性、擴(kuò)展性,同時縮短了系統(tǒng)開發(fā)時間,降低了系統(tǒng)開發(fā)難度,可為其他嵌入式系統(tǒng)的開發(fā)提供有益的參考。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉