Revert "cgroup: use an ordered workqueue for cgroup destruction"
authorTejun Heo <tj@kernel.org>
Thu, 13 Feb 2014 00:06:19 +0000 (19:06 -0500)
committerTejun Heo <tj@kernel.org>
Thu, 13 Feb 2014 00:08:28 +0000 (19:08 -0500)
commit1a11533fbd71792e8c5d36f6763fbce8df0d231d
treef7d31231685d2c52af4804d265956660f0f849fb
parent0ab02ca8f887908152d1a96db5130fc661d36a1e
Revert "cgroup: use an ordered workqueue for cgroup destruction"

This reverts commit ab3f5faa6255a0eb4f832675507d9e295ca7e9ba.
Explanation from Hugh:

  It's because more thorough testing, by others here, found that it
  wasn't always solving the problem: so I asked Tejun privately to
  hold off from sending it in, until we'd worked out why not.

  Most of our testing being on a v3,11-based kernel, it was perfectly
  possible that the problem was merely our own e.g. missing Tejun's
  8a2b75384444 ("workqueue: fix ordered workqueues in NUMA setups").

  But that turned out not to be enough to fix it either. Then Filipe
  pointed out how percpu_ref_kill_and_confirm() uses call_rcu_sched()
  before we ever get to put the offline on to the workqueue: by the
  time we get to the workqueue, the ordering has already been lost.

  So, thanks for the Acks, but I'm afraid that this ordered workqueue
  solution is just not good enough: we should simply forget that patch
  and provide a different answer."

Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Hugh Dickins <hughd@google.com>
kernel/cgroup.c