OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5778|回复: 6

LTDC寄存器配置奇怪现象

[复制链接]

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
979
金钱
979
注册时间
2016-6-15
在线时间
474 小时
发表于 2017-1-22 19:58:15 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 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; //影子寄存器

  /*--- 背景色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色键使能设置---*/  
  LTDC_Layer1 ->CR =0;     
  LTDC_Layer1 ->CR =0<<1; //使能色键
  LTDC_Layer1 ->CR =0<<0; //使能层

  LTDC_Layer2 ->CR =0;   
  LTDC_Layer2 ->CR =0<<1; //使能色键
  LTDC_Layer2 ->CR =0<<0; //使能层

  /*--- 层x色键配置寄存器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默认颜色配置寄存器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;
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
979
金钱
979
注册时间
2016-6-15
在线时间
474 小时
 楼主| 发表于 2017-1-22 19:58:16 | 显示全部楼层
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11552
金钱
11552
注册时间
2014-4-1
在线时间
1317 小时
发表于 2017-1-22 20:09:10 | 显示全部楼层

先看手册,确认这个寄存器是可以写的。

回复

使用道具 举报

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
979
金钱
979
注册时间
2016-6-15
在线时间
474 小时
 楼主| 发表于 2017-1-22 20:12:28 | 显示全部楼层
xuande 发表于 2017-1-22 20:09
先看手册,确认这个寄存器是可以写的。

都是层配置寄存器,都可以写.
回复

使用道具 举报

5

主题

13

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2017-3-29
在线时间
16 小时
发表于 2017-4-24 15:25:39 | 显示全部楼层
請問是如何解決的呢??? 我也遇到一樣的問題...
回复

使用道具 举报

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
979
金钱
979
注册时间
2016-6-15
在线时间
474 小时
 楼主| 发表于 2017-4-24 16:16:07 | 显示全部楼层
loveforme 发表于 2017-4-24 15:25
請問是如何解決的呢??? 我也遇到一樣的問題...

需要重载影子寄存器值才会有效。
回复

使用道具 举报

5

主题

13

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2017-3-29
在线时间
16 小时
发表于 2017-4-24 16:24:58 | 显示全部楼层
shuaigew88 发表于 2017-4-24 16:16
需要重载影子寄存器值才会有效。

一語驚醒了我.........  十分的感謝您
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-17 20:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表