diff options
Diffstat (limited to 'net/core/rtnetlink.c')
-rw-r--r-- | net/core/rtnetlink.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c index d1644e317e70..2d56cb9b0b94 100644 --- a/net/core/rtnetlink.c +++ b/net/core/rtnetlink.c | |||
@@ -850,6 +850,7 @@ static int rtnl_fill_ifinfo(struct sk_buff *skb, struct net_device *dev, | |||
850 | struct nlattr *attr, *af_spec; | 850 | struct nlattr *attr, *af_spec; |
851 | struct rtnl_af_ops *af_ops; | 851 | struct rtnl_af_ops *af_ops; |
852 | 852 | ||
853 | ASSERT_RTNL(); | ||
853 | nlh = nlmsg_put(skb, pid, seq, type, sizeof(*ifm), flags); | 854 | nlh = nlmsg_put(skb, pid, seq, type, sizeof(*ifm), flags); |
854 | if (nlh == NULL) | 855 | if (nlh == NULL) |
855 | return -EMSGSIZE; | 856 | return -EMSGSIZE; |
@@ -1876,6 +1877,7 @@ static int rtnetlink_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh) | |||
1876 | int min_len; | 1877 | int min_len; |
1877 | int family; | 1878 | int family; |
1878 | int type; | 1879 | int type; |
1880 | int err; | ||
1879 | 1881 | ||
1880 | type = nlh->nlmsg_type; | 1882 | type = nlh->nlmsg_type; |
1881 | if (type > RTM_MAX) | 1883 | if (type > RTM_MAX) |
@@ -1902,8 +1904,11 @@ static int rtnetlink_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh) | |||
1902 | if (dumpit == NULL) | 1904 | if (dumpit == NULL) |
1903 | return -EOPNOTSUPP; | 1905 | return -EOPNOTSUPP; |
1904 | 1906 | ||
1907 | __rtnl_unlock(); | ||
1905 | rtnl = net->rtnl; | 1908 | rtnl = net->rtnl; |
1906 | return netlink_dump_start(rtnl, skb, nlh, dumpit, NULL); | 1909 | err = netlink_dump_start(rtnl, skb, nlh, dumpit, NULL); |
1910 | rtnl_lock(); | ||
1911 | return err; | ||
1907 | } | 1912 | } |
1908 | 1913 | ||
1909 | memset(rta_buf, 0, (rtattr_max * sizeof(struct rtattr *))); | 1914 | memset(rta_buf, 0, (rtattr_max * sizeof(struct rtattr *))); |
@@ -1975,7 +1980,7 @@ static int __net_init rtnetlink_net_init(struct net *net) | |||
1975 | { | 1980 | { |
1976 | struct sock *sk; | 1981 | struct sock *sk; |
1977 | sk = netlink_kernel_create(net, NETLINK_ROUTE, RTNLGRP_MAX, | 1982 | sk = netlink_kernel_create(net, NETLINK_ROUTE, RTNLGRP_MAX, |
1978 | rtnetlink_rcv, NULL, THIS_MODULE); | 1983 | rtnetlink_rcv, &rtnl_mutex, THIS_MODULE); |
1979 | if (!sk) | 1984 | if (!sk) |
1980 | return -ENOMEM; | 1985 | return -ENOMEM; |
1981 | net->rtnl = sk; | 1986 | net->rtnl = sk; |