All of lore.kernel.org
 help / color / mirror / Atom feed
From: Stephen Warren <swarren-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
To: Joseph Lo <josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
Cc: linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org
Subject: Re: [PATCH V3 4/8] ARM: tegra: add common LP1 suspend support
Date: Mon, 12 Aug 2013 13:24:46 -0600	[thread overview]
Message-ID: <5209367E.10900@wwwdotorg.org> (raw)
In-Reply-To: <1376300407-14750-5-git-send-email-josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>

On 08/12/2013 03:40 AM, Joseph Lo wrote:
> The LP1 suspending mode on Tegra means CPU rail off, devices and PLLs are
> clock gated and SDRAM in self-refresh mode. That means the low level LP1
> suspending and resuming code couldn't be run on DRAM and the CPU must
> switch to the always on clock domain (a.k.a. CLK_M 12MHz oscillator). And
> the system clock (SCLK) would be switched to CLK_S, a 32KHz oscillator.
> The LP1 low level handling code need to be moved to IRAM area first. And
> marking the LP1 mask for indicating the Tegra device is in LP1. The CPU
> power timer needs to be re-calculated based on 32KHz that was originally
> based on PCLK.
> 
> When resuming from LP1, the LP1 reset handler will resume PLLs and then
> put DRAM to normal mode. Then jumping to the "tegra_resume" that will
> restore full context before back to kernel. The "tegra_resume" handler
> was expected to be found in PMC_SCRATCH41 register.
> 
> This is common LP1 procedures for Tegra, so we do these jobs mainly in
> this patch:
> * moving LP1 low level handling code to IRAM
> * marking LP1 mask
> * copying the physical address of "tegra_resume" to PMC_SCRATCH41
> * re-calculate the CPU power timer based on 32KHz
> 
> Signed-off-by: Joseph Lo <josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
> ---
> V3:
> * using a "#define" of IRAM_CODE to replace original static variable

I didn't mean change the variable to a define, but rather simply to use
the IO_ADDRESS() define instead of any new define. i.e.:

> diff --git a/arch/arm/mach-tegra/pm.c b/arch/arm/mach-tegra/pm.c

> +#define IRAM_CODE IO_ADDRESS(TEGRA_IRAM_CODE_AREA)

... just don't add that, and ...

> +static void tegra_suspend_enter_lp1(void)
> +{
> +	tegra_pmc_suspend();
> +
> +	/* copy the reset vector & SDRAM shutdown code into IRAM */
> +	memcpy(iram_save_addr, IRAM_CODE, iram_save_size);
> +	memcpy(IRAM_CODE, tegra_lp1_iram.start_addr, iram_save_size);

... and s/IRAM_CODE/IO_ADDRESS(TEGRA_IRAM_CODE_AREA)/ in that code.

I'll make that fixup when applying these patches.

WARNING: multiple messages have this Message-ID (diff)
From: swarren@wwwdotorg.org (Stephen Warren)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH V3 4/8] ARM: tegra: add common LP1 suspend support
Date: Mon, 12 Aug 2013 13:24:46 -0600	[thread overview]
Message-ID: <5209367E.10900@wwwdotorg.org> (raw)
In-Reply-To: <1376300407-14750-5-git-send-email-josephl@nvidia.com>

On 08/12/2013 03:40 AM, Joseph Lo wrote:
> The LP1 suspending mode on Tegra means CPU rail off, devices and PLLs are
> clock gated and SDRAM in self-refresh mode. That means the low level LP1
> suspending and resuming code couldn't be run on DRAM and the CPU must
> switch to the always on clock domain (a.k.a. CLK_M 12MHz oscillator). And
> the system clock (SCLK) would be switched to CLK_S, a 32KHz oscillator.
> The LP1 low level handling code need to be moved to IRAM area first. And
> marking the LP1 mask for indicating the Tegra device is in LP1. The CPU
> power timer needs to be re-calculated based on 32KHz that was originally
> based on PCLK.
> 
> When resuming from LP1, the LP1 reset handler will resume PLLs and then
> put DRAM to normal mode. Then jumping to the "tegra_resume" that will
> restore full context before back to kernel. The "tegra_resume" handler
> was expected to be found in PMC_SCRATCH41 register.
> 
> This is common LP1 procedures for Tegra, so we do these jobs mainly in
> this patch:
> * moving LP1 low level handling code to IRAM
> * marking LP1 mask
> * copying the physical address of "tegra_resume" to PMC_SCRATCH41
> * re-calculate the CPU power timer based on 32KHz
> 
> Signed-off-by: Joseph Lo <josephl@nvidia.com>
> ---
> V3:
> * using a "#define" of IRAM_CODE to replace original static variable

I didn't mean change the variable to a define, but rather simply to use
the IO_ADDRESS() define instead of any new define. i.e.:

> diff --git a/arch/arm/mach-tegra/pm.c b/arch/arm/mach-tegra/pm.c

> +#define IRAM_CODE IO_ADDRESS(TEGRA_IRAM_CODE_AREA)

... just don't add that, and ...

> +static void tegra_suspend_enter_lp1(void)
> +{
> +	tegra_pmc_suspend();
> +
> +	/* copy the reset vector & SDRAM shutdown code into IRAM */
> +	memcpy(iram_save_addr, IRAM_CODE, iram_save_size);
> +	memcpy(IRAM_CODE, tegra_lp1_iram.start_addr, iram_save_size);

... and s/IRAM_CODE/IO_ADDRESS(TEGRA_IRAM_CODE_AREA)/ in that code.

I'll make that fixup when applying these patches.

  parent reply	other threads:[~2013-08-12 19:24 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-08-12  9:39 [PATCH V3 0/8] ARM: tegra: support LP1 suspend mode Joseph Lo
2013-08-12  9:39 ` Joseph Lo
     [not found] ` <1376300407-14750-1-git-send-email-josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-08-12  9:40   ` [PATCH V3 1/8] ARM: tegra: add common resume handling code for LP1 resuming Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 2/8] ARM: tegra: config the polarity of the request of sys clock Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 3/8] clk: tegra114: add LP1 suspend/resume support Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 4/8] ARM: tegra: add common LP1 suspend support Joseph Lo
2013-08-12  9:40     ` Joseph Lo
     [not found]     ` <1376300407-14750-5-git-send-email-josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-08-12 19:24       ` Stephen Warren [this message]
2013-08-12 19:24         ` Stephen Warren
     [not found]         ` <5209367E.10900-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-08-13  6:58           ` Joseph Lo
2013-08-13  6:58             ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 5/8] ARM: tegra: add LP1 suspend support for Tegra30 Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 6/8] ARM: tegra: add LP1 suspend support for Tegra20 Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 7/8] ARM: tegra: add LP1 suspend support for Tegra114 Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12  9:40   ` [PATCH V3 8/8] ARM: tegra: enable LP1 suspend mode Joseph Lo
2013-08-12  9:40     ` Joseph Lo
2013-08-12 19:40   ` [PATCH V3 0/8] ARM: tegra: support " Stephen Warren
2013-08-12 19:40     ` Stephen Warren

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=5209367E.10900@wwwdotorg.org \
    --to=swarren-3lzwwm7+weoh9zmkesr00q@public.gmane.org \
    --cc=josephl-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org \
    --cc=linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
    --cc=linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.