OpenEdv-开源电子网

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

6ull裸机缓存刷新的方法 cache flush

[复制链接]

11

主题

20

帖子

0

精华

初级会员

Rank: 2

积分
88
金钱
88
注册时间
2020-4-1
在线时间
21 小时
发表于 2020-4-13 14:23:40 | 显示全部楼层 |阅读模式
之前在测试memcpy速度时发现开启缓存提高效率时会出现外设读取内存数据不更新的情况,查了好久终于找到了解决方案,从arch\arm\mm\cache-v7中找出来的,做成了c函数,将cpu cache回写到内存中,经测试可用,但还有模糊的地方
void v7_cache_flush_range(unsigned int *start, unsigned int *end)

{
    //dcache_line_size siz2, siz3
    unsigned int siz2 = 64, siz3, dir;
    siz3 = siz2 - 1;
    dir = (unsigned int)start & (~(siz3));
    while (dir <= (unsigned int)end)
    {
        asm("mcr p15, 0, r0, c7, c14, 1 "); // clean & invalidate D / U line
        dir += siz2;
    }
    asm("dsb st ");
}
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2020-4-13 16:45:50 | 显示全部楼层
开启缓存以后就会导致缓存不一致的现象发生,需要做清缓存的操作。这个问题STM32F7这种Cortex-M7内核的单片机上很常见,所以uboot都是默认直接关闭cache的,尤其是D Cache
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-25 09:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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