void RA8875_Config(void)
{
/* 初始化PLL. 晶振频率为25M */
LCD_RA8875_REG(0x88);
LCD_Delay(10); /* 短暂延迟 */
LCD_RA8875_WRITE_DATA(12); /* PLLDIVM [7] = 0 ; PLLDIVN [4:0] = 10 */
LCD_Delay(10000);
LCD_RA8875_REG(0x89);
LCD_Delay(10); /* 延迟1us */
LCD_RA8875_WRITE_DATA(2); /* PLLDIVK[2:0] = 2, 除以4 */
/* RA8875 的内部系统频率 (SYS_CLK) 是结合振荡电路及PLL 电路所产生,频率计算公式如下 :
SYS_CLK = FIN * ( PLLDIVN [4:0] +1 ) / ((PLLDIVM+1 ) * ( 2^PLLDIVK [2:0] ))
= 25M * (12 + 1) / ((0 + 1) * (2 ^ 2))
= 81.25MHz
*/
/* REG[88h]或REG[89h]被设定后,为保证PLL 输出稳定,须等待一段「锁频时间」(< 100us)。*/
LCD_Delay(10000);
/*
配置系统控制寄存器。 中文pdf 第18页:
bit3:2 色彩深度设定 (Color Depth Setting)
00b : 8-bpp 的通用TFT 接口, i.e. 256 色。
1xb : 16-bpp 的通用TFT 接口, i.e. 65K 色。 【选这个】
bit1:0 MCUIF 选择
00b : 8-位MCU 接口。
1xb : 16-位MCU 接口。 【选这个】
*/
RA8875_WriteReg(0x10, (1 <<3 ) | (1 << 1)); /* 配置16位MCU并口,65K色 */
/* REG[04h] Pixel Clock Setting Register (PCSR)
bit7 PCLK Inversion
0 : PDAT 是在PCLK 正缘上升 (Rising Edge) 时被取样。
1 : PDAT 是在PCLK 负缘下降 (Falling Edge) 时被取样。
bit1:0 PCLK 频率周期设定
Pixel Clock ,PCLK 频率周期设定。
00b: PCLK 频率周期= 系统频率周期。
01b: PCLK 频率周期= 2 倍的系统频率周期。
10b: PCLK 频率周期= 4 倍的系统频率周期。
11b: PCLK 频率周期= 8 倍的系统频率周期。
*/
RA8875_WriteReg(0x04, 0x81);
LCD_Delay(10000);
/* OTD9960 & OTA7001 设置 */
RA8875_WriteReg(0x14, 0x63);
RA8875_WriteReg(0x15, 0x00);
RA8875_WriteReg(0x16, 0x03);
RA8875_WriteReg(0x17, 0x03);
RA8875_WriteReg(0x18, 0x0B);
RA8875_WriteReg(0x19, 0xDF);
RA8875_WriteReg(0x1A, 0x01);
RA8875_WriteReg(0x1B, 0x1F);
RA8875_WriteReg(0x1C, 0x00);
RA8875_WriteReg(0x1D, 0x16);
RA8875_WriteReg(0x1E, 0x00);
RA8875_WriteReg(0x1F, 0x01);
/* 设置TFT面板的 DISP 引脚为高,使能面板. 秉火TFT模块的DISP引脚连接到RA8875芯片的GP0X脚 */
RA8875_WriteReg(0xC7, 0x01); /* DISP = 1 */
/* LCD 显示/关闭讯号 (LCD Display on) */
RA8875_WriteReg(0x01, 0x80);
/* REG[40h] Memory Write Control Register 0 (MWCR0)
Bit 7 显示模式设定
0 : 绘图模式。
1 : 文字模式。
Bit 6 文字写入光标/内存写入光标设定
0 : 设定文字/内存写入光标为不显示。
1 : 设定文字/内存写入光标为显示。
Bit 5 文字写入光标/内存写入光标闪烁设定
0 : 游标不闪烁。
1 : 游标闪烁。
Bit 4 NA
Bit 3-2 绘图模式时的内存写入方向
00b : 左 -> 右,然后上 -> 下。
01b : 右 -> 左,然后上 -> 下。
10b : 上 -> 下,然后左 -> 右。
11b : 下 -> 上,然后左 -> 右。
Bit 1 内存写入光标自动增加功能设定
0 : 当内存写入时光标位置自动加一。
1 : 当内存写入时光标位置不会自动加一。
Bit 0 内存读取光标自动增加功能设定
0 : 当内存读取时光标位置自动加一。
1 : 当内存读取时光标位置不会自动加一。
*/
RA8875_WriteReg(0x40, 0x00); /* 选择绘图模式 */
//RA8875_WriteReg(0x20, 0x04);
/* REG[41h] Memory Write Control Register1 (MWCR1)
写入目的位置,选择图层1
*/
RA8875_WriteReg(0x41, 0x01); /* 选择绘图模式, 目的为CGRAM */
} |