为什么flush_dcache_page()在linux内核中什么都不做?
发布时间:2020-12-13 22:54:48 所属栏目:Linux 来源:网络整理
导读:我发现flush_dcache_page()在x86 arch上的 linux内核中没有做任何事情,如下所示 包括/ ASM-通用/ cacheflush.h Line 17 #define flush_dcache_page(page) do {} while (0) 我认为在x86 arch上有缓存刷新指令“CLFLUSH”,它可以用于此页面刷新. 但是,flush_dc
我发现flush_dcache_page()在x86 arch上的
linux内核中没有做任何事情,如下所示
包括/ ASM-通用/ cacheflush.h Line 17 #define flush_dcache_page(page) do {} while (0) 我认为在x86 arch上有缓存刷新指令“CLFLUSH”,它可以用于此页面刷新. 但是,flush_dcache_page()不会像上面的源代码一样运行任何CPU指令. 为什么flush_dcache_page()不运行x86架构上的任何指令? 是否保证将dcache中的页面写入主内存? 解决方法
从
https://www.kernel.org/doc/Documentation/cachetlb.txt起
“如果D-cache别名不是问题,那么这个例程可能只是被定义为该架构上的nop.” (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |