新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 基于Zynq的OLED驱动设计

基于Zynq的OLED驱动设计

作者:时间:2014-10-02来源:网络收藏

  (5)在系统生成的user_logic.v文件中,用Verilog语言进行逻辑设计,实现寄存器和SPI对应端口连接并实时读取,主要代码如下。其中slv_reg0为IP核寄存器,tmp为用户定义临时寄存器,tmp的每一位和IP端口一一对应。实现把slv_reg0寄存器低6位实时传给tmp寄存器,通过对寄存器slv_reg0的写操作达到控制6个引脚的时序。

本文引用地址:http://www.eepw.com.cn/article/263551.htm

  always@(posedgeBus2IP_Clk)

  begin

  tmp<=slv_reg0[5:0];

  end

  4 驱动程序设计

  由于ZedBoard开发板上的使用的是SPI协议,并且只支持写,不支持读,因此控制就是在SCLK的时钟下,通过SDIN进行命令和数据的传输。OLED的控制需要经过初始化、传数据和命令以及对显存设置等操作实现。

  4.1 初始化

  驱动IC的初始化代码,可以参考厂家推荐的设置,但需要根据开发板上OLED实际参数进行一些修改。

  根据SSD1306数据手册的初始化说明,具体步骤如图4所示。初始化的实现就是对SSD1306进行写命令。

  

 

  图4 SSD1306初始化步骤

  4.2 写数据和命令的实现

  在SCLK时钟下,根据要写入的数据或者命令,设置SDIN引脚的电平,一位一位地把数据写入SSD1306.SSD1306每次传送的命令和数据均为一个字节,传送数据和命令的区别是通过Set_OLED_DC宏,设置该函数为写数据,通过Clr_OLED_DC宏,设置该函数为写命令。实现一个字节的数据传输代码如下:

  for(i=0;i<8;i++)

  {

  Clr_OLED_SCLK;

  if(data&0x80)

  Set_OLED_SDIN;

  else

  Clr_OLED_SDIN;

  Set_OLED_SCLK;

  data《=1;

  }

  4.3 显存数据写入SSD1306存储器

  我们采用的办法是在PS的内部建立一个OLED的GRAM(共128个字节),在每次修改的时候,只是修改PS上的GRAM(实际上就是SRAM),在修改完之后,一次性把PS上的GRAM写入到OLED的GRAM.具体代码如下:

  voidOLED_Refresh_Gram(void)

  {

  u8i,n;

  for(i=0;i<4;i++)

  {

  write_cmd(0xb0+i);//设置页地址

  write_cmd(0x00);//设置显示位置-列低地址,偏移了2列

  write_cmd(0x10);//设置显示位置-列高地址

  for(n=0;n<128;n++)write_data(OLED_GRAM[n][i]);

  }

  }

  4.4 显示结果

  系统实现了OLED的字母、数字和点阵图形实时显示,如图5所示。

  

 

  图5 OLED运行结果

  5 结论

  系统采用可软硬件协同设计的器件,定制硬件IP核,采用传统ARM程序设计方法设计OLED驱动程序和测试程序,实现了实时显示。解决了基于器件在广电仪器和电力仪表仪器中人机交互的工程技术,具有集成度高、可移植性强和通用性好等优点。


上一页 1 2 下一页

关键词: Zynq OLED STM

评论


相关推荐

技术专区

关闭