Sebastian Andrzej Siewior
e708d7ad80
perf: Do poll_wait() before checking condition in perf_poll()
...
One should first enqueue to the waitqueue and then check for the
condition. If the condition gets true after mutex_unlock() but before
poll_wait() then we lose it and would have wait for another wakeup.
This has been like this since v2.6.31-rc1 commit c7138f37f9 ("perf_counter:
fix perf_poll()"). Before that it was slightly worse. I guess we get enough
wakeups so if we miss here one it doesn't really matter. It is still a
bad example.
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1407159068-1478-1-git-send-email-bigeasy@linutronix.de
Cc: Arnaldo Carvalho de Melo <acme@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
2014-08-13 07:51:11 +02:00
..
2014-06-04 16:54:17 -07:00
2014-08-13 07:51:11 +02:00
2014-06-10 15:34:46 -07:00
2014-07-05 21:42:08 +02:00
2014-07-17 12:32:47 +02:00
2014-08-04 11:50:00 -07:00
2014-07-03 09:21:54 -07:00
2014-08-04 15:55:08 -07:00
2014-08-04 16:23:30 -07:00
2014-08-04 16:23:30 -07:00
2014-08-04 16:09:53 -07:00
2013-12-10 18:21:34 +00:00
2014-06-06 16:08:14 -07:00
2014-02-18 11:17:17 +01:00
2014-02-18 11:17:17 +01:00
2014-06-12 14:27:40 -07:00
2014-03-20 10:10:53 -04:00
2014-04-12 12:38:53 -07:00
2014-06-10 08:44:40 -07:00
2014-06-04 16:54:14 -07:00
2013-12-20 12:25:45 -08:00
2014-06-10 13:57:22 -07:00
2014-07-15 11:05:09 -04:00
2014-08-04 10:11:28 -07:00
2014-06-04 16:54:19 -07:00
2013-05-01 17:29:18 -04:00
2014-06-14 09:07:44 +02:00
2014-07-05 11:17:45 +02:00
2014-08-04 10:11:28 -07:00
2013-11-13 12:09:12 +09:00
2013-11-09 00:16:23 -05:00
2014-06-04 16:54:15 -07:00
2014-06-06 16:08:11 -07:00
2014-02-13 18:13:22 -08:00
2014-07-16 15:10:07 +02:00
2013-12-19 13:50:32 -05:00
2014-02-02 14:09:12 -08:00
2014-06-21 22:26:24 +02:00
2014-04-03 16:21:05 -07:00
2014-06-06 07:55:06 +02:00
2014-06-04 16:54:15 -07:00
2014-07-05 11:17:26 +02:00
2013-10-19 19:45:35 -04:00
2014-04-07 16:36:11 -07:00
2013-11-15 09:32:22 +09:00
2014-07-16 14:57:13 +02:00
2014-07-30 20:09:37 -07:00
2014-06-06 16:08:12 -07:00
2014-08-08 10:38:04 +02:00
2014-04-25 12:00:49 -07:00
2014-07-28 14:07:52 -04:00
2014-06-04 16:54:15 -07:00
2014-03-31 14:13:25 -07:00
2013-10-25 17:15:18 -04:00
2013-09-25 17:17:01 +01:00
2014-07-03 21:38:32 +08:00
2014-04-24 10:26:39 +02:00
2013-09-07 14:35:32 -07:00
2013-12-05 21:28:42 +08:00
2014-06-06 16:08:12 -07:00
2014-04-28 11:48:34 +09:30
2014-04-02 16:20:21 -07:00
2013-09-30 14:31:03 -07:00
2013-12-09 16:56:29 +01:00
2013-04-18 12:51:19 +02:00
2014-06-06 16:08:13 -07:00
2014-07-16 15:10:39 +02:00
2013-06-18 11:32:10 -05:00
2014-06-04 16:54:15 -07:00
2014-04-12 14:49:50 -07:00
2014-06-04 16:54:15 -07:00
2014-05-23 10:47:21 -06:00
2014-06-12 14:27:40 -07:00
2014-07-09 09:14:33 -07:00
2014-07-16 15:10:07 +02:00
2013-07-14 19:36:59 -04:00
2014-05-22 11:36:10 +02:00
2014-06-04 16:54:15 -07:00
2014-06-04 16:54:14 -07:00
2014-05-22 11:16:36 +02:00
2013-11-13 12:09:33 +09:00
2014-06-23 16:47:44 -07:00
2013-12-10 18:25:28 +00:00
2013-12-10 18:25:28 +00:00
2013-09-11 15:58:27 -07:00
2013-11-19 16:39:05 -05:00
2013-04-29 18:28:42 -07:00
2013-06-19 12:58:42 +02:00
2014-04-30 13:46:17 +02:00
2014-07-07 10:12:56 -07:00
2014-06-21 00:15:26 -04:00
2013-08-30 23:44:11 -07:00
2014-02-24 14:47:15 -08:00
2014-06-06 16:08:13 -07:00
2014-06-04 16:54:16 -07:00
2014-06-06 16:08:16 -07:00
2013-08-30 23:44:11 -07:00
2014-06-23 16:47:44 -07:00
2014-05-20 10:59:32 -04:00
2014-08-04 10:09:27 -07:00