基于Zynq的OLED驅(qū)動設(shè)計
OLED具備自發(fā)光、不需背光源、對比度高、厚度薄、視角廣、反應速度快、可用于撓曲性面板、使用溫度范圍廣、構(gòu)造及制程較簡單等優(yōu)異特性,被認為是下一代的平面顯示器新興應用技術(shù)。目前OLED的驅(qū)動大部分都是基于STM系列 ARM芯片和傳統(tǒng)FPGA芯片。為適應Xilinx最新平臺Zynq的人機交互需要,提出一種基于Zynq的OLED驅(qū)動設(shè)計方法。文章闡述了OLED的特性和SPI控制方式,給出了設(shè)計流程和硬件電路圖。利用Zynq的PL部分完成了OLED驅(qū)動的IP核,利用Zynq的PS部分實現(xiàn)了OLED的驅(qū)動程序設(shè)計。通過AXI總線實現(xiàn)PL和PS的通信。最后通過測試程序,實現(xiàn)了字母、數(shù)字和點陣圖像的實時顯示。解決了基于Zynq器件在廣電儀器和電力儀表儀器中人機交互的工程技術(shù),具有集成度高、可移植性強和通用性好等優(yōu)點。
本文引用地址:http://www.ex-cimer.com/article/263551.htm1 引言
隨著近幾年嵌入式技術(shù)的飛速發(fā)展和廣泛應用,人機交互成為嵌入式設(shè)備的迫切需要。為適應Xilinx最新平臺Zynq的人機交互需要,提出一種基于Zynq的OLED驅(qū)動設(shè)計方法。
有機發(fā)光二極管(Organic Light-Emitting Diode,OLED)由于同時具備自發(fā)光、不需背光源、對比度高、厚度薄、視角廣、反應速度快、可用于撓曲性面板、使用溫度范圍廣、構(gòu)造及制程較簡單等優(yōu)異特性,被認為是下一代的平面顯示器新興應用技術(shù)。
Xilinx最新平臺Zynq將處理器的軟件可編程能力與FPGA的硬件可編程能力實現(xiàn)完美結(jié)合,以低功耗和低成本等系統(tǒng)優(yōu)勢實現(xiàn)良好的系統(tǒng)性能、靈活性和可擴展性。
目前OLED的驅(qū)動大部分都是基于STM系列ARM芯片和傳統(tǒng)FPGA芯片。在Zynq上,Xilinx提供了Linux演示實例,但無裸機源碼,無法滿足實時性比較強的工程實際需求。
文章詳細闡述了基于Zynq的OLED驅(qū)動設(shè)計步驟和方法,并且在基于Zynq的開發(fā)板ZedBoard上實現(xiàn)了實時顯示字母、數(shù)字和點陣圖像,為Zynq在儀器儀表領(lǐng)域?qū)崿F(xiàn)人機交互提供了技術(shù)支撐。
2 OLED驅(qū)動設(shè)計流程
Zynq是一個ARMPS+PL結(jié)構(gòu),其中PL部分就是傳統(tǒng)意義的FPGA,可以方便地定制相關(guān)外設(shè)IP,也可以進行相關(guān)的算法設(shè)計,和使用普通FPGA完全一樣。如果不使用PL,Zynq的PS部分和普通的ARM開發(fā)一樣。Zynq最大的特點是可以利用PL部分靈活地定制外設(shè),掛在PS上,而普通的ARM,外設(shè)是固定的。因此,Zynq的硬件外設(shè)是不固定的,這也是Zynq靈活性的一個表現(xiàn)。OLED在Zynq上是連接在PL上,因此需要把OLED對應引腳掛在PS的硬件上,然后設(shè)計OLED IP核,再通過SDK設(shè)計驅(qū)動程序,OLED驅(qū)動設(shè)計流程如圖1所示。
ZedBozrd控制OLED的主要方法是:自行設(shè)計一個IP核,對OLED的6個控制信號和電源信號進行邏輯設(shè)計和引腳約束,通過AXI總線,把OLED的IP核和PS聯(lián)系起來。在PS部分編寫相應的驅(qū)動程序,即可實現(xiàn)對OLED的控制,如圖2所示。
圖1 OLED驅(qū)動設(shè)計流程
圖2 OLED系統(tǒng)設(shè)計圖
因此,要實現(xiàn)OLED顯示功 能,主要做以下幾個方面工作:設(shè)計Zynq硬件系統(tǒng)(PS部分)、設(shè)計自己的IP核和PS部分驅(qū)動程序設(shè)計。
3 建立Zynq硬件系統(tǒng)和OLED IP核
Zynq的開發(fā)板ZedBoard上使用Inteltronic/Wisechip公司的OLED顯示模組UG-2832HSWEG04,分辨率為128×32,是一款單色被動式顯示屏,驅(qū)動電路采用所羅門科技的SSD1306芯片。具體電路如圖3所示。根據(jù)原理圖可知,ZedBoard開發(fā)板使用的OLED采用SPI方式控制,SPI模式使用的信號線和電源線有如下幾條:
RST(RES):硬復位OLED;
DC:命令/數(shù)據(jù)標志(0,讀寫命令;1,讀寫數(shù)據(jù));
SCLK:串行時鐘線;
SDIN:串行數(shù)據(jù)線;
VDD:邏輯電路電源;
VBAT:DC/DC轉(zhuǎn)換電路電源。
在SPI模式下,每個數(shù)據(jù)長度均為8位,在SCLK的上升沿,數(shù)據(jù)從SDIN移入到SSD1306,并且是高位在前的。
圖3 OLED原理圖
Zynq的硬件系統(tǒng)是指在PL中配置相關(guān)外設(shè),掛載到PS中,作為PS部分的外設(shè)使用。OLED驅(qū)動主要用到6個IO口,在生成硬件系統(tǒng)時,只需要利用Xilinx的嵌入式工具XPS生成最小硬件系統(tǒng),然后把OLED的相關(guān)引腳添加到最小硬件系統(tǒng)中。主要過程如下:
(1)根據(jù)芯片型號,根據(jù)XPS工具設(shè)計流程,生成Zynq的最小硬件系統(tǒng)。
(2)在最小硬件系統(tǒng)中,添加外設(shè)IPmy_oled,把OLED的SPI引腳添加到工程中。添加一個6位寄存器,每位和SPI引腳對應。
(3)my_oledIP核邏輯設(shè)計主要完成IP核引腳添加、端口映射和用戶邏輯功能。首先要對設(shè)計的IP核添加引腳,在系統(tǒng)生成的MPD文件中,添加OLED的相關(guān)引腳端口和方向信息。
在MPD文件中,在PORT下添加OLED的相關(guān)引腳和方向信息,具體代碼如下:
PORTDC=“ ”,DIR=O
PORTRES=“ ”,DIR=O
PORTSCLK=“ ”,DIR=O
PORTSDIN=“ ”,DIR=O
PORTVBAT=“ ”,DIR=O
PORTVDD=“ ”,DIR=O
(4)在系統(tǒng)生成的my_oled.vhd文件中,用VHDL語言進行端口設(shè)計,主要進行以下兩個設(shè)計。
聲明IP和用戶6個信號和電源的端口。代碼如下:
DC ∶outstd_logic;
RES ∶outstd_logic;
SCLK ∶outstd_logic;
SDIN ∶outstd_logic;
VBAT ∶outstd_logic;
VDD ∶outstd_logic;
將用戶端口和IP核端口進行映射,代碼如下:
DC =>DC,
RES =>RES,
SCLK =>SCLK,
SDIN =>SDIN,
VBAT =>VBAT,
VDD =>VDD,
評論