mirror of
https://gitee.com/bianbu-linux/opensbi
synced 2025-04-24 23:07:08 -04:00
97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2020 Western Digital Corporation or its affiliates.
|
|
*
|
|
* Authors:
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
* Atish Patra <atish.patra@wdc.com>
|
|
*/
|
|
|
|
#include <sbi/sbi_ecall.h>
|
|
#include <sbi/sbi_ecall_interface.h>
|
|
#include <sbi/sbi_error.h>
|
|
#include <sbi/sbi_trap.h>
|
|
#include <sbi/sbi_version.h>
|
|
#include <sbi/riscv_asm.h>
|
|
#if defined(CONFIG_PLATFORM_SPACEMIT_K1PRO) || defined(CONFIG_PLATFORM_SPACEMIT_K1X)
|
|
#include <sbi_utils/cache/cacheflush.h>
|
|
#endif
|
|
|
|
static int sbi_ecall_base_probe(unsigned long extid, unsigned long *out_val)
|
|
{
|
|
struct sbi_ecall_extension *ext;
|
|
|
|
ext = sbi_ecall_find_extension(extid);
|
|
if (!ext) {
|
|
*out_val = 0;
|
|
return 0;
|
|
}
|
|
|
|
if (ext->probe)
|
|
return ext->probe(extid, out_val);
|
|
|
|
*out_val = 1;
|
|
return 0;
|
|
}
|
|
|
|
static int sbi_ecall_base_handler(unsigned long extid, unsigned long funcid,
|
|
const struct sbi_trap_regs *regs,
|
|
unsigned long *out_val,
|
|
struct sbi_trap_info *out_trap)
|
|
{
|
|
int ret = 0;
|
|
|
|
switch (funcid) {
|
|
case SBI_EXT_BASE_GET_SPEC_VERSION:
|
|
*out_val = (SBI_ECALL_VERSION_MAJOR <<
|
|
SBI_SPEC_VERSION_MAJOR_OFFSET) &
|
|
(SBI_SPEC_VERSION_MAJOR_MASK <<
|
|
SBI_SPEC_VERSION_MAJOR_OFFSET);
|
|
*out_val = *out_val | SBI_ECALL_VERSION_MINOR;
|
|
break;
|
|
case SBI_EXT_BASE_GET_IMP_ID:
|
|
*out_val = sbi_ecall_get_impid();
|
|
break;
|
|
case SBI_EXT_BASE_GET_IMP_VERSION:
|
|
*out_val = OPENSBI_VERSION;
|
|
break;
|
|
case SBI_EXT_BASE_GET_MVENDORID:
|
|
*out_val = csr_read(CSR_MVENDORID);
|
|
break;
|
|
case SBI_EXT_BASE_GET_MARCHID:
|
|
*out_val = csr_read(CSR_MARCHID);
|
|
break;
|
|
case SBI_EXT_BASE_GET_MIMPID:
|
|
*out_val = csr_read(CSR_MIMPID);
|
|
break;
|
|
#if defined(CONFIG_PLATFORM_SPACEMIT_K1PRO) || defined(CONFIG_PLATFORM_SPACEMIT_K1X)
|
|
case SBI_EXT_BASE_FLUSH_CACHE_ALL:
|
|
csi_flush_dcache_all();
|
|
/* there has no need to flush l2 cache here */
|
|
/* csi_flush_l2_cache(); */
|
|
break;
|
|
#endif
|
|
case SBI_EXT_BASE_PROBE_EXT:
|
|
ret = sbi_ecall_base_probe(regs->a0, out_val);
|
|
break;
|
|
default:
|
|
ret = SBI_ENOTSUPP;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
struct sbi_ecall_extension ecall_base;
|
|
|
|
static int sbi_ecall_base_register_extensions(void)
|
|
{
|
|
return sbi_ecall_register_extension(&ecall_base);
|
|
}
|
|
|
|
struct sbi_ecall_extension ecall_base = {
|
|
.extid_start = SBI_EXT_BASE,
|
|
.extid_end = SBI_EXT_BASE,
|
|
.register_extensions = sbi_ecall_base_register_extensions,
|
|
.handle = sbi_ecall_base_handler,
|
|
};
|