|
我用的是野火的mini板子,换上RA8875 4.3 480* 272的LCD,目前无法点亮,原理图如下:
原理图
移植过来的驱动代码只修改了以下几个地方:
1. GPIO_D_13改为GPIO_D_11,因为RS为A16;
2.删除 init.FSMC_MemoryType = FSMC_MemoryType_SRAM;
3. RA8875_InitHard()中去除了兼容部分。
4.
#define RA8875_REG *(__IO uint16_t *)(0x60000000)
#define RA8875_RAM *(__IO uint16_t *)(0x60020000) |
|
硬件上的连接检查了,应该没有问题;
int main(void)
{
int i = 0;
/* LED 端口初始化 */
ALL_GPIO_Config();
GPIO_SetBits(GPIOB,GPIO_Pin_0);
GPIO_SetBits(GPIOB,GPIO_Pin_1);
GPIO_SetBits(GPIOB,GPIO_Pin_5);
RA8875_InitHard();
RA8875_SetBackLight(200);
/* 初始化定时器 */
// SysTick_Init();
/*CRC和emWin没有关系,只是他们为了库的保护而做的,这样STemWin的库只能用在ST的芯片上面,别的芯片是无法使用的。 */
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_CRC, ENABLE);
// GUI_Init();
GPIO_ResetBits(GPIOB,GPIO_Pin_0);
/* 初始化串口 */
USART1_Config();
while (1)
{
//i = Key_Scan();
}
}
初始化代码如下:
static void LCD_CtrlLinesConfig(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* 使能复用IO时钟*/
RCC_APB2PeriphClockCmd ( RCC_APB2Periph_AFIO, ENABLE );
/* 使能FSMC对应相应管脚时钟*/
RCC_APB2PeriphClockCmd ( RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE, ENABLE );
#endif
/* 设置 PD.00(D2), PD.01(D3), PD.04(NOE), PD.05(NWE), PD.08(D13), PD.09(D14),
PD.10(D15), PD.14(D0), PD.15(D1) 为复用推挽输出 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5 |
GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_14 |
GPIO_Pin_15;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOD, &GPIO_InitStructure);
/* 设置 PE.07(D4), PE.08(D5), PE.09(D6), PE.10(D7), PE.11(D8), PE.12(D9), PE.13(D10),
PE.14(D11), PE.15(D12) 为复用推挽输出 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 |
GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 |
GPIO_Pin_15;
GPIO_Init(GPIOE, &GPIO_InitStructure);
/* 设置 PD.13(A18 (RS)) 为复用推挽输出 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
GPIO_Init(GPIOD, &GPIO_InitStructure);
/* 设置 PD.7(NE1 (LCD/CS)) 为复用推挽输出 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;
GPIO_Init(GPIOD, &GPIO_InitStructure);
}
/*
*********************************************************************************************************
* 函 数 名: LCD_FSMCConfig
* 功能说明: 配置FSMC并口访问时序
* 形 参:无
* 返 回 值: 无
*********************************************************************************************************
*/
static void LCD_FSMCConfig(void)
{
FSMC_NORSRAMInitTypeDef init;
FSMC_NORSRAMTimingInitTypeDef timing;
/*-- FSMC Configuration ------------------------------------------------------*/
/*----------------------- SRAM Bank 1 ----------------------------------------*/
/* FSMC_Bank1_NORSRAM4 configuration */
timing.FSMC_AddressSetupTime = 1;
timing.FSMC_AddressHoldTime = 0;
timing.FSMC_DataSetupTime = 2;
timing.FSMC_BusTurnAroundDuration = 0;
timing.FSMC_CLKDivision = 0;
timing.FSMC_DataLatency = 0;
timing.FSMC_AccessMode = FSMC_AccessMode_A;
/*
LCD configured as follow:
- Data/Address MUX = Disable
- Memory Type = SRAM
- Data Width = 16bit
- Write Operation = Enable
- Extended Mode = Enable
- Asynchronous Wait = Disable
*/
init.FSMC_Bank = FSMC_Bank1_NORSRAM1;
init.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
// init.FSMC_MemoryType = FSMC_MemoryType_SRAM;
init.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;
init.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;
init.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; /* 注意旧库无这个成员 */
init.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
init.FSMC_WrapMode = FSMC_WrapMode_Disable;
init.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
init.FSMC_WriteOperation = FSMC_WriteOperation_Enable;
init.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
init.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;
init.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
init.FSMC_ReadWriteTimingStruct = &timing;
init.FSMC_WriteTimingStruct = &timing;
FSMC_NORSRAMInit(&init);
/* - BANK 3 (of NOR/SRAM Bank 1~4) is enabled */
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
}
/*
*********************************************************************************************************
* 函 数 名: RA8875_InitHard
* 功能说明: 初始化RA8875驱动芯片
* 形 参:无
* 返 回 值: 无
*********************************************************************************************************
*/
void RA8875_InitHard(void)
{
uint8_t ucGPIX;
/* 读取 RA8875 芯片额GPIX引脚的电平状态;1表示4.3寸屏;0表示7寸屏
【备注】这是安富莱电子为了便于统一测试例程,在LCD模块上做的硬件标识。在做产品时,不必自动识别。
*/
//Add by Luoxingxing
LCD_CtrlLinesConfig();
LCD_FSMCConfig();
Delay_Ms(20);
// ucGPIX = RA8875_ReadReg(0xC7);
// if (ucGPIX == 1) /* GPIX = 1 表示 4.3 寸屏 480x272 */
{
/* 初始化PLL. 晶振频率为25M */
RA8875_REG = 0x88;
RA8875_Delaly1us(); /* 延迟1us */
RA8875_RAM = 10; /* PLLDIVM [7] = 0 ; PLLDIVN [4:0] = 10 */
RA8875_Delaly1ms();
RA8875_REG = 0x89;
RA8875_Delaly1us(); /* 延迟1us */
RA8875_RAM = 2; /* PLLDIVK[2:0] = 2, 除以4 */
/* RA8875 的内部系统频率 (SYS_CLK) 是结合振荡电路及PLL 电路所产生,频率计算公式如下 :
SYS_CLK = FIN * ( PLLDIVN [4:0] +1 ) / ((PLLDIVM+1 ) * ( 2^PLLDIVK [2:0] ))
= 25M * (10 + 1) / ((0 + 1) * (2 ^ 2))
= 68.75MHz
*/
/* REG[88h]或REG[89h]被设定后,为保证PLL 输出稳定,须等待一段「锁频时间」(< 100us)。*/
RA8875_Delaly1ms();
/*
配置系统控制寄存器。 中文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, 0x82); /* 设置PCLK反相 */
RA8875_Delaly1ms();
//Horizontal set
//HDWR//Horizontal Display Width Setting Bit[6:0]
//Horizontal display width(pixels) = (HDWR + 1)*8
RA8875_WriteReg(0x14, 0x3B);
RA8875_WriteReg(0x15, 0x00);
//HNDR//Horizontal Non-Display Period Bit[4:0]
//Horizontal Non-Display Period (pixels) = (HNDR + 1)*8
RA8875_WriteReg(0x16, 0x01);
//HSTR//HSYNC Start Position[4:0]
//HSYNC Start Position(PCLK) = (HSTR + 1)*8
RA8875_WriteReg(0x17, 0x00);
//HPWR//HSYNC Polarity ,The period width of HSYNC.
//HSYNC Width [4:0] HSYNC Pulse width(PCLK) = (HPWR + 1)*8
RA8875_WriteReg(0x18, 0x05);
//Vertical set
//VDHR0 //Vertical Display Height Bit [7:0]
//Vertical pixels = VDHR + 1
RA8875_WriteReg(0x19, 0x0F);
//VDHR1 //Vertical Display Height Bit [8]
//Vertical pixels = VDHR + 1
RA8875_WriteReg(0x1A, 0x01);
//VNDR0 //Vertical Non-Display Period Bit [7:0]
//Vertical Non-Display area = (VNDR + 1)
RA8875_WriteReg(0x1B, 0x02);
//VNDR1 //Vertical Non-Display Period Bit [8]
//Vertical Non-Display area = (VNDR + 1)
RA8875_WriteReg(0x1C, 0x00);
//VSTR0 //VSYNC Start Position[7:0]
//VSYNC Start Position(PCLK) = (VSTR + 1)
RA8875_WriteReg(0x1D, 0x07);
//VSTR1 //VSYNC Start Position[8]
//VSYNC Start Position(PCLK) = (VSTR + 1)
RA8875_WriteReg(0x1E, 0x00);
//VPWR //VSYNC Polarity ,VSYNC Pulse Width[6:0]
//VSYNC Pulse Width(PCLK) = (VPWR + 1)
RA8875_WriteReg(0x1F, 0x09);
// g_LcdHeight = LCD_43_HEIGHT;
// g_LcdWidth = LCD_43_WIDTH;
}
/* 设置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); /* 选择绘图模式 */
/* REG[41h] Memory Write Control Register1 (MWCR1)
写入目的位置,选择图层1
*/
RA8875_WriteReg(0x41, 0x00); /* 选择绘图模式, 目的为CGRAM */
RA8875_SetDispWin(0, 0, LCD_43_HEIGHT, LCD_43_WIDTH);
/* 设置单图层,水平扫描方向,垂直扫描方向 */
RA8875_REG = 0x20;
RA8875_RAM = 0x00;
RA8875_REG = 0x52;
RA8875_REG = 0x00;
} |
|