mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2026-02-06 00:45:22 +08:00
[dm][hwcache] support hwcache (#11049)
Some ARCH not has std cache ops, such as RISC-V Signed-off-by: GuEe-GUI <2991707448@qq.com>
This commit is contained in:
@@ -30,6 +30,7 @@ rsource "ata/Kconfig"
|
||||
rsource "nvme/Kconfig"
|
||||
rsource "block/Kconfig"
|
||||
rsource "scsi/Kconfig"
|
||||
rsource "hwcache/Kconfig"
|
||||
rsource "regulator/Kconfig"
|
||||
rsource "reset/Kconfig"
|
||||
rsource "pmdomain/Kconfig"
|
||||
|
||||
9
components/drivers/hwcache/Kconfig
Normal file
9
components/drivers/hwcache/Kconfig
Normal file
@@ -0,0 +1,9 @@
|
||||
menuconfig RT_USING_HWCACHE
|
||||
bool "Using Hardware Cache device drivers"
|
||||
depends on RT_USING_DM
|
||||
depends on RT_USING_CACHE
|
||||
default n
|
||||
|
||||
if RT_USING_HWCACHE
|
||||
osource "$(SOC_DM_HWCACHE_DIR)/Kconfig"
|
||||
endif
|
||||
15
components/drivers/hwcache/SConscript
Normal file
15
components/drivers/hwcache/SConscript
Normal file
@@ -0,0 +1,15 @@
|
||||
from building import *
|
||||
|
||||
group = []
|
||||
|
||||
if not GetDepend(['RT_USING_HWCACHE']):
|
||||
Return('group')
|
||||
|
||||
cwd = GetCurrentDir()
|
||||
CPPPATH = [cwd + '/../include']
|
||||
|
||||
src = ['hwcache.c']
|
||||
|
||||
group = DefineGroup('DeviceDrivers', src, depend = [''], CPPPATH = CPPPATH)
|
||||
|
||||
Return('group')
|
||||
139
components/drivers/hwcache/hwcache.c
Normal file
139
components/drivers/hwcache/hwcache.c
Normal file
@@ -0,0 +1,139 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2023, RT-Thread Development Team
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2023-02-25 GuEe-GUI the first version
|
||||
*/
|
||||
|
||||
#include <drivers/hwcache.h>
|
||||
|
||||
#define DBG_TAG "rtdm.hwcache"
|
||||
#define DBG_LVL DBG_INFO
|
||||
#include <rtdbg.h>
|
||||
|
||||
struct rt_hwcache_ops *rt_dm_cpu_dcache_ops = RT_NULL;
|
||||
struct rt_hwcache_ops *rt_dm_cpu_icache_ops = RT_NULL;
|
||||
|
||||
static void hwcache_enable(struct rt_hwcache_ops *ops)
|
||||
{
|
||||
if (ops && ops->enable)
|
||||
{
|
||||
ops->enable();
|
||||
}
|
||||
}
|
||||
|
||||
static void hwcache_disable(struct rt_hwcache_ops *ops)
|
||||
{
|
||||
if (ops && ops->enable)
|
||||
{
|
||||
ops->enable();
|
||||
}
|
||||
}
|
||||
|
||||
static rt_base_t hwcache_status(struct rt_hwcache_ops *ops)
|
||||
{
|
||||
if (ops && ops->status)
|
||||
{
|
||||
return ops->status();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void hwcache_ops(struct rt_hwcache_ops *ops, int op, void *addr, int size)
|
||||
{
|
||||
if (ops)
|
||||
{
|
||||
if (op == RT_HW_CACHE_FLUSH)
|
||||
{
|
||||
if (ops->flush)
|
||||
{
|
||||
ops->flush(addr, size);
|
||||
}
|
||||
}
|
||||
else if (op == RT_HW_CACHE_INVALIDATE)
|
||||
{
|
||||
if (ops->invalidate)
|
||||
{
|
||||
ops->invalidate(addr, size);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void rt_hwcache_icache_enable(void)
|
||||
{
|
||||
hwcache_enable(rt_dm_cpu_icache_ops);
|
||||
}
|
||||
|
||||
void rt_hwcache_icache_disable(void)
|
||||
{
|
||||
hwcache_disable(rt_dm_cpu_icache_ops);
|
||||
}
|
||||
|
||||
rt_base_t rt_hwcache_icache_status(void)
|
||||
{
|
||||
return hwcache_status(rt_dm_cpu_icache_ops);
|
||||
}
|
||||
|
||||
void rt_hwcache_icache_ops(int ops, void *addr, int size)
|
||||
{
|
||||
hwcache_ops(rt_dm_cpu_icache_ops, ops, addr, size);
|
||||
}
|
||||
|
||||
void rt_hwcache_dcache_enable(void)
|
||||
{
|
||||
hwcache_enable(rt_dm_cpu_dcache_ops);
|
||||
}
|
||||
|
||||
void rt_hwcache_dcache_disable(void)
|
||||
{
|
||||
hwcache_disable(rt_dm_cpu_dcache_ops);
|
||||
}
|
||||
|
||||
rt_base_t rt_hwcache_dcache_status(void)
|
||||
{
|
||||
return hwcache_status(rt_dm_cpu_dcache_ops);
|
||||
}
|
||||
|
||||
void rt_hwcache_dcache_ops(int ops, void *addr, int size)
|
||||
{
|
||||
hwcache_ops(rt_dm_cpu_dcache_ops, ops, addr, size);
|
||||
}
|
||||
|
||||
#ifdef RT_USING_OFW
|
||||
RT_OFW_STUB_RANGE_EXPORT(hwcache, _hwcache_ofw_start, _hwcache_ofw_end);
|
||||
|
||||
static rt_err_t ofw_hwcache_init(void)
|
||||
{
|
||||
struct rt_ofw_node *cache_np;
|
||||
|
||||
rt_ofw_foreach_allnodes(cache_np)
|
||||
{
|
||||
rt_ofw_stub_probe_range(cache_np, &_hwcache_ofw_start, &_hwcache_ofw_end);
|
||||
}
|
||||
|
||||
return RT_EOK;
|
||||
}
|
||||
#else
|
||||
static rt_err_t ofw_hwcache_init(void)
|
||||
{
|
||||
return RT_EOK;
|
||||
}
|
||||
#endif /* !RT_USING_OFW */
|
||||
|
||||
rt_err_t rt_hwcache_init(void)
|
||||
{
|
||||
rt_err_t err;
|
||||
|
||||
LOG_D("init start");
|
||||
|
||||
err = ofw_hwcache_init();
|
||||
|
||||
LOG_D("init end");
|
||||
|
||||
return err;
|
||||
}
|
||||
48
components/drivers/include/drivers/hwcache.h
Normal file
48
components/drivers/include/drivers/hwcache.h
Normal file
@@ -0,0 +1,48 @@
|
||||
/*
|
||||
* Copyright (c) 2006-2023, RT-Thread Development Team
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* Change Logs:
|
||||
* Date Author Notes
|
||||
* 2023-02-25 GuEe-GUI the first version
|
||||
*/
|
||||
|
||||
#ifndef __HWCACHE_H__
|
||||
#define __HWCACHE_H__
|
||||
|
||||
#include <rthw.h>
|
||||
#include <rtthread.h>
|
||||
#include <drivers/ofw.h>
|
||||
|
||||
struct rt_hwcache_ops
|
||||
{
|
||||
const char *name;
|
||||
|
||||
void (*enable)(void);
|
||||
void (*disable)(void);
|
||||
|
||||
rt_base_t (*status)(void);
|
||||
|
||||
void (*flush)(void *vaddr, rt_size_t size);
|
||||
void (*invalidate)(void *vaddr, rt_size_t size);
|
||||
};
|
||||
|
||||
extern struct rt_hwcache_ops *rt_dm_cpu_dcache_ops;
|
||||
extern struct rt_hwcache_ops *rt_dm_cpu_icache_ops;
|
||||
|
||||
#define RT_HWCACHE_OFW_DECLARE(name, ids, handler) RT_OFW_STUB_EXPORT(name, ids, hwcache, handler)
|
||||
|
||||
void rt_hwcache_icache_enable(void);
|
||||
void rt_hwcache_icache_disable(void);
|
||||
rt_base_t rt_hwcache_icache_status(void);
|
||||
void rt_hwcache_icache_ops(int ops, void *addr, int size);
|
||||
|
||||
void rt_hwcache_dcache_enable(void);
|
||||
void rt_hwcache_dcache_disable(void);
|
||||
rt_base_t rt_hwcache_dcache_status(void);
|
||||
void rt_hwcache_dcache_ops(int ops, void *addr, int size);
|
||||
|
||||
rt_err_t rt_hwcache_init(void);
|
||||
|
||||
#endif /* __HWCACHE_H__ */
|
||||
@@ -130,6 +130,10 @@ extern "C" {
|
||||
#include "drivers/thermal.h"
|
||||
#endif /* RT_USING_THERMAL */
|
||||
|
||||
#ifdef RT_USING_HWCACHE
|
||||
#include "drivers/hwcache.h"
|
||||
#endif /* RT_USING_HWCACHE */
|
||||
|
||||
#ifdef RT_USING_NVMEM
|
||||
#include "drivers/nvmem.h"
|
||||
#endif /* RT_USING_NVMEM */
|
||||
|
||||
Reference in New Issue
Block a user