mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2025-08-30 09:56:33 +01:00
platform: generic: thead: separate implement of T-HEAD c9xx errata
Separate the implement of T-HEAD c9xx errata to allow any platform with bug related to c9xx cores can use it. Signed-off-by: Inochi Amaoto <inochiama@outlook.com> Reviewed-by: Anup Patel <anup@brainfault.org>
This commit is contained in:

committed by
Anup Patel

parent
8e941e7fe3
commit
492d9b153d
@@ -7,40 +7,34 @@
|
||||
*/
|
||||
|
||||
#include <platform_override.h>
|
||||
#include <sbi/riscv_barrier.h>
|
||||
#include <thead/c9xx_errata.h>
|
||||
#include <sbi/sbi_const.h>
|
||||
#include <sbi/sbi_platform.h>
|
||||
#include <sbi/sbi_scratch.h>
|
||||
#include <sbi/sbi_string.h>
|
||||
#include <sbi_utils/fdt/fdt_helper.h>
|
||||
|
||||
/**
|
||||
* T-HEAD board with this quirk need to execute sfence.vma to flush
|
||||
* stale entrie avoid incorrect memory access.
|
||||
*/
|
||||
#define THEAD_QUIRK_TLB_FLUSH_FIXUP BIT(0)
|
||||
|
||||
void _thead_tlb_flush_fixup_trap_handler(void);
|
||||
|
||||
void thead_register_tlb_flush_trap_handler(void)
|
||||
{
|
||||
csr_write(CSR_MTVEC, &_thead_tlb_flush_fixup_trap_handler);
|
||||
}
|
||||
struct thead_generic_quirks {
|
||||
u64 errata;
|
||||
};
|
||||
|
||||
static int thead_generic_early_init(bool cold_boot,
|
||||
const struct fdt_match *match)
|
||||
{
|
||||
unsigned long quirks = (unsigned long)match->data;
|
||||
struct thead_generic_quirks *quirks = (void *)match->data;
|
||||
|
||||
if (quirks & THEAD_QUIRK_TLB_FLUSH_FIXUP)
|
||||
if (quirks->errata & THEAD_QUIRK_ERRATA_TLB_FLUSH)
|
||||
thead_register_tlb_flush_trap_handler();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct thead_generic_quirks thead_th1520_quirks = {
|
||||
.errata = THEAD_QUIRK_ERRATA_TLB_FLUSH,
|
||||
};
|
||||
|
||||
static const struct fdt_match thead_generic_match[] = {
|
||||
{ .compatible = "thead,th1520",
|
||||
.data = (void*)THEAD_QUIRK_TLB_FLUSH_FIXUP },
|
||||
{ .compatible = "thead,th1520", .data = &thead_th1520_quirks },
|
||||
{ },
|
||||
};
|
||||
|
||||
|
Reference in New Issue
Block a user