• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于NioslI的SOPC系統(tǒng)的LCD顯示驅(qū)動(dòng)IP核設(shè)計(jì)

    基于NioslI的SOPC系統(tǒng)的LCD顯示驅(qū)動(dòng)IP核設(shè)計(jì)

    作者: 時(shí)間:2010-08-30 來(lái)源:網(wǎng)絡(luò) 收藏

    本文引用地址:http://www.czjhyjcfj.com/article/151605.htm

      3.2 寄存器組

      寄存器組由一系列寄存器組成,為軟件提供了訪問(wèn)硬件的通道。寄存器組中的寄存器是根據(jù)任務(wù)邏輯中需要實(shí)現(xiàn)的特定邏輯功能來(lái)設(shè)定的,任務(wù)邏輯中的數(shù)據(jù)通過(guò)這些寄存器傳輸。本中,寄存器組設(shè)定了8位頁(yè)地址寄存器、8位列地址寄存器,以及32位數(shù)據(jù)寄存器等。

      3.3 Ayalon總線接口

      的Avalon總線接口需要一個(gè)簡(jiǎn)單的Slave端口。該端口使用較少的Avalon信號(hào)來(lái)處理簡(jiǎn)單的寄存器讀/寫(xiě)傳輸。該模塊是與Avalon總線接口的一個(gè)頂層模塊,主要功能是對(duì)任務(wù)邏輯模塊和寄存器模塊進(jìn)行例化和封裝,使其信號(hào)類(lèi)型符合Avalon總線信號(hào)規(guī)范和外接模塊的信號(hào)規(guī)范。頂層接口定義如下:

      

    程序

      3.4 封裝及軟件

      直接在 Builder中添加好的 Core和Verilog HDL語(yǔ)言描述的文件,并根據(jù)Avalon總線傳輸規(guī)范設(shè)置好相關(guān)的信號(hào)線及傳輸參數(shù)。由于是在NiosII IDE環(huán)境下直接編寫(xiě)用戶程序,可以不用編寫(xiě)驅(qū)動(dòng)程序。完成后,將顯示驅(qū)動(dòng) Core添加至工程,并編譯、下載到FPGA器件中。

      在NiosII IDE環(huán)境下,使用自己添加的模塊編寫(xiě)程序,可直接調(diào)用甬?dāng)?shù)IOWR(BASE,OFFSET,DATA)和IORD(BASE,OFFSET)對(duì)內(nèi)部寄存器進(jìn)行讀寫(xiě)。本文使用結(jié)構(gòu)體定義了一個(gè)指向模塊的結(jié)構(gòu)體指針,對(duì)寄存器進(jìn)行讀寫(xiě)操作。

      

      CBGl28064本身不帶字庫(kù),可以通過(guò)2種方式添加字庫(kù):一種是把所需字庫(kù)做到硬件ROM中,增加了硬件資源成本,且缺乏靈活性;另一種是在軟件中定義字庫(kù),通過(guò)寫(xiě)數(shù)據(jù)寄存器進(jìn)行顯示。本設(shè)計(jì)采用第2種方式,在軟件中定義字庫(kù),并編寫(xiě)了簡(jiǎn)單的顯示測(cè)試程序,在液晶屏上顯示“ZHONG GUO”字樣。測(cè)試結(jié)果表明,該設(shè)計(jì)是正確可行的。此外,利用字模軟件生成的圖形數(shù)據(jù),也可進(jìn)行圖形顯示。

      結(jié)語(yǔ)

      本文采用有限狀態(tài)機(jī)設(shè)計(jì)了CBGl28064液晶模塊驅(qū)動(dòng)硬件邏輯,并將顯示驅(qū)動(dòng)核進(jìn)行封裝構(gòu)成了一個(gè)模塊化的獨(dú)立元件,使其能夠在其他的工程中復(fù)用;在此基礎(chǔ)上,NiosII嵌入式處理器構(gòu)建了一個(gè)用戶定制的片上。經(jīng)過(guò)在Cyclone系列FPGA上測(cè)試,該驅(qū)動(dòng)能夠在C-BGl28064液晶模塊上顯示字符、圖形。整個(gè)體現(xiàn)了嵌入式的靈活性和擴(kuò)展性。


    上一頁(yè) 1 2 3 下一頁(yè)

    評(píng)論


    相關(guān)推薦

    技術(shù)專(zhuān)區(qū)

    關(guān)閉
    主站蜘蛛池模板: 云和县| 浦东新区| 西乡县| 商城县| 略阳县| 金沙县| 南丹县| 甘谷县| 和硕县| 衡阳市| 思茅市| 噶尔县| 正安县| 通许县| 兰溪市| 开封市| 合肥市| 白朗县| 德清县| 临城县| 侯马市| 新和县| 通化县| 马边| 团风县| 东平县| 随州市| 平武县| 九龙坡区| 峡江县| 东乌珠穆沁旗| 谢通门县| 萍乡市| 威海市| 临潭县| 平谷区| 麻栗坡县| 东至县| 黄骅市| 枣庄市| 阳信县|