All of lore.kernel.org
 help / color / mirror / Atom feed
From: Kevin Hilman <khilman@ti.com>
To: Santosh Shilimkar <santosh.shilimkar@ti.com>
Cc: linux-omap@vger.kernel.org, linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH 02/17] omap4: pm: Add SAR RAM support
Date: Wed, 02 Mar 2011 13:56:45 -0800	[thread overview]
Message-ID: <87vd016vaa.fsf@ti.com> (raw)
In-Reply-To: <1298112158-28469-3-git-send-email-santosh.shilimkar@ti.com> (Santosh Shilimkar's message of "Sat, 19 Feb 2011 16:12:23 +0530")

Santosh Shilimkar <santosh.shilimkar@ti.com> writes:

> This patch adds SAR RAM support on OMAP4430. SAR RAM used to save
> and restore the HW context in low power modes.
>
> Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
> Reviewed-by: Kevin Hilman <khilman@ti.com>
> ---
>  arch/arm/mach-omap2/omap4-common.c         |   25 ++++++++++++++++++++++++-
>  arch/arm/mach-omap2/omap4-sar-layout.h     |   24 ++++++++++++++++++++++++
>  arch/arm/plat-omap/include/plat/omap44xx.h |    1 +
>  3 files changed, 49 insertions(+), 1 deletions(-)
>  create mode 100644 arch/arm/mach-omap2/omap4-sar-layout.h
>
> diff --git a/arch/arm/mach-omap2/omap4-common.c b/arch/arm/mach-omap2/omap4-common.c
> index 559d227..48484a5 100644
> --- a/arch/arm/mach-omap2/omap4-common.c
> +++ b/arch/arm/mach-omap2/omap4-common.c
> @@ -23,12 +23,14 @@
>  #include <mach/omap4-common.h>
>  #include <mach/omap-wakeupgen.h>
>  
> +#include "omap4-sar-layout.h"
> +
>  #ifdef CONFIG_CACHE_L2X0
>  void __iomem *l2cache_base;
>  #endif
>  
>  void __iomem *gic_dist_base_addr;
> -
> +void __iomem *sar_ram_base;
>  
>  void __init gic_init_irq(void)
>  {
> @@ -107,3 +109,24 @@ static int __init omap_l2_cache_init(void)
>  }
>  early_initcall(omap_l2_cache_init);
>  #endif
> +
> +/*
> + * SAR RAM used to save and restore the HW
> + * context in low power modes
> + */
> +static int __init omap4_sar_ram_init(void)
> +{
> +	/*
> +	 * To avoid code running on other OMAPs in
> +	 * multi-omap builds
> +	 */
> +	if (!cpu_is_omap44xx())
> +		return -ENODEV;
> +
> +	/* Static mapping, never released */
> +	sar_ram_base = ioremap(OMAP44XX_SAR_RAM_BASE, SZ_8K);
> +	BUG_ON(!sar_ram_base);

Again, a BUG is not approprate here.

Instead, other code needs to properly handle when sar_ram_base == NULL

> +	return 0;
> +}
> +early_initcall(omap4_sar_ram_init);
> diff --git a/arch/arm/mach-omap2/omap4-sar-layout.h b/arch/arm/mach-omap2/omap4-sar-layout.h
> new file mode 100644
> index 0000000..bb66816
> --- /dev/null
> +++ b/arch/arm/mach-omap2/omap4-sar-layout.h
> @@ -0,0 +1,24 @@
> +/*
> + * omap4-sar-layout.h: OMAP4 SAR RAM layout header file
> + *
> + * Copyright (C) 2011 Texas Instruments, Inc.
> + * Santosh Shilimkar <santosh.shilimkar@ti.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + */
> +#ifndef OMAP_ARCH_OMAP4_SAR_LAYOUT_H
> +#define OMAP_ARCH_OMAP4_SAR_LAYOUT_H
> +
> +/*
> + * SAR BANK offsets from base address OMAP44XX_SAR_RAM_BASE
> + */
> +#define SAR_BANK1_OFFSET		0x0000
> +#define SAR_BANK2_OFFSET		0x1000
> +#define SAR_BANK3_OFFSET		0x2000
> +#define SAR_BANK4_OFFSET		0x3000
> +
> +extern void __iomem *sar_ram_base;

This patch creates this as global, but has no global users.

Also, personally, I don't like these 'base address as global pointer'
that are appearing throughout the OMAP4 code.  This one is continuing
the pattern of some others (gic_dist_base_addr, gic_cpu_base) etc., but
I'm not crazy about them.  BTW, the gic* ones also suffer from the BUG
problem and do not properly handle error conditions.

It would be much cleaner to keep this base address static (and local)
and just create some sar_read/write helpers that can be used from other
code.

Hmm, I see the assembly code uses this base address to.  For that, a
helper function to get the base address could be created.

Kevin


> +#endif
> diff --git a/arch/arm/plat-omap/include/plat/omap44xx.h b/arch/arm/plat-omap/include/plat/omap44xx.h
> index ea2b8a6..c0d478e 100644
> --- a/arch/arm/plat-omap/include/plat/omap44xx.h
> +++ b/arch/arm/plat-omap/include/plat/omap44xx.h
> @@ -45,6 +45,7 @@
>  #define OMAP44XX_WKUPGEN_BASE		0x48281000
>  #define OMAP44XX_MCPDM_BASE		0x40132000
>  #define OMAP44XX_MCPDM_L3_BASE		0x49032000
> +#define OMAP44XX_SAR_RAM_BASE		0x4a326000
>  
>  #define OMAP44XX_MAILBOX_BASE		(L4_44XX_BASE + 0xF4000)
>  #define OMAP44XX_HSUSB_OTG_BASE		(L4_44XX_BASE + 0xAB000)

WARNING: multiple messages have this Message-ID (diff)
From: khilman@ti.com (Kevin Hilman)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 02/17] omap4: pm: Add SAR RAM support
Date: Wed, 02 Mar 2011 13:56:45 -0800	[thread overview]
Message-ID: <87vd016vaa.fsf@ti.com> (raw)
In-Reply-To: <1298112158-28469-3-git-send-email-santosh.shilimkar@ti.com> (Santosh Shilimkar's message of "Sat, 19 Feb 2011 16:12:23 +0530")

Santosh Shilimkar <santosh.shilimkar@ti.com> writes:

> This patch adds SAR RAM support on OMAP4430. SAR RAM used to save
> and restore the HW context in low power modes.
>
> Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
> Reviewed-by: Kevin Hilman <khilman@ti.com>
> ---
>  arch/arm/mach-omap2/omap4-common.c         |   25 ++++++++++++++++++++++++-
>  arch/arm/mach-omap2/omap4-sar-layout.h     |   24 ++++++++++++++++++++++++
>  arch/arm/plat-omap/include/plat/omap44xx.h |    1 +
>  3 files changed, 49 insertions(+), 1 deletions(-)
>  create mode 100644 arch/arm/mach-omap2/omap4-sar-layout.h
>
> diff --git a/arch/arm/mach-omap2/omap4-common.c b/arch/arm/mach-omap2/omap4-common.c
> index 559d227..48484a5 100644
> --- a/arch/arm/mach-omap2/omap4-common.c
> +++ b/arch/arm/mach-omap2/omap4-common.c
> @@ -23,12 +23,14 @@
>  #include <mach/omap4-common.h>
>  #include <mach/omap-wakeupgen.h>
>  
> +#include "omap4-sar-layout.h"
> +
>  #ifdef CONFIG_CACHE_L2X0
>  void __iomem *l2cache_base;
>  #endif
>  
>  void __iomem *gic_dist_base_addr;
> -
> +void __iomem *sar_ram_base;
>  
>  void __init gic_init_irq(void)
>  {
> @@ -107,3 +109,24 @@ static int __init omap_l2_cache_init(void)
>  }
>  early_initcall(omap_l2_cache_init);
>  #endif
> +
> +/*
> + * SAR RAM used to save and restore the HW
> + * context in low power modes
> + */
> +static int __init omap4_sar_ram_init(void)
> +{
> +	/*
> +	 * To avoid code running on other OMAPs in
> +	 * multi-omap builds
> +	 */
> +	if (!cpu_is_omap44xx())
> +		return -ENODEV;
> +
> +	/* Static mapping, never released */
> +	sar_ram_base = ioremap(OMAP44XX_SAR_RAM_BASE, SZ_8K);
> +	BUG_ON(!sar_ram_base);

Again, a BUG is not approprate here.

Instead, other code needs to properly handle when sar_ram_base == NULL

> +	return 0;
> +}
> +early_initcall(omap4_sar_ram_init);
> diff --git a/arch/arm/mach-omap2/omap4-sar-layout.h b/arch/arm/mach-omap2/omap4-sar-layout.h
> new file mode 100644
> index 0000000..bb66816
> --- /dev/null
> +++ b/arch/arm/mach-omap2/omap4-sar-layout.h
> @@ -0,0 +1,24 @@
> +/*
> + * omap4-sar-layout.h: OMAP4 SAR RAM layout header file
> + *
> + * Copyright (C) 2011 Texas Instruments, Inc.
> + * Santosh Shilimkar <santosh.shilimkar@ti.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + */
> +#ifndef OMAP_ARCH_OMAP4_SAR_LAYOUT_H
> +#define OMAP_ARCH_OMAP4_SAR_LAYOUT_H
> +
> +/*
> + * SAR BANK offsets from base address OMAP44XX_SAR_RAM_BASE
> + */
> +#define SAR_BANK1_OFFSET		0x0000
> +#define SAR_BANK2_OFFSET		0x1000
> +#define SAR_BANK3_OFFSET		0x2000
> +#define SAR_BANK4_OFFSET		0x3000
> +
> +extern void __iomem *sar_ram_base;

This patch creates this as global, but has no global users.

Also, personally, I don't like these 'base address as global pointer'
that are appearing throughout the OMAP4 code.  This one is continuing
the pattern of some others (gic_dist_base_addr, gic_cpu_base) etc., but
I'm not crazy about them.  BTW, the gic* ones also suffer from the BUG
problem and do not properly handle error conditions.

It would be much cleaner to keep this base address static (and local)
and just create some sar_read/write helpers that can be used from other
code.

Hmm, I see the assembly code uses this base address to.  For that, a
helper function to get the base address could be created.

Kevin


> +#endif
> diff --git a/arch/arm/plat-omap/include/plat/omap44xx.h b/arch/arm/plat-omap/include/plat/omap44xx.h
> index ea2b8a6..c0d478e 100644
> --- a/arch/arm/plat-omap/include/plat/omap44xx.h
> +++ b/arch/arm/plat-omap/include/plat/omap44xx.h
> @@ -45,6 +45,7 @@
>  #define OMAP44XX_WKUPGEN_BASE		0x48281000
>  #define OMAP44XX_MCPDM_BASE		0x40132000
>  #define OMAP44XX_MCPDM_L3_BASE		0x49032000
> +#define OMAP44XX_SAR_RAM_BASE		0x4a326000
>  
>  #define OMAP44XX_MAILBOX_BASE		(L4_44XX_BASE + 0xF4000)
>  #define OMAP44XX_HSUSB_OTG_BASE		(L4_44XX_BASE + 0xAB000)

  reply	other threads:[~2011-03-02 21:56 UTC|newest]

Thread overview: 110+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-02-19 10:42 [PATCH 00/17] omap4: pm: suspend, hotplug and cpuilde support Santosh Shilimkar
2011-02-19 10:42 ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 01/17] omap4: pm: Add omap WakeupGen module support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 21:47   ` Kevin Hilman
2011-03-02 21:47     ` Kevin Hilman
2011-03-03 16:04     ` Santosh Shilimkar
2011-03-03 16:04       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 02/17] omap4: pm: Add SAR RAM support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 21:56   ` Kevin Hilman [this message]
2011-03-02 21:56     ` Kevin Hilman
2011-03-03 16:08     ` Santosh Shilimkar
2011-03-03 16:08       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 03/17] omap4: Export scu base address Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 21:58   ` Kevin Hilman
2011-03-02 21:58     ` Kevin Hilman
2011-03-03 16:09     ` Santosh Shilimkar
2011-03-03 16:09       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 04/17] omap4: pm: Add CPUx OFF mode support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:12   ` Kevin Hilman
2011-03-02 22:12     ` Kevin Hilman
2011-03-03 16:14     ` Santosh Shilimkar
2011-03-03 16:14       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 05/17] omap4: pm: Initialise all the clockdomains to supported states Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:17   ` Kevin Hilman
2011-03-02 22:17     ` Kevin Hilman
2011-03-03 16:14     ` Santosh Shilimkar
2011-03-03 16:14       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 06/17] omap4: pm: Program CPU1 to hit OFF when off-lined Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 07/17] omap4: pm: CPU1 wakeup workaround form Low power modes Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:23   ` Kevin Hilman
2011-03-02 22:23     ` Kevin Hilman
2011-03-03 16:15     ` Santosh Shilimkar
2011-03-03 16:15       ` Santosh Shilimkar
2011-03-02 23:44   ` Kevin Hilman
2011-03-02 23:44     ` Kevin Hilman
2011-02-19 10:42 ` [PATCH 08/17] omap4: pm: Add GIC save/restore support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:29   ` Kevin Hilman
2011-03-02 22:29     ` Kevin Hilman
2011-03-03 16:29     ` Santosh Shilimkar
2011-03-03 16:29       ` Santosh Shilimkar
2011-03-03 17:03       ` Kevin Hilman
2011-03-03 17:03         ` Kevin Hilman
2011-03-04  8:39     ` Santosh Shilimkar
2011-03-04  8:39       ` Santosh Shilimkar
2011-03-04 16:11       ` Kevin Hilman
2011-03-04 16:11         ` Kevin Hilman
2011-03-04 16:14         ` Santosh Shilimkar
2011-03-04 16:14           ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 09/17] omap4: pm: Add WakeupGen " Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:34   ` Kevin Hilman
2011-03-02 22:34     ` Kevin Hilman
2011-02-19 10:42 ` [PATCH 10/17] omap4: pm: Add L2 cache lowpower support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:36   ` Kevin Hilman
2011-03-02 22:36     ` Kevin Hilman
2011-03-03 16:30     ` Santosh Shilimkar
2011-03-03 16:30       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 11/17] omap4: suspend: Add MPUSS RET and OFF support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:45   ` Kevin Hilman
2011-03-02 22:45     ` Kevin Hilman
2011-03-03 16:31     ` Santosh Shilimkar
2011-03-03 16:31       ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 12/17] omap4: pm-debug: Add wakeup timer and debug counters Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:51   ` Kevin Hilman
2011-03-02 22:51     ` Kevin Hilman
2011-03-03 16:34     ` Santosh Shilimkar
2011-03-03 16:34       ` Santosh Shilimkar
2011-03-03 17:05       ` Kevin Hilman
2011-03-03 17:05         ` Kevin Hilman
2011-03-04  6:26         ` Santosh Shilimkar
2011-03-04  6:26           ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 13/17] omap4: cpuidle: Basic CPUidle support Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 22:55   ` Kevin Hilman
2011-03-02 22:55     ` Kevin Hilman
2011-02-19 10:42 ` [PATCH 14/17] omap4: cpuidle: Add MPUSS RET OFF states Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-02-21 10:19   ` Jean Pihet
2011-02-21 10:19     ` Jean Pihet
2011-02-21 10:26     ` Santosh Shilimkar
2011-02-21 10:26       ` Santosh Shilimkar
2011-02-21 14:01       ` Santosh Shilimkar
2011-02-21 14:01         ` Santosh Shilimkar
2011-03-02 23:32   ` Kevin Hilman
2011-03-02 23:32     ` Kevin Hilman
2011-02-19 10:42 ` [PATCH 15/17] omap4: cpuidle: Switch to gptimer from twd in deeper C-states Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-02-19 10:42 ` [PATCH 16/17] omap4: cpuidle: Allow debugfs control through enable_off_mode Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 23:43   ` Kevin Hilman
2011-03-02 23:43     ` Kevin Hilman
2011-02-19 10:42 ` [PATCH 17/17] omap4: Remove un-used do_wfi() macro Santosh Shilimkar
2011-02-19 10:42   ` Santosh Shilimkar
2011-03-02 23:46 ` [PATCH 00/17] omap4: pm: suspend, hotplug and cpuilde support Kevin Hilman
2011-03-02 23:46   ` Kevin Hilman
2011-03-03  7:20   ` Santosh Shilimkar
2011-03-03  7:20     ` Santosh Shilimkar
2011-03-04 17:20   ` Santosh Shilimkar
2011-03-04 17:20     ` Santosh Shilimkar

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=87vd016vaa.fsf@ti.com \
    --to=khilman@ti.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=santosh.shilimkar@ti.com \
    /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.