summaryrefslogtreecommitdiff
path: root/scripts/lib
diff options
context:
space:
mode:
authorBibo Mao <maobibo@loongson.cn>2025-09-06 09:49:51 +0300
committerThomas Gleixner <tglx@linutronix.de>2025-09-09 14:39:00 +0300
commitfe2a449a45b13df1562419e0104b4777b6ea5248 (patch)
treef37875d3d9132b30ab521abeeb98fff852a6c15a /scripts/lib
parent3c3af563b31766f67106c7549ad084a08ef613f2 (diff)
downloadlinux-fe2a449a45b13df1562419e0104b4777b6ea5248.tar.xz
tick: Do not set device to detached state in tick_shutdown()
tick_shutdown() sets the state of the clockevent device to detached first and the invokes clockevents_exchange_device(), which in turn invokes clockevents_switch_state(). But clockevents_switch_state() returns without invoking the device shutdown callback as the device is already in detached state. As a consequence the timer device is not shutdown when a CPU goes offline. tick_shutdown() does this because it was originally invoked on a online CPU and not on the outgoing CPU. It therefore could not access the clockevent device of the already offlined CPU and just set the state. Since commit 3b1596a21fbf tick_shutdown() is called on the outgoing CPU, so the hardware device can be accessed. Remove the state set before calling clockevents_exchange_device(), so that the subsequent clockevents_switch_state() handles the state transition and invokes the shutdown callback of the clockevent device. [ tglx: Massaged change log ] Fixes: 3b1596a21fbf ("clockevents: Shutdown and unregister current clockevents at CPUHP_AP_TICK_DYING") Signed-off-by: Bibo Mao <maobibo@loongson.cn> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Frederic Weisbecker <frederic@kernel.org> Link: https://lore.kernel.org/all/20250906064952.3749122-2-maobibo@loongson.cn
Diffstat (limited to 'scripts/lib')
0 files changed, 0 insertions, 0 deletions