wang, biao ac5a2962b0 klist: del waiter from klist_remove_waiters before wakeup waitting process
There is a race between klist_remove and klist_release. klist_remove
uses a local var waiter saved on stack. When klist_release calls
wake_up_process(waiter->process) to wake up the waiter, waiter might run
immediately and reuse the stack. Then, klist_release calls
list_del(&waiter->list) to change previous
wait data and cause prior waiter thread corrupt.

The patch fixes it against kernel 3.9.

Signed-off-by: wang, biao <biao.wang@intel.com>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2013-05-21 10:16:39 -07:00
..
2013-03-13 15:21:48 -07:00
2011-03-11 14:25:50 +00:00
2011-10-29 21:20:22 +02:00
2011-03-31 11:26:23 -03:00
2013-04-30 17:04:09 -07:00
2013-02-27 19:10:09 -08:00
2012-09-30 18:02:20 -07:00
2012-10-06 03:04:57 +09:00
2013-01-17 12:19:09 -08:00
2013-04-29 18:28:41 -07:00
2012-10-09 16:22:40 +09:00
2013-03-02 08:31:39 -08:00
2013-05-07 16:09:00 -07:00
2012-12-17 17:15:22 -08:00
2012-03-28 15:58:21 -07:00
2012-07-30 17:25:16 -07:00
2012-01-31 23:19:47 +02:00
2011-12-08 19:52:43 -05:00
2013-04-29 18:28:42 -07:00