Files
zephyr/drivers/cache/cache_nxp_lmem_cache.c
Holt Sun e179f48a8c drivers: cache: add NXP LMEM cache driver
Add LMEM cache driver implementing instruction cache ops.
Wire driver into cache Kconfig menu and CMake build.
Enables I-cache control on SoCs with NXP LMEM controller.

Signed-off-by: Holt Sun <holt.sun@nxp.com>
2025-12-03 11:41:13 +01:00

63 lines
992 B
C

/*
* Copyright 2025 NXP
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/kernel.h>
#include <zephyr/drivers/cache.h>
#include <zephyr/logging/log.h>
#include <fsl_cache.h>
void cache_instr_enable(void)
{
L1CACHE_EnableCodeCache();
}
void cache_instr_disable(void)
{
L1CACHE_DisableCodeCache();
}
int cache_instr_flush_all(void)
{
L1CACHE_CleanCodeCache();
return 0;
}
int cache_instr_invd_all(void)
{
L1CACHE_InvalidateCodeCache();
return 0;
}
int cache_instr_flush_and_invd_all(void)
{
L1CACHE_CleanInvalidateCodeCache();
return 0;
}
int cache_instr_flush_range(void *addr, size_t size)
{
L1CACHE_CleanCodeCacheByRange((uint32_t)addr, (uint32_t)size);
return 0;
}
int cache_instr_invd_range(void *addr, size_t size)
{
L1CACHE_InvalidateCodeCacheByRange((uint32_t)addr, (uint32_t)size);
return 0;
}
int cache_instr_flush_and_invd_range(void *addr, size_t size)
{
L1CACHE_CleanInvalidateCodeCacheByRange((uint32_t)addr, (uint32_t)size);
return 0;
}