mirror of
https://github.com/riscv-software-src/opensbi
synced 2025-11-05 06:20:21 +00:00
The current RISC-V CMO only defines how to flush a cache block. However, certain use cases, such as power management, may require flushing the entire cache. Therefore, a framework is being introduced to allow vendors to flush the entire cache using their own methods. Signed-off-by: Nick Hu <nick.hu@sifive.com> Reviewed-by: Samuel Holland <samuel.holland@sifive.com> Reviewed-by: Anup Patel <anup@brainfault.org> Link: https://lore.kernel.org/r/20251020-cache-upstream-v7-1-69a132447d8a@sifive.com Signed-off-by: Anup Patel <anup@brainfault.org>
47 lines
740 B
C
47 lines
740 B
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2025 SiFive Inc.
|
|
*/
|
|
|
|
#include <sbi/sbi_error.h>
|
|
#include <sbi_utils/cache/cache.h>
|
|
|
|
static SBI_LIST_HEAD(cache_list);
|
|
|
|
struct cache_device *cache_find(u32 id)
|
|
{
|
|
struct cache_device *dev;
|
|
|
|
sbi_list_for_each_entry(dev, &cache_list, node) {
|
|
if (dev->id == id)
|
|
return dev;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
int cache_add(struct cache_device *dev)
|
|
{
|
|
if (!dev)
|
|
return SBI_ENODEV;
|
|
|
|
if (cache_find(dev->id))
|
|
return SBI_EALREADY;
|
|
|
|
sbi_list_add(&dev->node, &cache_list);
|
|
|
|
return SBI_OK;
|
|
}
|
|
|
|
int cache_flush_all(struct cache_device *dev)
|
|
{
|
|
if (!dev)
|
|
return SBI_ENODEV;
|
|
|
|
if (!dev->ops || !dev->ops->cache_flush_all)
|
|
return SBI_ENOTSUPP;
|
|
|
|
return dev->ops->cache_flush_all(dev);
|
|
}
|