|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Minios-devel] [PATCH RFC 10/16] Save/Restore Support: Add suspend/resume support for timers
Signed-off-by: Bruno Alvisio <bruno.alvisio@xxxxxxxxx>
---
arch/x86/time.c | 13 +++++++++++++
include/time.h | 2 ++
kernel.c | 4 ++++
3 files changed, 19 insertions(+)
diff --git a/arch/x86/time.c b/arch/x86/time.c
index 3658142..8f79d69 100644
--- a/arch/x86/time.c
+++ b/arch/x86/time.c
@@ -244,3 +244,16 @@ void fini_time(void)
HYPERVISOR_set_timer_op(0);
unbind_evtchn(port);
}
+
+void suspend_time(void)
+{
+ /* Clear any pending timer */
+ HYPERVISOR_set_timer_op(0);
+ unbind_evtchn(port);
+}
+
+void resume_time(void)
+{
+ port = bind_virq(VIRQ_TIMER, &timer_handler, NULL);
+ unmask_evtchn(port);
+}
diff --git a/include/time.h b/include/time.h
index 5d6ed67..2e06d58 100644
--- a/include/time.h
+++ b/include/time.h
@@ -55,6 +55,8 @@ typedef long suseconds_t;
/* prototypes */
void init_time(void);
void fini_time(void);
+void suspend_time(void);
+void resume_time(void);
s_time_t get_s_time(void);
s_time_t get_v_time(void);
uint64_t monotonic_clock(void);
diff --git a/kernel.c b/kernel.c
index 782eb79..a16b1ba 100644
--- a/kernel.c
+++ b/kernel.c
@@ -120,10 +120,14 @@ void start_kernel(void* par)
void pre_suspend(void)
{
local_irq_disable();
+
+ suspend_time();
}
void post_suspend(int canceled)
{
+ resume_time();
+
local_irq_enable();
}
--
2.3.2 (Apple Git-55)
_______________________________________________
Minios-devel mailing list
Minios-devel@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/mailman/listinfo/minios-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |