From: <hliang1...@gmail.com>
Date: Tue, 30 Sep 2014 13:55:34 +0800

> From: Hao Liang <hliang1...@gmail.com>
> 
> This is the fix for a power management issue caused by suspend and resume 
> function in stmmac_main.c.
> After enable CONFIG_DEBUG_ATOMIC_SLEEP which enable sleep-inside atomic 
> section checking, power
> managemet can not work normally. Board couldn't wakeup successfully after 
> suspend. Command
> "echo mem > /sys/power/state" suspend the board.
> 
> In suspend and resume function of stmmac driver, there are some sleep-inside 
> function in atomic section
> created by spin lock. These functions will causes system warnings and wakeup 
> issue when enable
> CONFIG_DEBUG_ATOMIC_SLEEP.
> 
> This bug was fixed by:
> * replace some sleep function with non-sleep function
>   clk_disable_unprepare -> clk_disable ...
> * decrease the atomic area created by spin lock function. The original atomic 
> area in resume function is
> too large.
> 
> Signed-off-by: Hao Liang <hliang1...@gmail.com>

I really think the ->mac->xxx calls need to be under the lock, and therefore 
this
spinlock region shortening is not valid.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to