STM32关于FSMC连接LCD例程:怎么确定片外的寄存器地址?

chunlei9924   2010-3-7 23:11 楼主


Keil4自带的demo: STM32F103VE用FSMC驱动LCD AM-240320L8TNQW00H(ILI9320),在lcd.c里有:
typedef struct
{
  __IO uint16_t LCD_REG;
  __IO uint16_t LCD_RAM;
} LCD_TypeDef;

#define LCD_BASE    ((uint32_t)(0x60000000 | 0x0C000000))
#define LCD         ((LCD_TypeDef *) LCD_BASE)

第一个define好理解:LCD连接的是FSMC_Bank1_NOR/SRAM4,映射到FSMC的memory为0x6C00 0000 - 0x6FFF FFFF,共64MByte。
但第二个define该怎么理解呢,为什么LCD_REG(寄存器序号)地址为0x6C00 0000、LCD_RAM(该寄存器的值)地址为0x6C00 0001?

对于写寄存器,代码里有:
#define R1             0x01
LCD_WriteReg(R1, 0x0100);
uint16_t LCD_ReadReg(uint8_t LCD_Reg)
{
  LCD->LCD_REG = LCD_Reg;
  return (LCD->LCD_RAM);
}
MCU和LCD的通讯,从ILI9320 DS里的时序图可知是:先CS=0,RS=0,WR=0写IR,然后使CS=0,RS=1,WR=0再写index是IR值的寄存器(RS=1时不时写RAM么?不懂),而对于上面的LCD_WriteReg()语句,就是先往地址为0x6C00 0000的地方写0x01、再往地址为0x6C00 0001的地方写0x0100,中间也没有CS/RS/WR的设置,LCD_REG怎么就成了IR寄存器呢、LCD_RAM怎么就成了IR索引的那个寄存器呢?

请高手指教。
附图:问题中提到的demo所用的电路图:  





回复评论 (31)

LCD_WriteReg(R1, 0x0100);   我觉得是 R1 地址 写入数据0x100;
LCD_ReadReg                        从寄存器里读数据
点赞  2010-3-8 11:21
版主主、列为大虾兄,给个话3
我知道之前有个帖子和我这个问题相似,但说的不是一个事
点赞  2010-3-8 11:22
                                 A0的电平   驱动的 RS 和你的LCD 操作有关系
点赞  2010-3-8 11:27
                                 看的不是很明白,还是希望高手解答下
点赞  2010-3-8 11:49
为什么LCD_REG(寄存器序号)地址为0x6C00 0000、LCD_RAM(该寄存器的值)地址为0x6C00 0001?

是这样:因为是16位的,LCD_REG地址为0x6C00 0000,LCD_RAM(该寄存器的值)地址为0x6C00 0002
点赞  2010-3-8 12:30
                                 4楼已经给出了答案。
点赞  2010-3-8 12:32
对于上面的LCD_WriteReg()语句,就是先往地址为0x6C00 0000的地方写0x01、再往地址为0x6C00 0001的地方写0x0100,中间也没有CS/RS/WR的设置

回答:
1. 无论往LCD_REG还是LCD_RAM写入、读出,片选CS都会变低
2.  电路图中RS接A0,所以往LCD_REG写入时 RS为0,往往LCD_RAM写入、读出时 RS为1
点赞  2010-3-8 12:38
对于LCD_WriteReg(R1, 0x0200);过程应该是:MCU先通过interface将R1(0x01)写入LCD控制器的IR寄存器,然后MCU再通过interface将值0x0200写入LCD控制器中索引值为0x01的寄存器。
对于MCU的片内各外设的寄存器,每个都有确定地址,在datasheet里查得到,访问它们就是对某地址的读写。但这里,IR寄存器和索引值为0x01的寄存器都在MCU外,如何访问它们呢,对于FSMC来说,是把他们的统统映射到0x6C00 0000 - 0x6FFF FFFF区域,但这片区域怎么对应LCD控制器的一堆寄存器和RAM呢?看起来IR是对应0x6C00 0000,这依据的是什么呢?0x6C00 0002又是依据什么映射哪个寄存器呢?
点赞  2010-3-8 13:11
                                 4楼说的太浓缩,能稀释一下吗
点赞  2010-3-8 13:14
                                 lcd 的RS脚电平0、1  关系到你对lcd的操作,0x6C00 0001,0x6C00 0000  中的1,0 是对RS脚的电平操作
点赞  2010-3-8 13:30
4楼说的太浓缩,能稀释一下吗
8楼已经稀释了。
点赞  2010-3-8 13:30
                                 对你有用的部分 仅仅是0x6C00 0001,0x6C00 0000    地址 其余统统没用 ,你需要看一下单片机总线方面的资料
点赞  2010-3-8 13:35
                                 MCU往0x6C00 0000地址写0x01,片外的LCD从接口数据线的16bit收到这个值,但它怎么就知道该把这个值送给IR寄存器呢,FSMC只把0x6C00 0000 - 0x6FFF FFFF映射给了LCD,但也没说0x6C00 0000就是IR寄存器呀
点赞  2010-3-8 13:35
0x6C00 0000    相当于给你的LCD脚RS 低电平  
0x6C00 0001   相当于给你的LCD脚RS 高电平

然后看你的资料  RS  电平不同 操作的内容是不同的
点赞  2010-3-8 13:39


根据ILI9320的手册,RS=0就是对IR寄存器写或者对SR寄存器读,RS=1就是对其它寄存器或者RAM写、读。

电路图上RS接A0,所以RS=0就对应于地址0x6C00 0000或者0x6C00 0004、0x6C00 0008...;所以RS=1就对应于地址0x6C00 0002或者0x6C00 0006、0x6C00 000A...。

对地址0x6C00 0000或者0x6C00 0004写就是对IR寄存器写,对地址0x6C00 0000或者0x6C00 0004读就是对SR寄存器读。

对地址0x6C00 0002或者0x6C00 0006写、读就是对其它寄存器写、读,到底是对哪个寄存器读写?这取决于IR寄存器的值。通常在读写其它寄存器前,对IR寄存器执行写操作来设定IR寄存器的值。

ILI9320 Regs.png (26.97 KB)

点赞  2010-3-8 13:47
                                 0x6C00 0000、0x6C00 0001不是通过D[0...15]这16bit发给LCD的么,RS接的A0,MCU对A0没有明显的设置呀,A0怎么就知道把自己置高、低电平呢……
点赞  2010-3-8 13:47
                                 请按照13楼的提示“你需要看一下单片机总线方面的资料”,你问的问题说明你没有这方面的基础。
点赞  2010-3-8 13:49
                                 0x6C00 0000  0x6C00 0001  地址线的电平
点赞  2010-3-8 13:50
                                 A0-A15       “C语言要加强一下!”  你没理解“ #define LCD         ((LCD_TypeDef *) LCD_BASE) ”
点赞  2010-3-8 13:53
12下一页
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复