OpenEdv-开源电子网

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

F7 的 cache 让人捉摸不定。

[复制链接]

122

主题

294

帖子

0

精华

高级会员

Rank: 4

积分
712
金钱
712
注册时间
2015-11-14
在线时间
868 小时
发表于 2018-3-2 19:04:12 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 walker168 于 2018-3-2 19:06 编辑

用一块STM32F746G-DISCO跑自己的代码。   CACHE 如果不开,运行速度几乎下降一半,无法接受;CACHE打开, 有时软件运行正常,但仅仅增加或删除一些无关紧要的代码,立马出现异常:显示偶尔有点闪,QSPI FLASH 中的字库读取不正常,明显是乱码。   软件在运行过程中,对SDRAM 的操作很频繁,既要刷屏又有大量数据要临时保存到SDRAM中,可能是原因之一。

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8024
金钱
8024
注册时间
2014-8-13
在线时间
1595 小时
发表于 2018-3-2 23:19:48 | 显示全部楼层
cache麻烦就在这里。cache要用好要对系统有相当深刻的理解。适当volatile以及编译优化级别也调节一下,测试一下看看效果吧
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2018-3-3 01:51:16 | 显示全部楼层
注意加MPU保护就会好了。
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2018-3-3 09:59:41 | 显示全部楼层
本帖最后由 zuozhongkai 于 2018-3-3 10:01 编辑

很正常,不只是F7,所有带有cache的CPU都很麻烦,比如说操作系统(linux这种大型操作系统)对于cache的处理就是操作系统设计的重难点。在linux这样的应用环境下,cache的处理是操作系统底层来完成的,程序员不需要管,但是STM32F7就是个单片机,UCOS这样的小操作系统有不会去处理cache,所以cache的处理就到了程序员身上了,这个是就需要程序员懂一些处理器架构的知识了,cache的重点处理就是解决数据一致性问题。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 22:54

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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