@@ -1640,6 +1640,7 @@ static void migrate_hrtimer_list(struct hrtimer_clock_base *old_base,
{
struct hrtimer *timer;
struct timerqueue_node *node;
+ int is_pinned;
while ((node = timerqueue_getnext(&old_base->active))) {
timer = container_of(node, struct hrtimer, node);
@@ -1652,6 +1653,15 @@ static void migrate_hrtimer_list(struct hrtimer_clock_base *old_base,
* under us on another CPU
*/
__remove_hrtimer(timer, HRTIMER_STATE_MIGRATE, 0);
+
+ is_pinned = timer->state & HRTIMER_STATE_PINNED;
+
+ /* Check if CPU still has pinned timers */
+ if (unlikely(WARN(is_pinned,
+ "%s: can't migrate pinned timer: %p, deactivating it\n",
+ __func__, timer)))
+ continue;
+
timer->base = new_base;
/*
* Enqueue the timers on the new cpu. This does not
migrate_hrtimer() is called when a CPU goes down and its timers are required to be migrated to some other CPU. Its the responsibility of the users of the hrtimer to remove it before control reaches to migrate_hrtimer(). As these were the pinned hrtimers, the best we can do is: don't migrate these and report to the user as well. That's all this patch does. Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> --- kernel/hrtimer.c | 10 ++++++++++ 1 file changed, 10 insertions(+)