diff options
author | Atish Patra <atish.patra@wdc.com> | 2020-05-09 16:47:27 -0700 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2020-05-10 10:02:49 +0530 |
commit | 6a053f6e6cb4db8a291239e882e9a778c2738e0a (patch) | |
tree | d4f6d52c7b486c51860c5a9eb9f96d5d176bef87 /lib/sbi/sbi_hart.c | |
parent | 79d0fadb0681acbba55bb6b4afcd3c2e6f725928 (diff) |
lib: Add support for hart specific features
There may be some features which are hart specific rather than a platform
specific feature. Add a framework to support that.
Signed-off-by: Atish Patra <atish.patra@wdc.com>
Tested-by: Jonathan Balkind <jbalkind@cs.princeton.edu>
Reviewed-by: Anup Patel <anup.patel@wdc.com>
Diffstat (limited to 'lib/sbi/sbi_hart.c')
-rw-r--r-- | lib/sbi/sbi_hart.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c index b789900..cf3e9fb 100644 --- a/lib/sbi/sbi_hart.c +++ b/lib/sbi/sbi_hart.c @@ -22,6 +22,7 @@ extern void __sbi_expected_trap(void); extern void __sbi_expected_trap_hext(void); void (*sbi_hart_expected_trap)(void) = &__sbi_expected_trap; +static unsigned long hart_features_offset; static void mstatus_init(struct sbi_scratch *scratch, u32 hartid) { @@ -209,14 +210,36 @@ static int pmp_init(struct sbi_scratch *scratch, u32 hartid) return 0; } +bool sbi_hart_has_feature(u32 hartid, unsigned long feature) +{ + unsigned long *hart_features; + struct sbi_scratch *scratch; + + scratch = sbi_hartid_to_scratch(hartid); + hart_features = sbi_scratch_offset_ptr(scratch, hart_features_offset); + + if (*hart_features & feature) + return true; + else + return false; +} + int sbi_hart_init(struct sbi_scratch *scratch, u32 hartid, bool cold_boot) { int rc; + unsigned long *hart_features; if (cold_boot) { if (misa_extension('H')) sbi_hart_expected_trap = &__sbi_expected_trap_hext; + hart_features_offset = sbi_scratch_alloc_offset( + sizeof(hart_features), + "HART_FEATURES"); + if (!hart_features_offset) + return SBI_ENOMEM; } + hart_features = sbi_scratch_offset_ptr(scratch, hart_features_offset); + *hart_features = 0; mstatus_init(scratch, hartid); |