完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
似乎这是内存问题而不是 D-Cache 问题,D-Cache 选项将其作为副作用修复了!
我有一个项目设置如下: STM32F765IIKx 实时操作系统 SDMMC1 上的 SD 卡配置为 SD 4 位宽,启用 DMA 我遵循了这个例子 ,但是,经过一天的摸索却没有任何效果后,我发现让它工作的唯一方法是禁用 D-Cache。发现此问题后,我记得在“sd_dsikio.c”文件中看到了用于缓存维护的选项。
那么为什么F7处理器也需要这个缓存维护设置才能让SD正常工作呢?我没有对我的 UART DMA 例程使用任何缓存维护,它们在这个 F7 处理器上工作正常,但是我确实需要在使用 H7 处理器的花药项目上维护 UART DMA 缓存? *编辑* 我还需要这个配置开关集!我认为这只是 D-Cache 问题而删除了它,但这也是正确操作所必需的。
|
|
相关推荐
1个回答
|
|
您可以设置一个非缓存内存区域,这是最简单的方法,但会降低 CPU 性能。
或按照第 3.2 节缓存维护和数据一致性示例中所述进行缓存维护: "内核和 DMA 之间的数据一致性通过以下方式确保: 1. 使 SRAM1 缓冲区不可缓存 2. 或者使 SRAM1 缓冲区高速缓存启用回写策略,并由软件确保一致性(清除或使 D-Cache 无效) 3. 或者修改MPU属性中的SRAM1区域为共享区域。 4. 或者使 SRAM1 缓冲区高速缓存启用直写策略。” 注意 F7 不推荐直写策略:Errata 2.1.1 Cortex®-M7 data corruption when using data cache configured in write-through |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2747 浏览 1 评论
3244 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1813 浏览 1 评论
3655 浏览 6 评论
6045 浏览 21 评论
1342浏览 4评论
204浏览 3评论
对H747I-DISCO写程序时将CN2的st-link复用为usart1,再次烧录时无法检测到stlink怎么解决?
359浏览 2评论
STM32G474RE芯片只是串口发个数据就发烫严重是怎么回事?
451浏览 2评论
STM32处理增量式编码器Z信号如何判断中断是正转的还是反向转的?
277浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-29 21:47 , Processed in 1.238230 second(s), Total 76, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号