diff options
author | David S. Miller <davem@davemloft.net> | 2015-04-06 21:52:19 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-04-06 22:34:15 -0400 |
commit | c85d6975ef923cffdd56de3e0e6aba0977282cff (patch) | |
tree | cb497deea01827951809c9c7c0f1c22780c146be /net/ipv4/ipmr.c | |
parent | 60302ff631f0f3eac0ec592e128b776f0676b397 (diff) | |
parent | f22e6e847115abc3a0e2ad7bb18d243d42275af1 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Conflicts:
drivers/net/ethernet/mellanox/mlx4/cmd.c
net/core/fib_rules.c
net/ipv4/fib_frontend.c
The fib_rules.c and fib_frontend.c conflicts were locking adjustments
in 'net' overlapping addition and removal of code in 'net-next'.
The mlx4 conflict was a bug fix in 'net' happening in the same
place a constant was being replaced with a more suitable macro.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/ipmr.c')
-rw-r--r-- | net/ipv4/ipmr.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c index c204b728bbc1..5f17d0e78071 100644 --- a/net/ipv4/ipmr.c +++ b/net/ipv4/ipmr.c | |||
@@ -276,11 +276,13 @@ static void __net_exit ipmr_rules_exit(struct net *net) | |||
276 | { | 276 | { |
277 | struct mr_table *mrt, *next; | 277 | struct mr_table *mrt, *next; |
278 | 278 | ||
279 | rtnl_lock(); | ||
279 | list_for_each_entry_safe(mrt, next, &net->ipv4.mr_tables, list) { | 280 | list_for_each_entry_safe(mrt, next, &net->ipv4.mr_tables, list) { |
280 | list_del(&mrt->list); | 281 | list_del(&mrt->list); |
281 | ipmr_free_table(mrt); | 282 | ipmr_free_table(mrt); |
282 | } | 283 | } |
283 | fib_rules_unregister(net->ipv4.mr_rules_ops); | 284 | fib_rules_unregister(net->ipv4.mr_rules_ops); |
285 | rtnl_unlock(); | ||
284 | } | 286 | } |
285 | #else | 287 | #else |
286 | #define ipmr_for_each_table(mrt, net) \ | 288 | #define ipmr_for_each_table(mrt, net) \ |
@@ -306,7 +308,10 @@ static int __net_init ipmr_rules_init(struct net *net) | |||
306 | 308 | ||
307 | static void __net_exit ipmr_rules_exit(struct net *net) | 309 | static void __net_exit ipmr_rules_exit(struct net *net) |
308 | { | 310 | { |
311 | rtnl_lock(); | ||
309 | ipmr_free_table(net->ipv4.mrt); | 312 | ipmr_free_table(net->ipv4.mrt); |
313 | net->ipv4.mrt = NULL; | ||
314 | rtnl_unlock(); | ||
310 | } | 315 | } |
311 | #endif | 316 | #endif |
312 | 317 | ||