Commit 0a50438c authored by Linus Torvalds's avatar Linus Torvalds

Merge branch 'for-5.12-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq

Pull workqueue fixes from Tejun Heo:
 "Two workqueue fixes.

  One is around debugobj and poses no risk. The other is to prevent the
  stall watchdog from firing spuriously in certain conditions. Not as
  trivial as debugobj change but is still fairly low risk"

* 'for-5.12-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
  workqueue/watchdog: Make unbound workqueues aware of touch_softlockup_watchdog() 84;0;0c84;0;0c There are two workqueue-specific watchdog timestamps:
  workqueue: Move the position of debug_work_activate() in __queue_work()
parents e49d033b 89e28ce6
...@@ -278,9 +278,10 @@ void touch_all_softlockup_watchdogs(void) ...@@ -278,9 +278,10 @@ void touch_all_softlockup_watchdogs(void)
* update as well, the only side effect might be a cycle delay for * update as well, the only side effect might be a cycle delay for
* the softlockup check. * the softlockup check.
*/ */
for_each_cpu(cpu, &watchdog_allowed_mask) for_each_cpu(cpu, &watchdog_allowed_mask) {
per_cpu(watchdog_touch_ts, cpu) = SOFTLOCKUP_RESET; per_cpu(watchdog_touch_ts, cpu) = SOFTLOCKUP_RESET;
wq_watchdog_touch(-1); wq_watchdog_touch(cpu);
}
} }
void touch_softlockup_watchdog_sync(void) void touch_softlockup_watchdog_sync(void)
......
...@@ -1412,7 +1412,6 @@ static void __queue_work(int cpu, struct workqueue_struct *wq, ...@@ -1412,7 +1412,6 @@ static void __queue_work(int cpu, struct workqueue_struct *wq,
*/ */
lockdep_assert_irqs_disabled(); lockdep_assert_irqs_disabled();
debug_work_activate(work);
/* if draining, only works from the same workqueue are allowed */ /* if draining, only works from the same workqueue are allowed */
if (unlikely(wq->flags & __WQ_DRAINING) && if (unlikely(wq->flags & __WQ_DRAINING) &&
...@@ -1494,6 +1493,7 @@ static void __queue_work(int cpu, struct workqueue_struct *wq, ...@@ -1494,6 +1493,7 @@ static void __queue_work(int cpu, struct workqueue_struct *wq,
worklist = &pwq->delayed_works; worklist = &pwq->delayed_works;
} }
debug_work_activate(work);
insert_work(pwq, work, worklist, work_flags); insert_work(pwq, work, worklist, work_flags);
out: out:
...@@ -5787,22 +5787,17 @@ static void wq_watchdog_timer_fn(struct timer_list *unused) ...@@ -5787,22 +5787,17 @@ static void wq_watchdog_timer_fn(struct timer_list *unused)
continue; continue;
/* get the latest of pool and touched timestamps */ /* get the latest of pool and touched timestamps */
if (pool->cpu >= 0)
touched = READ_ONCE(per_cpu(wq_watchdog_touched_cpu, pool->cpu));
else
touched = READ_ONCE(wq_watchdog_touched);
pool_ts = READ_ONCE(pool->watchdog_ts); pool_ts = READ_ONCE(pool->watchdog_ts);
touched = READ_ONCE(wq_watchdog_touched);
if (time_after(pool_ts, touched)) if (time_after(pool_ts, touched))
ts = pool_ts; ts = pool_ts;
else else
ts = touched; ts = touched;
if (pool->cpu >= 0) {
unsigned long cpu_touched =
READ_ONCE(per_cpu(wq_watchdog_touched_cpu,
pool->cpu));
if (time_after(cpu_touched, ts))
ts = cpu_touched;
}
/* did we stall? */ /* did we stall? */
if (time_after(jiffies, ts + thresh)) { if (time_after(jiffies, ts + thresh)) {
lockup_detected = true; lockup_detected = true;
...@@ -5826,8 +5821,8 @@ notrace void wq_watchdog_touch(int cpu) ...@@ -5826,8 +5821,8 @@ notrace void wq_watchdog_touch(int cpu)
{ {
if (cpu >= 0) if (cpu >= 0)
per_cpu(wq_watchdog_touched_cpu, cpu) = jiffies; per_cpu(wq_watchdog_touched_cpu, cpu) = jiffies;
else
wq_watchdog_touched = jiffies; wq_watchdog_touched = jiffies;
} }
static void wq_watchdog_set_thresh(unsigned long thresh) static void wq_watchdog_set_thresh(unsigned long thresh)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment