If CACHE_FLUSH_RANGE_LIMIT is defined, then the entire dcache will be flushed if the requested range is larger than this limit. Change-Id: I29277d645a9d6716b1952cf3b870c78496261dd0 Signed-off-by: Arve Hjønnevåg <arve@android.com>Slim...
//如果需要做cache一致性的层级为0,则不需要flush,跳转到finished标记处。 cbz x3, finished // if loc is 0, then no need toclean //x10存放cache级,从level0 cache开始做flush //以下三个循环loop3是set/way(x9), //loop2是index(x7),loop1是cache level(x10) mov x10, #0 // start clean at...
*/ flush_dcache_range((uintptr_t)&psci_plat_pm_ops, sizeof(psci_plat_pm_ops)); /* 标记可用的电源管理操作 */ psci_caps = PSCI_GENERIC_CAP; if (psci_plat_pm_ops->pwr_domain_off) psci_caps |= define_psci_cap(PSCI_CPU_OFF); if (psci_plat_pm_ops->pwr_domain_on && psci_pla...
* Flush the wholeD-cache. * Corrupted registers: x0-x7, x9-x11 */ ENTRY(__flush_dcache_all) //保证之前的訪存指令的顺序 dsb sy //读cache level id register mrs x0,clidr_el1// read clidr //取bits[26:24](Level of Coherency for the cache hierarchy.) //须要遵循cache一致性的cache...
//如果需要做cache一致性的层级为0,则不需要flush,跳转到finished标记处。 cbz x3, finished // if loc is 0, then no need toclean //x10存放cache级,从level0 cache开始做flush //以下三个循环loop3是set/way(x9), //loop2是index(x7),loop1是cache level(x10) ...
对处理器而言,清除操作只要清零相应cache行的有效位即可。当存储器配置上有变化时,整体或部分cache可能需要进行清除(flush)操作。有时也用术语作废(invalidate)来代替术语“清除(flush)”。然而,对于采用写回策略的D-cache,就需要使用清理(clean)操作(注:dcache也有flush(清除)操作,见flush_dcache_range函数)。
__flush_icache_range((uintptr_t)tp, (uintptr_t)tp + AARCH64_INSN_SIZE);returnret; } 进行kernel代码的 patching,在__flush_icache_range中会使用, /* * flush_icache_range(start,end) * * Ensure that the I and D caches are coherent within specified region. ...
linux/arch/arm64/include/asm/cacheflush.h void __flush_icache_range(unsigned long start, unsigned long end); int invalidate_icache_range(unsigned long start, unsigned long end); void __flush_dcache_area(void *addr, size_t len);
在驱动程序的设计中,我们可能会用到flush_cache_all将ARM cache的内容刷新到RAM,这是因为ARM Linux中cache一般会被设定为write back的。而通常象DMA是访问不了cache,所以如果我们需要启动DMA将RAM中的内容写到Flash中或LCD framebuffer,那么我们就需要调用flush_cache_all将cache中最新的内容刷新到RAM中。如果不这样...
在驱动程序的设计中,我们可能会用到flush_cache_all将ARM cache的内容刷新到RAM,这是因为ARM Linux中cache一般会被设定为write back的。而通常象DMA是访问不了cache,所以如果我们需要启动DMA将RAM中的内容写到Flash中或LCD framebuffer,那么我们就需要调用flush_cache_all将cache中最新的内容刷新到RAM中。如果不这样...