diff options
author | Samuel Holland <samuel@sholland.org> | 2022-06-13 04:03:47 +0300 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2022-06-13 09:24:06 +0300 |
commit | b20ed9febe0b78228055ce69d8e3fbb13f64f1cc (patch) | |
tree | e1d0a3f7dfcf5342ec85d1e0f786e6a90a7e5f68 /lib | |
parent | ce1d6188a2169c7771af1189cc8332e7a394cd19 (diff) | |
download | opensbi-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.c | 8 |
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) |