关于FSMC的地址操作

在看正点原子FSMC驱动TFTLCD屏的相关资料时,有一处地址操作的代码不是很懂:

使用 NOR/SRAM 的 Bank1.sector4,地址位 HADDR[27,26]=11 A10 作为数据命令区分线        注意 16 位数据总线时, STM32 内部地址会右移一位对齐!

//LCD 操作结构体
typedef struct
{ vu16 LCD_REG;
vu16 LCD_RAM;
} LCD_TypeDef;
 

#define LCD_BASE ((u32)(0x6C000000 | 0x000007FE))

#define LCD ((LCD_TypeDef *) LCD_BASE)
 

这段注释和这段代码的或操作想了好一段时间才相通,现在总结分析如下,为什么要stm32的内部地址要右移一位,为什么要进行这样的或操作,为什么要将LCD_BASE的地址强制转换为LCD_TypeDef类型的结构体,

搞懂这些东西首先要明白FSMC的概念,FSMC是灵活的静态存储控制器,它的接口支持包括SRAM,NOR FLASH,NAND FLASH,PSRAM等存储器。stm32的FSMC将这些设备分为3类分别是NOR/PSRAM设备,NAND设备,PC卡设备这些设备使用共同的地址及数据总线,通过片选线CS以区分不同的设备,之所以用FSMC驱动TFTLCD设备,是因为TFTLCD的外部连接和SRAM的外部连接时相似的。SRAM的外部连接有 地址线、数据线、片选线、写信号线、读信号线、如果支持字节控制那么还会有UB/LB信号线。TFTLCD的外部连接线有 RS (区分传来的数据是命令还是数据,类似于SRAM的地址线),数据线、片选线、写信号线、读信号线、片选线。故综上所述TFTLCD是可以看作SRAM,从而通过FSMC进行驱动的。

因此要通过FSMC驱动TFTLCD屏,就是控制读写信号线,数据线、片选线、及RS信号线来区分读写的是命令还是数据。而FSMC控制器就数据线、地址线、片选线。数据线和片选线是固定死了的,只能通过控制地址线来达到控制RS信号线的目的。

写到这就需要了解FSMC外部设备的地址映像,FSMC管理1G的外部存储空间,通过发送地址达到对外部存储器的访问。这里不做详细介绍。下面重点来了。如何通过控制FSMC实现对RS信号线的控制。

首先关于FSMC地址操作的一些认识:STM32每个地址是存放1个字节de,假如定义了一个u16 temp[5]的数组,如果temp对应的地址是0x00,那么temp[1]对应的地址就是0x00+2;(地址要加2的)。如果SRAM是64K*16的规格,即一个地址存放两个字节,但是stm32是一个地址对应一个字节,这样就会出现控制问题。如果地址线依旧是stm32的A0-A15和存储器的A0-A15相连接,那么如果要访问SRAM的temp[1],那么stm32会给出(0x00+2)的地址,这个地址对应到SRAM处就成了temp[2],这样就出现了问题。如果发送到SRAM的地址右移一位即0x01则地址就对应上了。stm32在控制16位的外部存储设备时发送的地址会自动向右一位,从而访问的正确的地址。

TFTLCD作为SRAM,通过地址线实现对RS的控制,假如LCD屏的RS挂载在地址线A10上。

比如写0,右移一位,还是0,A0就是0.
比如你写2,右移一位,就是1了,A0就是1.
比如你写0X7FE,右移一位,就是3FF. 换成二进制是多少? 
二进制表示:     0   1  1  1  1  1  1  1  1 1 1 
FSMC地址状态:   A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0
这个时候,A10,是不是0啊???
是不是RS=0?

那么:
typedef struct
{
u16 LCD_REG;
u16 LCD_RAM;
} LCD_TypeDef;
#define LCD             ((LCD_TypeDef *) LCD_BASE)

此时将LCD_BASE强制转化为LCD_TypeDef类型的地址,则可以得出 LCD_TypeDef 型结构体成员的首个结构体元素LCD_REG的地址为0X7FE,又因为定义为u16类型的结构体元素,因此LCD_RAM的地址就是0X800,

LCD->LCD_REG=CMD; //写命令 即向这个地址中写的就是命令
LCD->LCD_RAM=DATA; //写数据 向这个地址中写的就是数据

而读的时候反过来操作就可以了,如下所示:
CMD= LCD->LCD_REG; //读 LCD 寄存器命令
DATA = LCD->LCD_RAM; //读 LCD 数据

具有参考意义的链接如下:
http://www.openedv.com/forum.php?mod=viewthread&tid=33759

http://www.openedv.com/forum.php?mod=viewthread&tid=27240

 

 

 

 

 

 

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值