powerpc/83xx/suspend: Clear deep_sleeping after devices resume
authorAnton Vorontsov <avorontsov@ru.mvista.com>
Thu, 10 Dec 2009 18:00:53 +0000 (21:00 +0300)
committerKumar Gala <galak@kernel.crashing.org>
Fri, 11 Dec 2009 01:56:24 +0000 (19:56 -0600)
Currently 83xx PMC driver clears deep_sleeping variable very early,
before devices are resumed. This makes fsl_deep_sleep() unusable in
drivers' resume() callback.

Sure, drivers can store fsl_deep_sleep() value on suspend and use
the stored value on resume. But a better solution is to postpone
clearing the deep_sleeping variable, i.e. move it into finish()
callback.

Signed-off-by: Anton Vorontsov <avorontsov@ru.mvista.com>
Acked-by: Scott Wood <scottwood@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
arch/powerpc/platforms/83xx/suspend.c

index d306f07b9aa13ca6ee548ad8a56a436498f3cec0..b0c261936f3d7a8b240229231e518cd402319109 100644 (file)
@@ -194,7 +194,7 @@ out:
        return ret;
 }
 
-static void mpc83xx_suspend_finish(void)
+static void mpc83xx_suspend_end(void)
 {
        deep_sleeping = 0;
 }
@@ -278,7 +278,7 @@ static struct platform_suspend_ops mpc83xx_suspend_ops = {
        .valid = mpc83xx_suspend_valid,
        .begin = mpc83xx_suspend_begin,
        .enter = mpc83xx_suspend_enter,
-       .finish = mpc83xx_suspend_finish,
+       .end = mpc83xx_suspend_end,
 };
 
 static int pmc_probe(struct of_device *ofdev,