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

當(dāng)前位置:首頁(yè) > EDA > 電子設(shè)計(jì)自動(dòng)化
[導(dǎo)讀]MicroBlaze嵌入式軟核是一個(gè)被Xilinx公司優(yōu)化過(guò)的可以嵌入在FPGA中的RISC處理器軟核,具有運(yùn)行速度快、占用資源少、可配置性強(qiáng)等優(yōu)點(diǎn);液晶顯示器(LCD)具有功耗低、體積小、工作電壓低、壽命長(zhǎng)、可以顯示復(fù)雜的文字及圖形等優(yōu)點(diǎn)。本文以信利MPG240128點(diǎn)陣液晶顯示模塊為例,選擇Xilinx公司的Spartan 3E系列FPGA作為控制芯片,介紹嵌入式軟處理器MicroBlaze與液晶顯示模塊的接口和圖形顯示的編程技術(shù)。

1 MicrOBlaze的體系結(jié)構(gòu)
   
MicroBlaze采用功能強(qiáng)大的32位流水線結(jié)構(gòu),包含32個(gè)32位通用寄存器和1個(gè)可選的32位移位器,時(shí)鐘頻率可達(dá)150 MHz;在Virrex一4 FPGA上運(yùn)行速率高達(dá)120 DMIPS,僅占用Virtex—II Pro FPGA中的950個(gè)邏輯單元。MicroBlaze軟核的結(jié)構(gòu)框圖如圖1所示。它具有以下基本特征:
    ①32個(gè)32位通用寄存器和2個(gè)專用寄存器(程序計(jì)數(shù)器和狀態(tài)標(biāo)志寄存器)。
    ②32位指令系統(tǒng),支持3個(gè)操作數(shù)和2種尋址方式。
    ③分離的32位指令和數(shù)據(jù)總線,符合IBM的OPB總線規(guī)范(與外設(shè)相連接的低速總線)。
    ④通過(guò)本地存儲(chǔ)器總線(LMB,本地高速總線)直接訪問(wèn)片內(nèi)塊存儲(chǔ)器(BRAM)。
    ⑤具有高速的指令和數(shù)據(jù)緩存(cache),三級(jí)流水線結(jié)構(gòu)(取址、譯碼、執(zhí)行)。
    ⑥具有硬件調(diào)試模塊(MDM)。
    ⑦帶8個(gè)輸入和8個(gè)輸出快速鏈路接口(FSL)。
    圖中接口信號(hào)說(shuō)明如下:
    ①DOPB,器件內(nèi)部的外圍設(shè)備數(shù)據(jù)接口總線,用于處理器與片內(nèi)的設(shè)備進(jìn)行數(shù)據(jù)交換。
    ②DLMB,實(shí)現(xiàn)數(shù)據(jù)交換的本地塊存儲(chǔ)器總線。該總線為處理器內(nèi)核與塊存儲(chǔ)器(BRAM)之間提供專用的高速數(shù)據(jù)交換通道。
    ③IOPB,用于實(shí)現(xiàn)外部程序存儲(chǔ)器的總線接口。當(dāng)程序較大時(shí),需要外接大容量的存儲(chǔ)器。該總線提供讀取指令的通道。
    ④ILMB,用于取指令的本地存儲(chǔ)器總線。該總線與器件內(nèi)部的塊存儲(chǔ)器(BRAM)相連,實(shí)現(xiàn)高速的指令讀取。
    ⑤MFSLO~7,主設(shè)備數(shù)據(jù)接口,提供點(diǎn)對(duì)點(diǎn)的通信通道。
    ⑥SFSLO~7,從設(shè)備數(shù)據(jù)接口,提供點(diǎn)對(duì)點(diǎn)的通信通道。


2 MicroBlaze嵌入式開(kāi)發(fā)工具EDK
    Xilinx公司提供了完善的嵌入式開(kāi)發(fā)工具EDK(Em—bedded Development Kit)。EDK是Xilinx公司于2003年推出的SOPC(System On Programmable Chip)系統(tǒng)開(kāi)發(fā)套件。該套件集成了豐富的開(kāi)發(fā)工具和大量的IP核資源,其中集成的工具包括硬件平臺(tái)生成器(PlatGen)、硬件仿真模型生成器(SimGen)、硬件調(diào)試工具(XMD)、軟件庫(kù)生成器(LibGen)、應(yīng)用軟件編譯工具(GNU Compilers)、軟件調(diào)試工具(GNU Debuggers)等;IP核資源包括LMB和OPB總線接口、外部存儲(chǔ)器控制器(EMC)、SDRAM控制器、UART接口、中斷控制器、定時(shí)器等。所有這些工具和資源都由EDK中的一個(gè)叫平臺(tái)工作室XPS(XilinxPlatform Studio)的集成開(kāi)發(fā)環(huán)境統(tǒng)一管理。XPS提供一個(gè)友好的圖形用戶界面(GUI),使用非常方便。設(shè)計(jì)流程如圖2所示。

3 液晶顯示模塊
    MPG240128液晶模塊為圖形點(diǎn)陣式液晶,不僅可以顯示數(shù)字、字符等內(nèi)容,還可以顯示漢字和任意圖形。該模塊的控制芯片為T(mén)6963C,與外部的連接只有8位數(shù)據(jù)線和6條控制線及電源。液晶模塊引腳說(shuō)明如表1所列。MCtJ只要通過(guò)這些數(shù)據(jù)線和控制線,按照相應(yīng)的時(shí)序進(jìn)行讀寫(xiě),即可實(shí)現(xiàn)對(duì)模塊的顯示控制。

4 MicrOBlaze與液晶顯示模塊的接口
    由于本文采用的液晶模塊已經(jīng)自帶了顯示控制芯片T6963C,因此液晶模塊的外圍電路相對(duì)來(lái)說(shuō)就比較簡(jiǎn)單,只要考慮和MicroBlaze的接口電路即可。本設(shè)計(jì)采用GPIO模擬液晶模塊的時(shí)序,實(shí)現(xiàn)對(duì)液晶模塊的顯示控制。MicroBlaze和液晶模塊的接口電路如圖3所示。

    在EDK開(kāi)發(fā)套件的XPS集成開(kāi)發(fā)環(huán)境下進(jìn)行系統(tǒng)硬件設(shè)計(jì)。在其界面環(huán)境下,添加所需IP核,進(jìn)行系統(tǒng)連接和各項(xiàng)參數(shù)設(shè)置。利用平臺(tái)產(chǎn)生器,根據(jù)硬件描述文件(.MHS文件),生成嵌入式系統(tǒng)子模塊的網(wǎng)表文件(.NGC),然后調(diào)用Xilinx的綜合工具XST進(jìn)行綜合,從而構(gòu)成整個(gè)應(yīng)用系統(tǒng)的硬件模型。
    本設(shè)計(jì)中采用了GPIO對(duì)液晶模塊進(jìn)行控制。EDK提供了一系列API函數(shù),通過(guò)這些函數(shù)可以很方便地對(duì)GPIO進(jìn)行操作。下面先介紹2個(gè)函數(shù):


    其中,InstancePtr是指針,指向要控制的GPIO的基地址;Channel為通道值,選0或1。這兩個(gè)函數(shù)只對(duì)Mask中對(duì)應(yīng)位為1的位有影響,比如,XGpio_DiscreteSet(&lcd240128,1,Ox00000001)將LCl3240128_pin<O>置1,而不影響其他位;同理,XGpio_DiscteteClear(&1cd240128,1,0x00000001)將LCD240128_pin<0>置0,而不影響其他位。為了增強(qiáng)程序的可讀性,增加了8個(gè)宏定義:#define wr_high()XGpio_DiscreteSet(&lcd240128,1,Ox00000800),#define wr_low()XGpio_DiscreteClear(&1cd240128,l,0x00000800),其他6個(gè)同理可推知。有了這2個(gè)函數(shù),就可以很方便地編寫(xiě)出寫(xiě)命令和寫(xiě)數(shù)據(jù)函數(shù)了。下面對(duì)這2個(gè)函數(shù)作簡(jiǎn)要介紹:


    液晶顯示圖形和字符都是由點(diǎn)陣組成的,因此,在液晶上顯示一個(gè)像素點(diǎn)是顯示圖形和字符的基礎(chǔ)。下面將單像素點(diǎn)顯示函數(shù)介紹如下:


    有了單像素點(diǎn)顯示函數(shù),就可以很方便地編寫(xiě)出字符顯示函數(shù)和圖形顯示函數(shù)了。限于篇幅,這里不作介紹。

結(jié) 語(yǔ)
    本設(shè)計(jì)已在Xilinx Spatan3 Starter Board上進(jìn)行了驗(yàn)證,取得了良好的效果。通過(guò)本設(shè)計(jì)的實(shí)現(xiàn)可以看出,MicroBlaze是一個(gè)功能強(qiáng)大、應(yīng)用靈活的嵌入式軟處理器,特別是其強(qiáng)大的用戶自定義邏輯功能,極大地方便了系統(tǒng)設(shè)計(jì)。可以預(yù)見(jiàn),基于嵌入式軟處理器的SOPC開(kāi)發(fā)方法,必將擁有廣闊的應(yīng)用前景。

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

摘 要:從硬件與軟件方面介紹了基于PXI技術(shù)的1553B總線通訊模塊的設(shè)計(jì),并對(duì)PXI總線接口設(shè)計(jì)、驅(qū)動(dòng)程序的開(kāi)發(fā)、 SDRAM存儲(chǔ)器的控制和1553B總線通信協(xié)議實(shí)現(xiàn)等關(guān)鍵技術(shù)進(jìn)行了詳細(xì)的闡述,為航空領(lǐng)域測(cè)控系統(tǒng)開(kāi)發(fā)P...

關(guān)鍵字: PXI技術(shù) 驅(qū)動(dòng)程序 SDRAM存儲(chǔ)器 1553B總線

PnP全稱Plug-and-Play,譯文為即插即用。PnP的作用是自動(dòng)配置低層計(jì)算機(jī)中的板卡和其他設(shè)備,然后告訴對(duì)應(yīng)設(shè)備都做了什么。PnP的任務(wù)是把物理設(shè)備和軟件設(shè)備驅(qū)動(dòng)程序相配合,并操作設(shè)備,在每個(gè)設(shè)備和它的驅(qū)動(dòng)程序...

關(guān)鍵字: PnP 驅(qū)動(dòng)程序 操作設(shè)備

作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄kill命令和信號(hào)使用kill...

關(guān)鍵字: 信號(hào) 應(yīng)用程序 驅(qū)動(dòng)程序

驅(qū)動(dòng)程序本質(zhì)上是軟件代碼,主要作用是計(jì)算機(jī)系統(tǒng)與硬件設(shè)備之間完成數(shù)據(jù)傳送的功能,只有借助驅(qū)動(dòng)程序,兩者才能通信并完成特定的功能。

關(guān)鍵字: 驅(qū)動(dòng)程序 硬件設(shè)備 UNIX

驅(qū)動(dòng)程序(Device Driver)全稱為“設(shè)備驅(qū)動(dòng)程序”,是一種可以使計(jì)算機(jī)和設(shè)備通信的特殊程序,可以說(shuō)相當(dāng)于硬件的接口,操作系統(tǒng)只能通過(guò)這個(gè)接口,才能控制硬件設(shè)備的工作,假如某設(shè)備的驅(qū)動(dòng)程序未能正確安裝,便不能正常...

關(guān)鍵字: 驅(qū)動(dòng)程序 聲卡 設(shè)備

作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄API函數(shù)編寫(xiě)驅(qū)動(dòng)程序編寫(xiě)應(yīng)用...

關(guān)鍵字: 編寫(xiě) 驅(qū)動(dòng)程序 字符設(shè)備驅(qū)動(dòng)

作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄示例程序目標(biāo)編寫(xiě)驅(qū)動(dòng)程序編寫(xiě)應(yīng)...

關(guān)鍵字: GPIO 編寫(xiě) 驅(qū)動(dòng)程序

打印機(jī) 在我們的辦公區(qū)域?qū)嵱眯允欠浅?qiáng)的,不僅可以提高辦公的效率,而且還能節(jié)省用戶時(shí)間,是一款非常不錯(cuò)的辦公小助手。長(zhǎng)時(shí)間使用, 打印機(jī)驅(qū)動(dòng)程序無(wú)法使用 ,怎么回事呢?用戶一定要做出詳細(xì)了解,是否需要重新安裝,下面我們一...

關(guān)鍵字: 驅(qū)動(dòng)程序 打印機(jī)驅(qū)動(dòng)

作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄混亂的API函數(shù)舊的API函數(shù)...

關(guān)鍵字: 驅(qū)動(dòng)程序 字符設(shè)備驅(qū)動(dòng)

作?者:道哥,10年嵌入式開(kāi)發(fā)老兵,專注于:C/C、嵌入式、Linux。關(guān)注下方公眾號(hào),回復(fù)【書(shū)籍】,獲取Linux、嵌入式領(lǐng)域經(jīng)典書(shū)籍;回復(fù)【PDF】,獲取所有原創(chuàng)文章(PDF格式)。目錄學(xué)習(xí)的困惑實(shí)踐環(huán)境編譯進(jìn)內(nèi)核編...

關(guān)鍵字: 內(nèi)核 編譯 驅(qū)動(dòng)程序

電子設(shè)計(jì)自動(dòng)化

21319 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉