stm32F7,开启 cache 后,uart+idl+dma 接收失败?

2019-12-25 18:49发布

本帖最后由 hpdell 于 2017-3-30 12:05 编辑

F7的单片机,开启 cache 后,uart-idl+dma接收不到数据,中断可以进入,

SCB_EnableICache();   //使能I-Cache
SCB_EnableDCache();   //使能D-Cache    后,

使用usart+dma 接收就不行
屏蔽后uart+dam可以,但sd卡又不行

该如何处理啊 ??

sd卡使用 查询模式,

感觉这个f7的 cache 使用起来很麻烦,

其他的 mpu 保护还没有进行任何设置
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
26条回答
security
1楼-- · 2019-12-29 07:47
4317mjh 发表于 2017-8-19 02:16
您说得很好,请问这方面的理论知识在什么书上有介绍?我想系统地去了解一下 ...

可以在『ARM体系结构与编程杜春雷,这本书里面找到相关的描述。
详见: 5.4.6 存储系统的一致性问题
4317mjh
2楼-- · 2019-12-29 13:45
lusson 发表于 2017-3-30 13:51
这是我的FATFS中使用DMA和不使用DMA的调用,你可以参考看看,开启DMA前和读完数据后都要无效下cache。我比 ...

非常感谢兄弟您的分享!

一周热门 更多>