Files
linux/include/linux
Simon Horman f6f3c437d0 sched: add cond_resched_rcu() helper
This is intended for use in loops which read data protected by RCU and may
have a large number of iterations.  Such an example is dumping the list of
connections known to IPVS: ip_vs_conn_array() and ip_vs_conn_seq_next().

The benefits are for CONFIG_PREEMPT_RCU=y where we save CPU cycles
by moving rcu_read_lock and rcu_read_unlock out of large loops
but still allowing the current task to be preempted after every
loop iteration for the CONFIG_PREEMPT_RCU=n case.

The call to cond_resched() is not needed when CONFIG_PREEMPT_RCU=y.
Thanks to Paul E. McKenney for explaining this and for the
final version that checks the context with CONFIG_DEBUG_ATOMIC_SLEEP=y
for all possible configurations.

The function can be empty in the CONFIG_PREEMPT_RCU case,
rcu_read_lock and rcu_read_unlock are not needed in this case
because the task can be preempted on indication from scheduler.
Thanks to Peter Zijlstra for catching this and for his help
in trying a solution that changes __might_sleep.

Initial cond_resched_rcu_lock() function suggested by Eric Dumazet.

Tested-by: Julian Anastasov <ja@ssi.bg>
Signed-off-by: Julian Anastasov <ja@ssi.bg>
Signed-off-by: Simon Horman <horms@verge.net.au>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
2013-05-23 14:23:17 +02:00
..
2013-04-12 14:27:55 -04:00
2013-03-01 13:39:00 -08:00
2013-01-02 17:36:10 -08:00
2013-01-03 14:34:06 -08:00
2013-05-07 19:46:02 -07:00
2012-10-08 13:50:20 +10:30
2012-12-02 00:05:12 +00:00
2013-04-29 15:40:23 -04:00
2013-03-23 16:11:31 -07:00
2013-05-07 20:16:25 -07:00
2013-03-22 15:18:18 -07:00
2012-01-03 22:54:57 -05:00
2013-04-08 17:39:23 +02:00
2013-03-12 11:30:04 -07:00
2012-03-23 16:58:38 -07:00
2013-05-10 14:37:17 +01:00
2012-02-20 19:46:36 +11:00
2013-05-01 16:36:22 +05:30
2013-03-28 10:10:25 -06:00
2012-12-24 09:36:38 -07:00
2012-09-30 18:02:20 -07:00
2011-11-26 14:59:39 -05:00
2012-10-16 18:49:15 -07:00
2013-02-26 02:46:08 -05:00
2013-05-07 18:38:27 -07:00
2013-03-15 15:09:43 +10:30
2013-04-29 18:28:40 -07:00
2012-11-22 13:43:27 +09:00
2013-05-07 02:16:31 -04:00
2013-02-22 23:31:31 -05:00
2012-11-08 16:58:30 +01:00
2013-05-06 13:07:33 +02:00
2013-01-25 21:03:54 -08:00
2012-03-26 21:47:19 +02:00
2012-03-26 21:47:19 +02:00
2012-03-26 21:47:19 +02:00
2013-02-06 15:59:47 -05:00
2013-03-06 14:55:20 -05:00
2013-01-29 13:59:57 -05:00
2012-03-20 12:47:48 +01:00
2012-03-20 12:47:47 +01:00
2013-01-10 11:44:38 -06:00
2013-04-12 00:03:42 -04:00
2012-07-17 09:13:37 -07:00
2012-05-31 17:49:32 -07:00
2013-04-30 17:04:06 -07:00
2013-05-07 16:09:00 -07:00
2013-04-01 11:04:50 -07:00
2012-10-10 01:15:44 -04:00
2013-04-30 17:04:00 -07:00
2013-03-15 15:09:43 +10:30
2012-12-14 13:06:40 +10:30
2012-12-25 18:45:06 -05:00
2013-04-29 18:28:44 -07:00
2012-12-11 17:22:27 -08:00
2013-05-04 14:47:26 -04:00
2012-10-17 15:53:02 -05:00
2012-10-10 22:41:05 -04:00
2012-07-10 10:32:06 -05:00
2012-05-21 14:31:48 +01:00
2012-07-31 18:42:43 -07:00
2013-04-29 15:54:28 -07:00
2012-03-20 21:29:38 -04:00
2013-04-29 15:54:28 -07:00
2013-04-12 10:26:23 +02:00
2012-11-16 14:33:04 -08:00
2012-10-06 03:05:01 +09:00
2013-05-23 14:23:17 +02:00
2013-04-09 14:13:29 -04:00
2013-02-19 08:43:34 +01:00
2013-03-29 15:31:30 -04:00
2013-03-10 22:20:05 +01:00
2012-06-13 21:16:42 +02:00
2013-04-30 15:50:12 +05:30
2013-03-22 16:19:59 -07:00
2012-08-21 16:28:31 +02:00
2012-10-09 16:22:32 +09:00
2012-07-22 23:57:55 +04:00
2013-01-15 22:43:15 -08:00
2013-03-20 12:10:38 -04:00
2012-09-05 17:21:36 -07:00
2013-03-28 11:10:22 -07:00
2013-04-29 15:54:37 -07:00
2013-05-07 18:38:28 -07:00