本帖最后由 shuaigew88 于 2017-1-22 20:41 编辑
使用的是STM32F7的LTDC驱动LCD屏,配置了LTDC寄存器后ST-link仿真发现LTDC ->XXX寄存器的值都根据我写的值正常写入,但是LTDC_Layerx->xxx寄存器的值都为0,无论如何都无法写入!首先LTDC寄存器配置都是使用的APB2时钟所以应该不会是时钟未使能的原因,会不会是官方头文件中寄存器地址定义有BUG??
UINT8 LTDC_Init()
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_LTDC,Enable);
LTDC ->SSCR =0; //同步像素
LTDC ->SSCR|=(48-1)<<16;
LTDC ->SSCR|=(3-1) <<0;
LTDC ->BPCR =0; //后延像素
LTDC ->BPCR|=(48+40-1)<<16;
LTDC ->BPCR|=(3+29-1) <<0;
LTDC ->AWCR =0; //有效像素
LTDC ->AWCR|=(48+40+800-1)<<16;
LTDC ->AWCR|=(3+29+480-1) <<0;
LTDC ->TWCR =0; //总宽度
LTDC ->TWCR|=(48+40+800+928-1)<<16;
LTDC ->TWCR|=(3+29+480+528-1) <<0;
LTDC ->SRCR =0; //影子寄存器
/*--- 背景 {MOD}8bit ---*/
LTDC ->BCCR =0;
LTDC ->BCCR|=0<<16;//Red
LTDC ->BCCR|=0<<8; //Green
LTDC ->BCCR|=0<<0; //Blue
/*--- 控制信号极性 ---*/
LTDC ->GCR =0;
LTDC ->GCR |=(UINT32)(1<<31); //HS高有效
LTDC ->GCR |=1<<30; //VS高有效
LTDC ->GCR |=1<<29; //DE高有效
LTDC ->GCR |=0<<28; //像素时钟极性
/*--- 抖动单元3bit ---*/
LTDC ->GCR |=0<<16;
LTDC ->GCR |=0<<12; //Red
LTDC ->GCR |=0<<8; //Green
LTDC ->GCR |=0<<4; //Blue
/*--- 层x HV位置配置寄存器 ---*/
LTDC_Layer1 ->WHPCR =0;
LTDC_Layer1 ->WHPCR|=(48+40+800)<<16;
LTDC_Layer1 ->WHPCR|=(48+40)<<0;
LTDC_Layer2 ->WHPCR =0;
LTDC_Layer2 ->WHPCR|=(48+40+800)<<16;
LTDC_Layer2 ->WHPCR|=(48+40)<<0;
LTDC_Layer1 ->WVPCR =0;
LTDC_Layer1 ->WVPCR|=(3+29+480)<<16;
LTDC_Layer1 ->WVPCR|=(3+29)<<0;
LTDC_Layer2 ->WVPCR =0;
LTDC_Layer2 ->WVPCR|=(3+29+480)<<16;
LTDC_Layer2 ->WVPCR|=(3+29)<<0;
/*--- 层x {MOD}键使能设置---*/
LTDC_Layer1 ->CR =0;
LTDC_Layer1 ->CR =0<<1; //使能 {MOD}键
LTDC_Layer1 ->CR =0<<0; //使能层
LTDC_Layer2 ->CR =0;
LTDC_Layer2 ->CR =0<<1; //使能 {MOD}键
LTDC_Layer2 ->CR =0<<0; //使能层
/*--- 层x {MOD}键配置寄存器8bit ---*/
LTDC_Layer1 ->CKCR =0;
LTDC_Layer1 ->CKCR|=(0<<16); //Red
LTDC_Layer1 ->CKCR|=(0<<8); //Green
LTDC_Layer1 ->CKCR|=(0<<0); //Blue
LTDC_Layer2 ->CKCR =0;
LTDC_Layer2 ->CKCR|=(0<<16); //Red
LTDC_Layer2 ->CKCR|=(0<<8); //Green
LTDC_Layer2 ->CKCR|=(0<<0); //Blue
/*--- 层x像素格式配置寄存器 ---*/
LTDC_Layer1 ->PFCR =2; //RGB565
LTDC_Layer2 ->PFCR =2; //RGB565
/*--- 层x Alpha配置寄存器 ---*/
LTDC_Layer1 ->CACR =100;
LTDC_Layer2 ->CACR =100;
/*--- 层x默认颜 {MOD}配置寄存器8bit ---*/
LTDC_Layer1 ->DCCR =0;
LTDC_Layer1 ->DCCR|=(0<<24); //Alpha
LTDC_Layer1 ->DCCR|=(0<<16); //Alpha
LTDC_Layer1 ->DCCR|=(0<<8); //Alpha
LTDC_Layer1 ->DCCR|=(0<<0); //Alpha
LTDC_Layer2 ->DCCR =0;
LTDC_Layer2 ->DCCR|=(0<<24); //Alpha
LTDC_Layer2 ->DCCR|=(0<<16); //Alpha
LTDC_Layer2 ->DCCR|=(0<<8); //Alpha
LTDC_Layer2 ->DCCR|=(0<<0); //Alpha
/*--- 层x混合系数配置寄存器 ---*/
LTDC_Layer1 ->BFCR =0;
LTDC_Layer2 ->BFCR =0;
/*--- 层x缓冲区起始地址 ---*/
LTDC_Layer1 ->CFBAR =(UINT32)LTDC_Layer1_Buffer;
LTDC_Layer2 ->CFBAR =(UINT32)LTDC_Layer2_Buffer;
/*--- 层x缓冲区长度寄存器 ---*/
LTDC_Layer1 ->CFBLR =0;
LTDC_Layer1 ->CFBLR|=( (800*2) <<16);
LTDC_Layer1 ->CFBLR|=(((800*2)+3) <<0);
LTDC_Layer2 ->CFBLR =0;
LTDC_Layer2 ->CFBLR|=( (800*2) <<16);
LTDC_Layer2 ->CFBLR|=(((800*2)+3) <<0);
/*--- 层x缓冲区行数寄存器 ---*/
LTDC_Layer1 ->CFBLNR =480;
LTDC_Layer2 ->CFBLNR =480;
LTDC ->GCR |=1<<0; //使能LTDC
return 0;
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
一周热门 更多>