summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorSamuel Holland <samuel@sholland.org>2022-06-13 04:03:47 +0300
committerAnup Patel <anup@brainfault.org>2022-06-13 09:24:06 +0300
commitb20ed9febe0b78228055ce69d8e3fbb13f64f1cc (patch)
treee1d0a3f7dfcf5342ec85d1e0f786e6a90a7e5f68 /lib
parentce1d6188a2169c7771af1189cc8332e7a394cd19 (diff)
downloadopensbi-b20ed9febe0b78228055ce69d8e3fbb13f64f1cc.tar.xz
lib: sbi_hsm: Call a device hook during hart resume
Non-retentive suspend states may require platform-specific actions during resume. For example, firmware may need to save and restore the values of custom CSRs. Add a hook to support this. Reviewed-by: Anup Patel <anup@brainfault.org> Signed-off-by: Samuel Holland <samuel@sholland.org>
Diffstat (limited to 'lib')
-rw-r--r--lib/sbi/sbi_hsm.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/sbi/sbi_hsm.c b/lib/sbi/sbi_hsm.c
index c4d2c6d..a7b6a80 100644
--- a/lib/sbi/sbi_hsm.c
+++ b/lib/sbi/sbi_hsm.c
@@ -178,6 +178,12 @@ static int hsm_device_hart_suspend(u32 suspend_type, ulong raddr)
return SBI_ENOTSUPP;
}
+static void hsm_device_hart_resume(void)
+{
+ if (hsm_dev && hsm_dev->hart_resume)
+ hsm_dev->hart_resume();
+}
+
int sbi_hsm_init(struct sbi_scratch *scratch, u32 hartid, bool cold_boot)
{
u32 i;
@@ -384,6 +390,8 @@ void sbi_hsm_hart_resume_start(struct sbi_scratch *scratch)
__func__, oldstate);
sbi_hart_hang();
}
+
+ hsm_device_hart_resume();
}
void sbi_hsm_hart_resume_finish(struct sbi_scratch *scratch)