]> git.baikalelectronics.ru Git - kernel.git/commit
Merge branch 'for-3.11-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq
authorLinus Torvalds <torvalds@linux-foundation.org>
Fri, 30 Aug 2013 00:02:48 +0000 (17:02 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Fri, 30 Aug 2013 00:02:48 +0000 (17:02 -0700)
commit840b14490fa801708f5ec7e19d9fcdbcf7719c9a
treea02fd3216941b71ea58c6b57f84344be64168301
parentafe24dbe5a7844e90cb10586d530a89b2d955027
parentbd3111c330b89f4e9658a26d1514c1b63052cafd
Merge branch 'for-3.11-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq

Pull workqueue fix from Tejun Heo:
 "This contains one fix which could lead to system-wide lockup on
  !PREEMPT kernels.  It's very late in the cycle but this definitely is
  a -stable material.

  The problem is that workqueue worker tasks may process unlimited
  number of work items back-to-back without every yielding inbetween.
  This usually isn't noticeable but a work item which re-queues itself
  waiting for someone else to do something can deadlock with
  stop_machine.  stop_machine will ensure nothing else happens on all
  other cpus and the requeueing work item will reqeueue itself
  indefinitely without ever yielding and thus preventing the CPU from
  entering stop_machine.

  Kudos to Jamie Liu for spotting and diagnosing the problem.  This can
  be trivially fixed by adding cond_resched() after processing each work
  item"

* 'for-3.11-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
  workqueue: cond_resched() after processing each work item