OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
12
返回列表 发新帖
楼主: 雪雪

fsmc中的A10的偏移量到底应该怎么去计算?

  [复制链接]

2

主题

18

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
208
金钱
208
注册时间
2016-9-20
在线时间
47 小时
发表于 2017-7-17 16:46:06 | 显示全部楼层
正点原子逻辑分析仪DL16劲爆上市
回复 支持 反对

使用道具 举报

5

主题

45

帖子

0

精华

初级会员

Rank: 2

积分
106
金钱
106
注册时间
2014-7-26
在线时间
1 小时
发表于 2018-3-6 11:49:17 | 显示全部楼层
正点原子 发表于 2014-2-14 15:32
楼主关键要明白FSMC是个什么东西.
访问外部设备的时候,怎么访问.

这个机制不了解,再怎么和你解释,也没用啊 ...

原子哥,我看F4的开发板上FSMC与SRAM的地址顺序是乱的,请问你程序里面哪个地方有修复这个错乱的问题?我找了两天都找不到
回复 支持 反对

使用道具 举报

6

主题

105

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
368
金钱
368
注册时间
2018-8-31
在线时间
115 小时
发表于 2018-9-1 12:30:28 | 显示全部楼层
正点原子 发表于 2014-2-14 15:32
楼主关键要明白FSMC是个什么东西.
访问外部设备的时候,怎么访问.

这个机制不了解,再怎么和你解释,也没用啊 ...

A10的地址是根据要控制RS自己定义的对不??目的就是为了在结构体中连续的2个地址来控制数据还是命令。。。唯一不明白的就是每个FSMC的数据口和地址口都有自己内部的地址对不,,这里弄的有点蒙
回复 支持 反对

使用道具 举报

10

主题

71

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
478
金钱
478
注册时间
2018-10-7
在线时间
66 小时
发表于 2019-1-14 15:23:12 | 显示全部楼层
正点原子 发表于 2014-2-14 15:44
STM32的FSMC,在16位数据宽度的时候,地址线是右移一位对齐,且A0,永远接设备的A0.
意思就是说,你写数据的地 ...

看了您的解释简直豁然开朗啊,但是我有个问题,是不是我们不需要去考虑自己去右移一位对齐,这个是内部默认要自动右移一位对齐的。我们直接就按照已经对齐的情况去写这个地址就可以了。
回复 支持 反对

使用道具 举报

8

主题

38

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
348
金钱
348
注册时间
2019-2-1
在线时间
64 小时
发表于 2019-2-16 19:56:40 | 显示全部楼层
http://blog.sina.com.cn/s/blog_70a7b80201016zf5.html一个针对FSMC初学者的讲解,结合原子哥的帖子食用更佳!
回复 支持 反对

使用道具 举报

9

主题

120

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1141
金钱
1141
注册时间
2014-7-8
在线时间
133 小时
发表于 2019-2-21 11:25:38 | 显示全部楼层
Mark一下!
回复 支持 反对

使用道具 举报

6

主题

49

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2018-4-4
在线时间
40 小时
发表于 2019-4-14 09:45:48 | 显示全部楼层
正点原子 发表于 2014-2-14 15:44
STM32的FSMC,在16位数据宽度的时候,地址线是右移一位对齐,且A0,永远接设备的A0.
意思就是说,你写数据的地 ...

如果是写命令时,地址应该不变化了吧
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
3
金钱
3
注册时间
2020-10-27
在线时间
1 小时
发表于 2020-10-27 21:15:58 | 显示全部楼层
FSMC解惑。。。。mark
回复 支持 反对

使用道具 举报

2

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
50
金钱
50
注册时间
2013-9-2
在线时间
4 小时
发表于 2022-12-3 18:33:04 | 显示全部楼层
首先关于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 数据
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-24 20:51

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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