platform: generic: thead: separate T-Head PMU Errata

As Guo Ren said from the kernel mailing list [1], future T-Head CPUs,
including the newer versions of T-Head C908, will feature standard
Sscofpmf extension. For these CPUs, T-Head's implementation of PMU
Overflow Interrupts may not needed anymore. In this case, we shouldn't
apply T-Head PMU for all T-Head CPUs. Thus, this patch separated T-Head PMU
errata.

[1] https://lore.kernel.org/linux-riscv/Zh9sUUUT09LZb0MO@gmail.com/

Signed-off-by: Yangyu Chen <cyy@cyyself.name>
Reviewed-by: Inochi Amaoto <inochiama@outlook.com>
Reviewed-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
Yangyu Chen
2024-04-21 23:52:08 +08:00
committed by Anup Patel
parent 2b93ce0954
commit 33e21c9476
2 changed files with 7 additions and 2 deletions

View File

@@ -7,6 +7,7 @@
* stale entrie avoid incorrect memory access. * stale entrie avoid incorrect memory access.
*/ */
#define THEAD_QUIRK_ERRATA_TLB_FLUSH BIT(0) #define THEAD_QUIRK_ERRATA_TLB_FLUSH BIT(0)
#define THEAD_QUIRK_ERRATA_THEAD_PMU BIT(1)
void thead_register_tlb_flush_trap_handler(void); void thead_register_tlb_flush_trap_handler(void);

View File

@@ -33,12 +33,16 @@ static int thead_generic_early_init(bool cold_boot,
static int thead_generic_extensions_init(const struct fdt_match *match, static int thead_generic_extensions_init(const struct fdt_match *match,
struct sbi_hart_features *hfeatures) struct sbi_hart_features *hfeatures)
{ {
thead_c9xx_register_pmu_device(); struct thead_generic_quirks *quirks = (void *)match->data;
if (quirks->errata & THEAD_QUIRK_ERRATA_THEAD_PMU)
thead_c9xx_register_pmu_device();
return 0; return 0;
} }
static struct thead_generic_quirks thead_th1520_quirks = { static struct thead_generic_quirks thead_th1520_quirks = {
.errata = THEAD_QUIRK_ERRATA_TLB_FLUSH, .errata = THEAD_QUIRK_ERRATA_TLB_FLUSH | THEAD_QUIRK_ERRATA_THEAD_PMU,
}; };
static const struct fdt_match thead_generic_match[] = { static const struct fdt_match thead_generic_match[] = {