diff options
author | Kohji Okuno <okuno.kohji@jp.panasonic.com> | 2019-02-26 03:34:13 +0100 |
---|---|---|
committer | Shawn Guo <shawnguo@kernel.org> | 2019-03-19 09:48:00 +0100 |
commit | 91740fc8242b4f260cfa4d4536d8551804777fae (patch) | |
tree | 4f4168bd2bbd1187defe7c2f787ba76d8e92acbf /security/integrity | |
parent | ARM: imx51: fix a leaked reference by adding missing of_node_put (diff) | |
download | linux-91740fc8242b4f260cfa4d4536d8551804777fae.tar.xz linux-91740fc8242b4f260cfa4d4536d8551804777fae.zip |
ARM: imx6q: cpuidle: fix bug that CPU might not wake up at expected time
In the current cpuidle implementation for i.MX6q, the CPU that sets
'WAIT_UNCLOCKED' and the CPU that returns to 'WAIT_CLOCKED' are always
the same. While the CPU that sets 'WAIT_UNCLOCKED' is in IDLE state of
"WAIT", if the other CPU wakes up and enters IDLE state of "WFI"
istead of "WAIT", this CPU can not wake up at expired time.
Because, in the case of "WFI", the CPU must be waked up by the local
timer interrupt. But, while 'WAIT_UNCLOCKED' is set, the local timer
is stopped, when all CPUs execute "wfi" instruction. As a result, the
local timer interrupt is not fired.
In this situation, this CPU will wake up by IRQ different from local
timer. (e.g. broacast timer)
So, this fix changes CPU to return to 'WAIT_CLOCKED'.
Signed-off-by: Kohji Okuno <okuno.kohji@jp.panasonic.com>
Fixes: e5f9dec8ff5f ("ARM: imx6q: support WAIT mode using cpuidle")
Cc: <stable@vger.kernel.org>
Signed-off-by: Shawn Guo <shawnguo@kernel.org>
Diffstat (limited to 'security/integrity')
0 files changed, 0 insertions, 0 deletions