Thread (20 messages) 20 messages, 4 authors, 2015-01-31

[PATCH v5 05/13] pm: at91: move the copying the sram function to the sram initializationi phase

From: Sergei Shtylyov <hidden>
Date: 2015-01-30 11:20:53
Also in: lkml

Hello.

On 1/30/2015 9:54 AM, Yang, Wenyou wrote:
Thank you for your review and suggestion.
    Not at all.
quoted
-----Original Message-----
From: Sergei Shtylyov [mailto:sergei.shtylyov at cogentembedded.com]
Sent: Thursday, January 29, 2015 6:11 PM
To: Yang, Wenyou; Ferre, Nicolas; linux at arm.linux.org.uk
Cc: linux-arm-kernel at lists.infradead.org; linux-kernel at vger.kernel.org;
alexandre.belloni at free-electrons.com; sylvain.rochet at finsecur.com;
peda at axentia.se; linux at maxim.org.za
Subject: Re: [PATCH v5 05/13] pm: at91: move the copying the sram function to
the sram initializationi phase
quoted
Hello.
quoted
On 1/29/2015 9:38 AM, Wenyou Yang wrote:
quoted
quoted
To decrease the suspend time, move the copying the sram function to
the sram initialization phase, instead of every time go to suspend.
quoted
quoted
In the meanwhile, if there is no sram allocated for PM, the PM is not supported.
quoted
quoted
Signed-off-by: Wenyou Yang <redacted>
Acked-by: Alexandre Belloni <redacted>
---
   arch/arm/mach-at91/pm.c |   12 +++++++-----
   1 file changed, 7 insertions(+), 5 deletions(-)
quoted
quoted
diff --git a/arch/arm/mach-at91/pm.c b/arch/arm/mach-at91/pm.c index
daa998d..6df0152 100644
--- a/arch/arm/mach-at91/pm.c
+++ b/arch/arm/mach-at91/pm.c
@@ -163,10 +163,6 @@ static int at91_pm_enter(suspend_state_t state)
   			 * turning off the main oscillator; reverse on wakeup.
   			 */
   			if (slow_clock) {
-#ifdef CONFIG_AT91_SLOW_CLOCK
-				/* copy slow_clock handler to SRAM, and call it */
-				memcpy(slow_clock, at91_slow_clock,
at91_slow_clock_sz);
-#endif
   				slow_clock(at91_pmc_base, at91_ramc_base[0],
   					   at91_ramc_base[1],
   					   at91_pm_data.memctrl);
@@ -311,6 +307,9 @@ static void __init at91_pm_sram_init(void)
   	sram_pbase = gen_pool_virt_to_phys(sram_pool, sram_base);
   	slow_clock = __arm_ioremap_exec(sram_pbase, at91_slow_clock_sz,
false);

+	/* Copy the slow_clock handler to SRAM */
+	memcpy(slow_clock, at91_slow_clock, at91_slow_clock_sz);
quoted
     AFAIU (looking at the code above and below), __arm_ioremap_exec() can return
NULL and in this case memcpy() will cause kernel oops.
Will add a condition before copying
	if (sram_pbase)
    I rather meant *if* (slow_clock).

[...]
Best Regards,
Wenyou Yang
WBR, Sergei
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help