12#ifndef ZEPHYR_INCLUDE_ARCH_CACHE_H_
13#define ZEPHYR_INCLUDE_ARCH_CACHE_H_
21#if defined(CONFIG_ARM64)
23#elif defined(CONFIG_XTENSA)
27#if defined(CONFIG_DCACHE) || defined(__DOXYGEN__)
36#define cache_data_enable arch_dcache_enable
45#define cache_data_disable arch_dcache_disable
58#define cache_data_flush_all arch_dcache_flush_all
71#define cache_data_invd_all arch_dcache_invd_all
84#define cache_data_flush_and_invd_all arch_dcache_flush_and_invd_all
107#define cache_data_flush_range(addr, size) arch_dcache_flush_range(addr, size)
131#define cache_data_invd_range(addr, size) arch_dcache_invd_range(addr, size)
156#define cache_data_flush_and_invd_range(addr, size) \
157 arch_dcache_flush_and_invd_range(addr, size)
159#if defined(CONFIG_DCACHE_LINE_SIZE_DETECT) || defined(__DOXYGEN__)
176#define cache_data_line_size_get arch_dcache_line_size_get
182#if defined(CONFIG_ICACHE) || defined(__DOXYGEN__)
191#define cache_instr_enable arch_icache_enable
200#define cache_instr_disable arch_icache_disable
213#define cache_instr_flush_all arch_icache_flush_all
226#define cache_instr_invd_all arch_icache_invd_all
239#define cache_instr_flush_and_invd_all arch_icache_flush_and_invd_all
262#define cache_instr_flush_range(addr, size) arch_icache_flush_range(addr, size)
286#define cache_instr_invd_range(addr, size) arch_icache_invd_range(addr, size)
310#define cache_instr_flush_and_invd_range(addr, size) \
311 arch_icache_flush_and_invd_range(addr, size)
313#if defined(CONFIG_ICACHE_LINE_SIZE_DETECT) || defined(__DOXYGEN__)
331#define cache_instr_line_size_get arch_icache_line_size_get
337#if CONFIG_CACHE_DOUBLEMAP || __DOXYGEN__
339#define cache_is_ptr_cached(ptr) arch_cache_is_ptr_cached(ptr)
342#define cache_is_ptr_uncached(ptr) arch_cache_is_ptr_uncached(ptr)
345#define cache_cached_ptr(ptr) arch_cache_cached_ptr_get(ptr)
348#define cache_uncached_ptr(ptr) arch_cache_uncached_ptr_get(ptr)
static ALWAYS_INLINE void arch_cache_init(void)
Definition cache.h:333
void arch_dcache_disable(void)
Disable the d-cache.
void arch_icache_disable(void)
Disable the i-cache.
void * arch_cache_uncached_ptr_get(void *ptr)
int arch_dcache_invd_range(void *addr, size_t size)
Invalidate an address range in the d-cache.
int arch_icache_flush_and_invd_all(void)
Flush and Invalidate the i-cache.
int arch_icache_flush_all(void)
Flush the i-cache.
int arch_icache_invd_all(void)
Invalidate the i-cache.
int arch_dcache_flush_range(void *addr, size_t size)
Flush an address range in the d-cache.
size_t arch_dcache_line_size_get(void)
Get the d-cache line size.
size_t arch_icache_line_size_get(void)
Get the i-cache line size.
int arch_icache_flush_range(void *addr, size_t size)
Flush an address range in the i-cache.
int arch_icache_invd_range(void *addr, size_t size)
Invalidate an address range in the i-cache.
int arch_dcache_flush_all(void)
Flush the d-cache.
bool arch_cache_is_ptr_cached(void *ptr)
int arch_icache_flush_and_invd_range(void *addr, size_t size)
Flush and Invalidate an address range in the i-cache.
bool arch_cache_is_ptr_uncached(void *ptr)
void * arch_cache_cached_ptr_get(void *ptr)
int arch_dcache_flush_and_invd_all(void)
Flush and Invalidate the d-cache.
int arch_dcache_invd_all(void)
Invalidate the d-cache.
void arch_icache_enable(void)
Enable the i-cache.
int arch_dcache_flush_and_invd_range(void *addr, size_t size)
Flush and Invalidate an address range in the d-cache.
void arch_dcache_enable(void)
Enable the d-cache.