如何理解FSMC写地址的自动过程LCD->LCD_REG=CMD

2019-07-20 08:09发布

诸位,最近在看FSMC,不太理解这样的操作,



//LCD 操作结构体
typedef struct
{
u16 LCD_REG;
u16 LCD_RAM;
} LCD_TypeDef;
//使用 NOR/SRAM 的 Bank1.sector4,地址位 HADDR[27,26]=11 A6 作为数据命令区分线
//注意 16 位数据总线时, STM32 内部地址会右移一位对齐!
#define LCD_BASE ((u32)(0x6C000000 | 0x0000007E))
#define LCD ((LCD_TypeDef *) LCD_BASE)
其中 LCD_BASE,必须根据我们外部电路的连接来确定,我们使用 Bank1.sector4 就是从
地址 0X6C000000 开始,而 0X0000007E,则是 A6 的偏移量,
所以,有了这个定义,当我们要往 LCD 写命令/数据的时候,可以这样写:
LCD->LCD_REG=CMD; //写命令
LCD->LCD_RAM=DATA; //写数据
而读的时候反过来操作就可以了,如下所示:
CMD= LCD->LCD_REG;//读 LCD 寄存器
DATA = LCD->LCD_RAM;//读 LCD 数据
这其中, CS、 WR、 RD 和 IO 口方向都是由 FSMC 控制,不需要我们手动设置了。

  在前面的讲解中,明白了LCD->LCD_RAM与LCD->LCD_REG都是地址,为什么可以直接往地址里面写数据?查资料说有写寄存器序号啥的,也没整明白。谁能帮我解释一下,如何理解这一句。


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
11条回答
星夜欣宇
1楼-- · 2019-07-20 10:58
 精彩回答 2  元偷偷看……
taizonglai
2楼-- · 2019-07-20 15:24
学会论坛搜索,这个问题论坛里面都不知道说了多少次了。http://www.openedv.com/forum.php ... =LCD%2B%B5%D8%D6%B7
二十一画生
3楼-- · 2019-07-20 20:16
 精彩回答 2  元偷偷看……
二十一画生
4楼-- · 2019-07-20 23:43
二十一画生 发表于 2017-7-4 20:10
你好,我理解这个地址的变化过程,但是不太明白LCD->LCD_REG=CMD这一句,为什么直接可以这样写?查了资料 ...

后面还有
LCD->LCD_REG=CMD; //写命令
LCD->LCD_RAM=DATA; //写数据
这样的操作,一般情况下不是往寄存器写读写命令嘛,或者数据发送是放在变量啥的缓存里面读写?
二十一画生
5楼-- · 2019-07-21 01:37
二十一画生 发表于 2017-7-4 20:12
后面还有
LCD->LCD_REG=CMD; //写命令
LCD->LCD_RAM=DATA; //写数据

我的意思就是,是不是执行这两条语句的时候,(往这两个特殊的地址赋值写内容,比如cmd,data)fsmc会自动给外部设备lcd或者sram给一个读写时序?如果是,这是为啥?如何更好的理解
二十一画生
6楼-- · 2019-07-21 01:48
 精彩回答 2  元偷偷看……

一周热门 更多>