Kirill Tkhai
f0b07bb151
net: Introduce net_rwsem to protect net_namespace_list
...
rtnl_lock() is used everywhere, and contention is very high.
When someone wants to iterate over alive net namespaces,
he/she has no a possibility to do that without exclusive lock.
But the exclusive rtnl_lock() in such places is overkill,
and it just increases the contention. Yes, there is already
for_each_net_rcu() in kernel, but it requires rcu_read_lock(),
and this can't be sleepable. Also, sometimes it may be need
really prevent net_namespace_list growth, so for_each_net_rcu()
is not fit there.
This patch introduces new rw_semaphore, which will be used
instead of rtnl_mutex to protect net_namespace_list. It is
sleepable and allows not-exclusive iterations over net
namespaces list. It allows to stop using rtnl_lock()
in several places (what is made in next patches) and makes
less the time, we keep rtnl_mutex. Here we just add new lock,
while the explanation of we can remove rtnl_lock() there are
in next patches.
Fine grained locks generally are better, then one big lock,
so let's do that with net_namespace_list, while the situation
allows that.
Signed-off-by: Kirill Tkhai <ktkhai@virtuozzo.com >
Signed-off-by: David S. Miller <davem@davemloft.net >
2018-03-29 13:47:53 -04:00
..
2017-07-11 06:08:58 -04:00
2017-11-27 16:20:04 -05:00
2018-01-19 14:02:12 -05:00
2017-11-27 16:20:04 -05:00
2018-02-07 11:55:52 +01:00
2018-03-26 13:14:43 -04:00
2017-04-05 10:15:20 +02:00
2017-10-07 23:15:08 +01:00
2018-03-27 10:22:11 -04:00
2018-01-23 19:51:46 -05:00
2017-04-12 22:02:36 +02:00
2018-03-23 21:52:19 -04:00
2018-03-16 11:28:38 -04:00
2015-09-17 13:20:05 +02:00
2018-03-27 23:03:00 +01:00
2017-11-02 11:10:55 +01:00
2017-10-05 18:44:17 -07:00
2017-11-02 11:10:55 +01:00
2018-01-15 14:53:43 -05:00
2017-11-02 11:10:55 +01:00
2018-02-14 11:55:33 -05:00
2016-02-09 04:45:49 -05:00
2017-05-27 18:51:41 -04:00
2017-10-25 10:54:39 +09:00
2017-08-11 14:59:24 -07:00
2017-07-04 22:35:16 +01:00
2018-02-27 13:30:53 +01:00
2016-07-08 12:20:57 +02:00
2017-01-20 12:12:13 -05:00
2017-07-04 01:29:04 -07:00
2016-04-19 20:09:25 -04:00
2016-04-25 16:44:27 -04:00
2016-06-25 12:19:35 -04:00
2016-04-25 16:44:27 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-23 12:14:18 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-10-18 12:39:36 +01:00
2017-11-30 09:54:25 -05:00
2017-11-04 09:26:51 +09:00
2018-03-04 13:34:18 -05:00
2017-11-02 11:10:55 +01:00
2018-03-05 12:52:45 -05:00
2017-11-04 09:26:51 +09:00
2017-11-02 11:10:55 +01:00
2018-03-05 12:52:45 -05:00
2018-02-06 11:32:48 -05:00
2017-11-02 11:10:55 +01:00
2018-02-28 11:43:28 -05:00
2017-11-01 11:50:43 +09:00
2018-03-04 13:04:22 -05:00
2017-11-02 11:10:55 +01:00
2017-11-11 15:36:05 +09:00
2018-03-04 13:04:23 -05:00
2017-11-02 11:10:55 +01:00
2017-10-30 21:09:24 +09:00
2017-10-11 09:49:34 +02:00
2017-11-02 11:10:55 +01:00
2017-12-08 13:32:26 -05:00
2017-11-16 10:49:00 +09:00
2017-11-02 11:10:55 +01:00
2018-02-27 14:46:26 -05:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-11 14:10:06 -05:00
2017-11-02 11:10:55 +01:00
2016-04-27 22:48:25 -04:00
2018-02-22 21:13:02 +01:00
2016-01-04 20:40:41 +01:00
2017-07-04 01:29:04 -07:00
2017-11-02 11:10:55 +01:00
2015-12-15 23:25:20 -05:00
2017-01-18 13:04:28 -05:00
2017-08-07 11:39:22 -07:00
2018-02-12 14:15:04 -05:00
2018-02-28 11:43:28 -05:00
2017-11-04 09:26:51 +09:00
2017-11-04 09:26:51 +09:00
2017-12-03 10:18:28 -05:00
2017-12-20 14:00:25 -05:00
2017-12-13 14:33:10 -05:00
2017-11-02 11:10:55 +01:00
2016-03-13 23:55:13 -04:00
2018-03-04 13:04:22 -05:00
2018-03-23 11:31:58 -04:00
2017-12-15 12:34:00 -05:00
2018-03-23 11:31:58 -04:00
2018-03-09 11:23:11 -05:00
2018-01-08 18:01:02 +01:00
2018-03-23 11:31:58 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-12 11:07:15 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2016-08-17 19:36:23 -04:00
2016-10-13 12:05:26 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-10-25 12:06:25 +09:00
2015-05-11 10:50:17 -04:00
2017-07-04 22:35:15 +01:00
2018-02-14 14:43:32 -05:00
2018-03-23 11:31:58 -04:00
2016-07-08 13:23:12 +02:00
2017-11-02 11:10:55 +01:00
2017-04-01 20:21:44 -07:00
2016-10-03 02:00:22 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-04 09:26:51 +09:00
2018-03-29 13:47:53 -04:00
2017-11-02 11:10:55 +01:00
2018-03-04 13:04:23 -05:00
2017-07-01 07:39:09 -07:00
2017-11-02 11:10:55 +01:00
2015-12-08 22:02:33 -05:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2016-07-08 12:20:57 +02:00
2017-11-08 16:12:33 +09:00
2017-11-02 11:10:55 +01:00
2016-03-23 22:09:58 -04:00
2018-02-28 12:06:01 -05:00
2018-01-16 14:56:54 -05:00
2017-11-02 11:10:55 +01:00
2017-10-01 03:55:47 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-08-07 11:39:21 -07:00
2017-11-02 11:10:55 +01:00
2017-12-05 14:37:13 -05:00
2018-02-22 20:57:48 +01:00
2017-10-20 13:21:36 +01:00
2017-11-02 11:10:55 +01:00
2018-03-23 11:31:58 -04:00
2018-03-13 18:37:02 +02:00
2017-12-04 11:32:53 -05:00
2018-03-23 11:31:58 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2016-11-09 20:40:06 -05:00
2017-08-25 17:10:23 -07:00
2017-11-02 11:10:55 +01:00
2016-04-28 11:49:45 -04:00
2017-11-02 11:10:55 +01:00
2018-03-23 11:31:58 -04:00
2018-03-01 21:21:36 -05:00
2017-11-02 11:10:55 +01:00
2017-10-25 10:37:11 +09:00
2017-11-10 13:41:40 +09:00
2018-02-21 15:06:05 -05:00
2018-03-01 21:44:28 -05:00
2015-07-09 15:12:20 -07:00
2017-11-11 15:36:05 +09:00
2018-03-23 12:25:54 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-08-29 15:16:52 -07:00
2017-11-02 11:10:55 +01:00
2017-11-27 16:20:04 -05:00
2018-02-16 15:57:42 -05:00
2018-01-17 16:07:24 -05:00
2018-01-24 19:13:45 -05:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-05 15:21:21 -08:00
2018-02-28 11:43:28 -05:00