aboutsummaryrefslogtreecommitdiff
path: root/lib/sbi/sbi_hart.c
diff options
context:
space:
mode:
authorAtish Patra <atish.patra@wdc.com>2020-05-09 16:47:27 -0700
committerAnup Patel <anup@brainfault.org>2020-05-10 10:02:49 +0530
commit6a053f6e6cb4db8a291239e882e9a778c2738e0a (patch)
treed4f6d52c7b486c51860c5a9eb9f96d5d176bef87 /lib/sbi/sbi_hart.c
parent79d0fadb0681acbba55bb6b4afcd3c2e6f725928 (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.c23
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);