/* * SPDX-License-Identifier: BSD-2-Clause * * Copyright (c) 2020 Western Digital Corporation or its affiliates. * * Authors: * Anup Patel */ #ifndef __PLATFORM_OVERRIDE_H__ #define __PLATFORM_OVERRIDE_H__ #include #include #include #include #include struct platform_override { const struct fdt_match *match_table; int (*init)(const void *fdt, int nodeoff, const struct fdt_match *match); u64 (*features)(const struct fdt_match *match); u64 (*tlbr_flush_limit)(const struct fdt_match *match); u32 (*tlb_num_entries)(const struct fdt_match *match); bool (*cold_boot_allowed)(u32 hartid, const struct fdt_match *match); int (*early_init)(bool cold_boot, const void *fdt, const struct fdt_match *match); int (*final_init)(bool cold_boot, void *fdt, const struct fdt_match *match); void (*early_exit)(const struct fdt_match *match); void (*final_exit)(const struct fdt_match *match); int (*fdt_fixup)(void *fdt, const struct fdt_match *match); int (*extensions_init)(const struct fdt_match *match, struct sbi_hart_features *hfeatures); int (*pmu_init)(const struct fdt_match *match); int (*vendor_ext_provider)(long funcid, struct sbi_trap_regs *regs, struct sbi_ecall_return *out, const struct fdt_match *match); }; bool generic_cold_boot_allowed(u32 hartid); int generic_nascent_init(void); int generic_early_init(bool cold_boot); int generic_final_init(bool cold_boot); int generic_extensions_init(struct sbi_hart_features *hfeatures); int generic_domains_init(void); int generic_pmu_init(void); uint64_t generic_pmu_xlate_to_mhpmevent(uint32_t event_idx, uint64_t data); u64 generic_tlbr_flush_limit(void); u32 generic_tlb_num_entries(void); int generic_mpxy_init(void); extern struct sbi_platform_operations generic_platform_ops; #endif