Commit b1042d35 authored by Cong Wang's avatar Cong Wang Committed by David S. Miller

netlink: convert netlink tap spinlock to mutex

Both netlink_add_tap() and netlink_remove_tap() are
called in process context, no need to bother spinlock.

Note, in fact, currently we always hold RTNL when calling
these two functions, so we don't need any other lock at
all, but keeping this lock doesn't harm anything.

Cc: Daniel Borkmann <daniel@iogearbox.net>
Signed-off-by: default avatarCong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 25e3f70f
...@@ -176,7 +176,7 @@ static unsigned int netlink_tap_net_id; ...@@ -176,7 +176,7 @@ static unsigned int netlink_tap_net_id;
struct netlink_tap_net { struct netlink_tap_net {
struct list_head netlink_tap_all; struct list_head netlink_tap_all;
spinlock_t netlink_tap_lock; struct mutex netlink_tap_lock;
}; };
int netlink_add_tap(struct netlink_tap *nt) int netlink_add_tap(struct netlink_tap *nt)
...@@ -187,9 +187,9 @@ int netlink_add_tap(struct netlink_tap *nt) ...@@ -187,9 +187,9 @@ int netlink_add_tap(struct netlink_tap *nt)
if (unlikely(nt->dev->type != ARPHRD_NETLINK)) if (unlikely(nt->dev->type != ARPHRD_NETLINK))
return -EINVAL; return -EINVAL;
spin_lock(&nn->netlink_tap_lock); mutex_lock(&nn->netlink_tap_lock);
list_add_rcu(&nt->list, &nn->netlink_tap_all); list_add_rcu(&nt->list, &nn->netlink_tap_all);
spin_unlock(&nn->netlink_tap_lock); mutex_unlock(&nn->netlink_tap_lock);
__module_get(nt->module); __module_get(nt->module);
...@@ -204,7 +204,7 @@ static int __netlink_remove_tap(struct netlink_tap *nt) ...@@ -204,7 +204,7 @@ static int __netlink_remove_tap(struct netlink_tap *nt)
bool found = false; bool found = false;
struct netlink_tap *tmp; struct netlink_tap *tmp;
spin_lock(&nn->netlink_tap_lock); mutex_lock(&nn->netlink_tap_lock);
list_for_each_entry(tmp, &nn->netlink_tap_all, list) { list_for_each_entry(tmp, &nn->netlink_tap_all, list) {
if (nt == tmp) { if (nt == tmp) {
...@@ -216,7 +216,7 @@ static int __netlink_remove_tap(struct netlink_tap *nt) ...@@ -216,7 +216,7 @@ static int __netlink_remove_tap(struct netlink_tap *nt)
pr_warn("__netlink_remove_tap: %p not found\n", nt); pr_warn("__netlink_remove_tap: %p not found\n", nt);
out: out:
spin_unlock(&nn->netlink_tap_lock); mutex_unlock(&nn->netlink_tap_lock);
if (found) if (found)
module_put(nt->module); module_put(nt->module);
...@@ -240,7 +240,7 @@ static __net_init int netlink_tap_init_net(struct net *net) ...@@ -240,7 +240,7 @@ static __net_init int netlink_tap_init_net(struct net *net)
struct netlink_tap_net *nn = net_generic(net, netlink_tap_net_id); struct netlink_tap_net *nn = net_generic(net, netlink_tap_net_id);
INIT_LIST_HEAD(&nn->netlink_tap_all); INIT_LIST_HEAD(&nn->netlink_tap_all);
spin_lock_init(&nn->netlink_tap_lock); mutex_init(&nn->netlink_tap_lock);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment