[PATCH] cpuidle: mvebu: Fix the CPU PM notifier usage
Fulvio
fbf at libero.it
Tue Mar 3 06:58:21 PST 2015
> I didn't know you experimented random kernel panics and that you thought
> it was related to the CPU Idle driver.
>
>
>> All i can say is that the system use the "armadaxp_idle" driver and
>> works fine when running "stress --cpu 8" in background.
>> I asked Netgear to provide a firmware without the idle driver to confirm
>> if it's the cause of the problem, but they did not answered.
>>
>
> I think that if you disable all the state using by doing an
>
> echo 1 > /sys/devices/system/cpu/cpu0/cpuidle/stateNUM/disable
>
> where NUM is the nuymbert of the state. Then it should disable the
> cpuidle on the fly.
>
Thanks, i'll try that as soon as possible (i gave back the unit to my
client) and report back.
However, the description of the cpu_pm_enter function state:
"Must be called on the affected CPU with interrupts disabled. Platform
is responsible for ensuring that cpu_pm_enter is not called twice on the
same CPU before cpu_pm_exit is called. Notified drivers can include VFP
co-processor, interrupt controller and its PM extensions, local CPU
timers context save/restore which shouldn't be interrupted. Hence it
must be called with interrupts disabled."
and the point is: it that an invariant? Do current code and future code
safely assume that cpu_pm_enter is not called twice?
For example if cpu_pm_enter do "context save" and cpu_pm_exit do
"context restore", calling twice cpu_pm_enter will overwrite the
previous saved context: is that safe in all circumstances?
I assume the rule " It must fix a real bug that bothers people (not a,
"This could be a problem..." type thing)." is to avoid committing
useless changes that may introduce new bugs, but i do not think that
apply to this case: a bug report from an unknown user (me) should change
nothing.
Bye,
Fulvio
More information about the linux-arm-kernel
mailing list