OpenEdv-开源电子网

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

关于FSMC地址线的问题

[复制链接]

8

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
105
金钱
105
注册时间
2016-7-26
在线时间
19 小时
发表于 2016-7-31 14:12:38 | 显示全部楼层 |阅读模式
3金钱
         在做FSMC驱动TFTLCD实验时,在原子哥的书上看到这么一句话,“TFTLCD有RS信号,但是没有地址信号”。开发板上将TFTLCD的RS接在FSMC的A10上面。
         我的问题是,既然只有一根RS信号线,为什么不直接指定连接RS的IO口输出高低电平就行了,为什么原子哥的程序里还有“#define LCD_BASE       ( (u32)(0x6c000000|0x000007fe))”等
给A10:A0赋值的语句。A10是接TFTLCD的RS,那A9:A0又是接什么呢?我对通信方面的知识几乎是一片空白,请高手赐教

最佳答案

查看完整内容[请看2#楼]

因为要由FSMC硬件控制,如果指定IO要软件控制,速度就大打折扣了。。。。。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-7-31 14:12:39 | 显示全部楼层
因为要由FSMC硬件控制,如果指定IO要软件控制,速度就大打折扣了。。。。。
回复

使用道具 举报

8

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
105
金钱
105
注册时间
2016-7-26
在线时间
19 小时
 楼主| 发表于 2016-8-2 10:12:23 | 显示全部楼层
正点原子 发表于 2016-7-31 14:12
因为要由FSMC硬件控制,如果指定IO要软件控制,速度就大打折扣了。。。。。

原子哥,我在历史内容里也搜到了很多与我这相类似的问题,但我还是有一点不明白。
如果换成普通IO,速度大打折扣,我能理解。
那这样好了,FSMC_A10对应的IO是PG0,我就单单给PG0一个宏定义,然后只控制这一根地址线的电平,这样会有什么不妥吗?
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11537
金钱
11537
注册时间
2014-4-1
在线时间
1314 小时
发表于 2016-8-2 10:21:04 | 显示全部楼层
理理还是乱 发表于 2016-8-2 10:12
原子哥,我在历史内容里也搜到了很多与我这相类似的问题,但我还是有一点不明白。
如果换成普通IO,速度 ...


完全没问题。
单个用IO、部分用IO、全部用IO,都没问题,最多就是速度。

回复

使用道具 举报

8

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
105
金钱
105
注册时间
2016-7-26
在线时间
19 小时
 楼主| 发表于 2016-8-2 14:40:18 | 显示全部楼层
xuande 发表于 2016-8-2 10:21
完全没问题。
单个用IO、部分用IO、全部用IO,都没问题,最多就是速度。

谢谢,程序已经调通
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
23
金钱
23
注册时间
2013-10-21
在线时间
1 小时
发表于 2016-8-13 14:02:09 | 显示全部楼层
请教一下,采用FSMC方式来驱动显示屏,假如A16~A23没用到,这时A16~A23能否当普通IO口使用。谢谢
回复

使用道具 举报

8

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
105
金钱
105
注册时间
2016-7-26
在线时间
19 小时
 楼主| 发表于 2016-8-16 10:31:48 | 显示全部楼层
robin505 发表于 2016-8-13 14:02
请教一下,采用FSMC方式来驱动显示屏,假如A16~A23没用到,这时A16~A23能否当普通IO口使用。谢谢

我也不是很清楚,但是你说的那些IO口在FSMC模式下,都启动了它的复用功能了吧。如果要把A16—A23变回普通IO,应该还要设置其他寄存器
回复

使用道具 举报

5

主题

23

帖子

0

精华

初级会员

Rank: 2

积分
102
金钱
102
注册时间
2016-5-16
在线时间
13 小时
发表于 2016-9-12 14:52:00 | 显示全部楼层
我也对这个地址搞不清楚,看了几个贴子还是没搞懂。头疼。用“#define LCD_BASE       ( (u32)(0x6c000000|0x000007fe)的意思请帮忙解释下可否?谢谢!
回复

使用道具 举报

106

主题

418

帖子

0

精华

高级会员

Rank: 4

积分
764
金钱
764
注册时间
2016-7-26
在线时间
123 小时
发表于 2016-10-3 10:13:31 | 显示全部楼层
xuande 发表于 2016-8-2 10:21
完全没问题。
单个用IO、部分用IO、全部用IO,都没问题,最多就是速度。

请问,FSMC与芯片内部进行访问时有时序吗?
回复

使用道具 举报

106

主题

418

帖子

0

精华

高级会员

Rank: 4

积分
764
金钱
764
注册时间
2016-7-26
在线时间
123 小时
发表于 2016-10-3 10:21:57 | 显示全部楼层
xuande 发表于 2016-8-2 10:21
完全没问题。
单个用IO、部分用IO、全部用IO,都没问题,最多就是速度。

FSMC具体的作用是这个吗:CPU要访问SRAM时,首先MCU的引脚与FSMC通信(具体是怎么通信的?)然后FSMC与SRAM进行读时序把SRAM的内容存到自己的内存里面(是不是FSMC内存里面?),芯片内部(不知道怎么称呼)就直接取值吗?
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11537
金钱
11537
注册时间
2014-4-1
在线时间
1314 小时
发表于 2016-10-3 10:38:33 | 显示全部楼层
慕名兰 发表于 2016-10-3 10:21
FSMC具体的作用是这个吗:CPU要访问SRAM时,首先MCU的引脚与FSMC通信(具体是怎么通信的?)然后FSMC与SR ...


FSMC完成一系列动作,
地址、数据、控制三总线协调动作,一条语句就完成一系列动作。


回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-25 18:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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