From: Sudeep.KarkadaNagesha@arm.com (Sudeep KarkadaNagesha)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v5 5/5] drivers: clocksource: add CPU PM notifier for ARM architected timer
Date: Wed, 28 Aug 2013 11:55:41 +0100 [thread overview]
Message-ID: <521DD72D.7070000@arm.com> (raw)
In-Reply-To: <1377686689-30828-6-git-send-email-Sudeep.KarkadaNagesha@arm.com>
On 28/08/13 11:44, Sudeep KarkadaNagesha wrote:
> From: Sudeep KarkadaNagesha <sudeep.karkadanagesha@arm.com>
>
> Few control settings done in architected timer as part of initialisation
> can be lost when CPU enters deeper power states. They need to be
> re-initialised when the CPU is (warm)reset again.
>
> This patch adds CPU PM notifiers to do the timer initialisation on warm
> resets. It also save the event stream divider value calculated during
> cold reset and uses the same in warm reset path.
>
Ah, forgot to update the commit log. It's now updated:
Few control settings done in architected timer as part of initialisation
can be lost when CPU enters deeper power states. They need to be
restored when the CPU is (warm)reset again.
This patch adds CPU PM notifiers to save the counter control register
when entering low power modes and restore it when CPU exits low power.
> Cc: Catalin Marinas <catalin.marinas@arm.com>
> Reviewed-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
> Reviewed-by: Will Deacon <will.deacon@arm.com>
> Signed-off-by: Sudeep KarkadaNagesha <sudeep.karkadanagesha@arm.com>
> ---
> drivers/clocksource/arm_arch_timer.c | 34 ++++++++++++++++++++++++++++++++++
> 1 file changed, 34 insertions(+)
>
> diff --git a/drivers/clocksource/arm_arch_timer.c b/drivers/clocksource/arm_arch_timer.c
> index f42bef4..ffb0bfb 100644
> --- a/drivers/clocksource/arm_arch_timer.c
> +++ b/drivers/clocksource/arm_arch_timer.c
> @@ -13,6 +13,7 @@
> #include <linux/device.h>
> #include <linux/smp.h>
> #include <linux/cpu.h>
> +#include <linux/cpu_pm.h>
> #include <linux/clockchips.h>
> #include <linux/interrupt.h>
> #include <linux/of_irq.h>
> @@ -281,6 +282,33 @@ static struct notifier_block arch_timer_cpu_nb = {
> .notifier_call = arch_timer_cpu_notify,
> };
>
> +#ifdef CONFIG_CPU_PM
> +static unsigned int saved_cntkctl;
> +static int arch_timer_cpu_pm_notify(struct notifier_block *self,
> + unsigned long action, void *hcpu)
> +{
> + if (action == CPU_PM_ENTER)
> + saved_cntkctl = arch_timer_get_cntkctl();
> + else if (action == CPU_PM_ENTER_FAILED || action == CPU_PM_EXIT)
> + arch_timer_set_cntkctl(saved_cntkctl);
> + return NOTIFY_OK;
> +}
> +
> +static struct notifier_block arch_timer_cpu_pm_notifier = {
> + .notifier_call = arch_timer_cpu_pm_notify,
> +};
> +
> +static int __init arch_timer_cpu_pm_init(void)
> +{
> + return cpu_pm_register_notifier(&arch_timer_cpu_pm_notifier);
> +}
> +#else
> +static int __init arch_timer_cpu_pm_init(void)
> +{
> + return 0;
> +}
> +#endif
> +
> static int __init arch_timer_register(void)
> {
> int err;
> @@ -330,11 +358,17 @@ static int __init arch_timer_register(void)
> if (err)
> goto out_free_irq;
>
> + err = arch_timer_cpu_pm_init();
> + if (err)
> + goto out_unreg_notify;
> +
> /* Immediately configure the timer on the boot CPU */
> arch_timer_setup(this_cpu_ptr(arch_timer_evt));
>
> return 0;
>
> +out_unreg_notify:
> + unregister_cpu_notifier(&arch_timer_cpu_nb);
> out_free_irq:
> if (arch_timer_use_virtual)
> free_percpu_irq(arch_timer_ppi[VIRT_PPI], arch_timer_evt);
>
next prev parent reply other threads:[~2013-08-28 10:55 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-28 10:44 [PATCH v5 0/5] ARM/ARM64 architected timer updates Sudeep KarkadaNagesha
2013-08-28 10:44 ` [PATCH v5 1/5] ARM/ARM64: arch_timer: add macros for bits in control register Sudeep KarkadaNagesha
2013-08-28 10:44 ` [PATCH v5 2/5] ARM: arch_timer: add support to configure and enable event stream Sudeep KarkadaNagesha
2013-08-29 11:24 ` Catalin Marinas
2013-08-28 10:44 ` [PATCH v5 3/5] ARM64: " Sudeep KarkadaNagesha
2013-08-29 11:22 ` Catalin Marinas
2013-08-28 10:44 ` [PATCH v5 4/5] drivers: clocksource: add support for ARM architected timer " Sudeep KarkadaNagesha
2013-08-29 11:19 ` Catalin Marinas
2013-08-28 10:44 ` [PATCH v5 5/5] drivers: clocksource: add CPU PM notifier for ARM architected timer Sudeep KarkadaNagesha
2013-08-28 10:55 ` Sudeep KarkadaNagesha [this message]
[not found] ` <loom.20150219T133753-438@post.gmane.org>
2015-02-19 14:16 ` Sudeep Holla
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=521DD72D.7070000@arm.com \
--to=sudeep.karkadanagesha@arm.com \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).