diff --git a/kernel/irq/pm.c b/kernel/irq/pm.c index d6961d3c6f9e..15a095aaf63a 100644 --- a/kernel/irq/pm.c +++ b/kernel/irq/pm.c @@ -10,6 +10,7 @@ #include #include #include +#include #include "internals.h" @@ -21,6 +22,7 @@ bool irq_pm_check_wakeup(struct irq_desc *desc) desc->depth++; irq_disable(desc); pm_system_irq_wakeup(irq_desc_get_irq(desc)); + log_wakeup_reason(irq_desc_get_irq(desc)); return true; } return false; diff --git a/kernel/power/suspend.c b/kernel/power/suspend.c index 376a39f0ee44..ac07ca6def99 100644 --- a/kernel/power/suspend.c +++ b/kernel/power/suspend.c @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include @@ -769,6 +770,18 @@ static int enter_state(suspend_state_t state) return error; } +static void pm_suspend_marker(char *annotation) +{ + struct timespec ts; + struct rtc_time tm; + + getnstimeofday(&ts); + rtc_time_to_tm(ts.tv_sec, &tm); + pr_info("suspend %s %d-%02d-%02d %02d:%02d:%02d.%09lu UTC\n", + annotation, tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday, + tm.tm_hour, tm.tm_min, tm.tm_sec, ts.tv_nsec); +} + /** * pm_suspend - Externally visible function for suspending the system. * @state: System sleep state to enter. @@ -783,6 +796,7 @@ int pm_suspend(suspend_state_t state) if (state <= PM_SUSPEND_ON || state >= PM_SUSPEND_MAX) return -EINVAL; + pm_suspend_marker("entry"); pr_info("suspend entry (%s)\n", mem_sleep_labels[state]); #ifdef CONFIG_PM_SLEEP_MONITOR @@ -801,6 +815,7 @@ int pm_suspend(suspend_state_t state) stop_suspend_mon(); #endif + pm_suspend_marker("exit"); pr_info("suspend exit\n"); return error; } diff --git a/kernel/time/timekeeping_debug.c b/kernel/time/timekeeping_debug.c index 238e4be60229..6df6ac73d6fc 100644 --- a/kernel/time/timekeeping_debug.c +++ b/kernel/time/timekeeping_debug.c @@ -76,7 +76,7 @@ void tk_debug_account_sleep_time(const struct timespec64 *t) int bin = min(fls(t->tv_sec), NUM_BINS-1); sleep_time_bin[bin]++; - pm_deferred_pr_dbg("Timekeeping suspended for %lld.%03lu seconds\n", + pr_info("Suspended for %lld.%03lu seconds\n", (s64)t->tv_sec, t->tv_nsec / NSEC_PER_MSEC); }