[NETLINK]: Convert netlink users to use group numbers instead of bitmasks
Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
Este cometimento está contido em:

cometido por
David S. Miller

ascendente
d629b836d1
cometimento
ac6d439d20
@@ -78,8 +78,8 @@ static void ulog_send(unsigned int nlgroup)
|
||||
if (ub->qlen > 1)
|
||||
ub->lastnlh->nlmsg_type = NLMSG_DONE;
|
||||
|
||||
NETLINK_CB(ub->skb).dst_groups = 1 << nlgroup;
|
||||
netlink_broadcast(ebtulognl, ub->skb, 0, 1 << nlgroup, GFP_ATOMIC);
|
||||
NETLINK_CB(ub->skb).dst_group = nlgroup + 1;
|
||||
netlink_broadcast(ebtulognl, ub->skb, 0, nlgroup + 1, GFP_ATOMIC);
|
||||
|
||||
ub->qlen = 0;
|
||||
ub->skb = NULL;
|
||||
|
@@ -2343,8 +2343,8 @@ void neigh_app_ns(struct neighbour *n)
|
||||
}
|
||||
nlh = (struct nlmsghdr *)skb->data;
|
||||
nlh->nlmsg_flags = NLM_F_REQUEST;
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_NEIGH;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_NEIGH, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_NEIGH;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_NEIGH, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static void neigh_app_notify(struct neighbour *n)
|
||||
@@ -2361,8 +2361,8 @@ static void neigh_app_notify(struct neighbour *n)
|
||||
return;
|
||||
}
|
||||
nlh = (struct nlmsghdr *)skb->data;
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_NEIGH;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_NEIGH, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_NEIGH;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_NEIGH, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
#endif /* CONFIG_ARPD */
|
||||
|
@@ -148,7 +148,7 @@ int rtnetlink_send(struct sk_buff *skb, u32 pid, unsigned group, int echo)
|
||||
{
|
||||
int err = 0;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = group;
|
||||
NETLINK_CB(skb).dst_group = group;
|
||||
if (echo)
|
||||
atomic_inc(&skb->users);
|
||||
netlink_broadcast(rtnl, skb, pid, group, GFP_KERNEL);
|
||||
@@ -458,8 +458,8 @@ void rtmsg_ifinfo(int type, struct net_device *dev, unsigned change)
|
||||
kfree_skb(skb);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_LINK;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_LINK, GFP_KERNEL);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_LINK;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_LINK, GFP_KERNEL);
|
||||
}
|
||||
|
||||
static int rtnetlink_done(struct netlink_callback *cb)
|
||||
|
@@ -1144,8 +1144,8 @@ static inline void rtmsg_iwinfo(struct net_device * dev,
|
||||
kfree_skb(skb);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_LINK;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_LINK, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_LINK;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_LINK, GFP_ATOMIC);
|
||||
}
|
||||
#endif /* WE_EVENT_NETLINK */
|
||||
|
||||
|
@@ -752,16 +752,16 @@ static void rtmsg_ifa(int event, struct dn_ifaddr *ifa)
|
||||
|
||||
skb = alloc_skb(size, GFP_KERNEL);
|
||||
if (!skb) {
|
||||
netlink_set_err(rtnl, 0, RTMGRP_DECnet_IFADDR, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_DECnet_IFADDR, ENOBUFS);
|
||||
return;
|
||||
}
|
||||
if (dn_dev_fill_ifaddr(skb, ifa, 0, 0, event, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_DECnet_IFADDR, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_DECnet_IFADDR, EINVAL);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_DECnet_IFADDR;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_DECnet_IFADDR, GFP_KERNEL);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_DECnet_IFADDR;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_DECnet_IFADDR, GFP_KERNEL);
|
||||
}
|
||||
|
||||
static int dn_dev_dump_ifaddr(struct sk_buff *skb, struct netlink_callback *cb)
|
||||
|
@@ -349,10 +349,10 @@ static void dn_rtmsg_fib(int event, struct dn_fib_node *f, int z, int tb_id,
|
||||
kfree_skb(skb);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_DECnet_ROUTE;
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_DECnet_ROUTE;
|
||||
if (nlh->nlmsg_flags & NLM_F_ECHO)
|
||||
atomic_inc(&skb->users);
|
||||
netlink_broadcast(rtnl, skb, pid, RTMGRP_DECnet_ROUTE, GFP_KERNEL);
|
||||
netlink_broadcast(rtnl, skb, pid, RTNLGRP_DECnet_ROUTE, GFP_KERNEL);
|
||||
if (nlh->nlmsg_flags & NLM_F_ECHO)
|
||||
netlink_unicast(rtnl, skb, pid, MSG_DONTWAIT);
|
||||
}
|
||||
|
@@ -71,10 +71,10 @@ static void dnrmg_send_peer(struct sk_buff *skb)
|
||||
|
||||
switch(flags & DN_RT_CNTL_MSK) {
|
||||
case DN_RT_PKT_L1RT:
|
||||
group = DNRMG_L1_GROUP;
|
||||
group = DNRMG_L1_NLGRP;
|
||||
break;
|
||||
case DN_RT_PKT_L2RT:
|
||||
group = DNRMG_L2_GROUP;
|
||||
group = DNRMG_L2_NLGRP;
|
||||
break;
|
||||
default:
|
||||
return;
|
||||
@@ -83,7 +83,7 @@ static void dnrmg_send_peer(struct sk_buff *skb)
|
||||
skb2 = dnrmg_build_message(skb, &status);
|
||||
if (skb2 == NULL)
|
||||
return;
|
||||
NETLINK_CB(skb2).dst_groups = group;
|
||||
NETLINK_CB(skb2).dst_group = group;
|
||||
netlink_broadcast(dnrmg, skb2, 0, group, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
|
@@ -1111,13 +1111,12 @@ static void rtmsg_ifa(int event, struct in_ifaddr* ifa)
|
||||
struct sk_buff *skb = alloc_skb(size, GFP_KERNEL);
|
||||
|
||||
if (!skb)
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV4_IFADDR, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV4_IFADDR, ENOBUFS);
|
||||
else if (inet_fill_ifaddr(skb, ifa, current->pid, 0, event, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV4_IFADDR, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV4_IFADDR, EINVAL);
|
||||
} else {
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV4_IFADDR;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_IPV4_IFADDR, GFP_KERNEL);
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_IPV4_IFADDR, GFP_KERNEL);
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -560,7 +560,7 @@ static void nl_fib_input(struct sock *sk, int len)
|
||||
pid = nlh->nlmsg_pid; /*pid of sending process */
|
||||
NETLINK_CB(skb).pid = 0; /* from kernel */
|
||||
NETLINK_CB(skb).dst_pid = pid;
|
||||
NETLINK_CB(skb).dst_groups = 0; /* unicast */
|
||||
NETLINK_CB(skb).dst_group = 0; /* unicast */
|
||||
netlink_unicast(sk, skb, pid, MSG_DONTWAIT);
|
||||
}
|
||||
|
||||
|
@@ -290,10 +290,10 @@ void rtmsg_fib(int event, u32 key, struct fib_alias *fa,
|
||||
kfree_skb(skb);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV4_ROUTE;
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_IPV4_ROUTE;
|
||||
if (n->nlmsg_flags&NLM_F_ECHO)
|
||||
atomic_inc(&skb->users);
|
||||
netlink_broadcast(rtnl, skb, pid, RTMGRP_IPV4_ROUTE, GFP_KERNEL);
|
||||
netlink_broadcast(rtnl, skb, pid, RTNLGRP_IPV4_ROUTE, GFP_KERNEL);
|
||||
if (n->nlmsg_flags&NLM_F_ECHO)
|
||||
netlink_unicast(rtnl, skb, pid, MSG_DONTWAIT);
|
||||
}
|
||||
|
@@ -297,7 +297,7 @@ static int ctnetlink_conntrack_event(struct notifier_block *this,
|
||||
struct sk_buff *skb;
|
||||
unsigned int type;
|
||||
unsigned char *b;
|
||||
unsigned int flags = 0, groups;
|
||||
unsigned int flags = 0, group;
|
||||
|
||||
/* ignore our fake conntrack entry */
|
||||
if (ct == &ip_conntrack_untracked)
|
||||
@@ -305,7 +305,7 @@ static int ctnetlink_conntrack_event(struct notifier_block *this,
|
||||
|
||||
if (events & IPCT_DESTROY) {
|
||||
type = IPCTNL_MSG_CT_DELETE;
|
||||
groups = NF_NETLINK_CONNTRACK_DESTROY;
|
||||
group = NFNLGRP_CONNTRACK_DESTROY;
|
||||
goto alloc_skb;
|
||||
}
|
||||
if (events & (IPCT_NEW | IPCT_RELATED)) {
|
||||
@@ -313,7 +313,7 @@ static int ctnetlink_conntrack_event(struct notifier_block *this,
|
||||
flags = NLM_F_CREATE|NLM_F_EXCL;
|
||||
/* dump everything */
|
||||
events = ~0UL;
|
||||
groups = NF_NETLINK_CONNTRACK_NEW;
|
||||
group = NFNLGRP_CONNTRACK_NEW;
|
||||
goto alloc_skb;
|
||||
}
|
||||
if (events & (IPCT_STATUS |
|
||||
@@ -322,7 +322,7 @@ static int ctnetlink_conntrack_event(struct notifier_block *this,
|
||||
IPCT_HELPINFO |
|
||||
IPCT_NATINFO)) {
|
||||
type = IPCTNL_MSG_CT_NEW;
|
||||
groups = NF_NETLINK_CONNTRACK_UPDATE;
|
||||
group = NFNLGRP_CONNTRACK_UPDATE;
|
||||
goto alloc_skb;
|
||||
}
|
||||
|
||||
@@ -375,7 +375,7 @@ alloc_skb:
|
||||
goto nfattr_failure;
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
nfnetlink_send(skb, 0, groups, 0);
|
||||
nfnetlink_send(skb, 0, group, 0);
|
||||
return NOTIFY_DONE;
|
||||
|
||||
nlmsg_failure:
|
||||
@@ -1194,7 +1194,7 @@ static int ctnetlink_expect_event(struct notifier_block *this,
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
proto = exp->tuple.dst.protonum;
|
||||
nfnetlink_send(skb, 0, NF_NETLINK_CONNTRACK_EXP_NEW, 0);
|
||||
nfnetlink_send(skb, 0, NFNLGRP_CONNTRACK_EXP_NEW, 0);
|
||||
return NOTIFY_DONE;
|
||||
|
||||
nlmsg_failure:
|
||||
|
@@ -116,10 +116,10 @@ static void ulog_send(unsigned int nlgroupnum)
|
||||
if (ub->qlen > 1)
|
||||
ub->lastnlh->nlmsg_type = NLMSG_DONE;
|
||||
|
||||
NETLINK_CB(ub->skb).dst_groups = (1 << nlgroupnum);
|
||||
DEBUGP("ipt_ULOG: throwing %d packets to netlink mask %u\n",
|
||||
ub->qlen, nlgroupnum);
|
||||
netlink_broadcast(nflognl, ub->skb, 0, (1 << nlgroupnum), GFP_ATOMIC);
|
||||
NETLINK_CB(ub->skb).dst_group = nlgroupnum + 1;
|
||||
DEBUGP("ipt_ULOG: throwing %d packets to netlink group %u\n",
|
||||
ub->qlen, nlgroupnum + 1);
|
||||
netlink_broadcast(nflognl, ub->skb, 0, nlgroupnum + 1, GFP_ATOMIC);
|
||||
|
||||
ub->qlen = 0;
|
||||
ub->skb = NULL;
|
||||
|
@@ -2858,16 +2858,16 @@ static void inet6_ifa_notify(int event, struct inet6_ifaddr *ifa)
|
||||
|
||||
skb = alloc_skb(size, GFP_ATOMIC);
|
||||
if (!skb) {
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_IFADDR, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_IFADDR, ENOBUFS);
|
||||
return;
|
||||
}
|
||||
if (inet6_fill_ifaddr(skb, ifa, current->pid, 0, event, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_IFADDR, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_IFADDR, EINVAL);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV6_IFADDR;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_IPV6_IFADDR, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_IPV6_IFADDR;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_IPV6_IFADDR, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static void inline ipv6_store_devconf(struct ipv6_devconf *cnf,
|
||||
@@ -2994,16 +2994,16 @@ void inet6_ifinfo_notify(int event, struct inet6_dev *idev)
|
||||
|
||||
skb = alloc_skb(size, GFP_ATOMIC);
|
||||
if (!skb) {
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_IFINFO, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_IFINFO, ENOBUFS);
|
||||
return;
|
||||
}
|
||||
if (inet6_fill_ifinfo(skb, idev, current->pid, 0, event, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_IFINFO, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_IFINFO, EINVAL);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV6_IFINFO;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_IPV6_IFINFO, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_IPV6_IFINFO;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_IPV6_IFINFO, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static int inet6_fill_prefix(struct sk_buff *skb, struct inet6_dev *idev,
|
||||
@@ -3054,16 +3054,16 @@ static void inet6_prefix_notify(int event, struct inet6_dev *idev,
|
||||
|
||||
skb = alloc_skb(size, GFP_ATOMIC);
|
||||
if (!skb) {
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_PREFIX, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_PREFIX, ENOBUFS);
|
||||
return;
|
||||
}
|
||||
if (inet6_fill_prefix(skb, idev, pinfo, current->pid, 0, event, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_PREFIX, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_PREFIX, EINVAL);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV6_PREFIX;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_IPV6_PREFIX, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_IPV6_PREFIX;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_IPV6_PREFIX, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static struct rtnetlink_link inet6_rtnetlink_table[RTM_NR_MSGTYPES] = {
|
||||
|
@@ -1850,16 +1850,16 @@ void inet6_rt_notify(int event, struct rt6_info *rt, struct nlmsghdr *nlh,
|
||||
|
||||
skb = alloc_skb(size, gfp_any());
|
||||
if (!skb) {
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_ROUTE, ENOBUFS);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_ROUTE, ENOBUFS);
|
||||
return;
|
||||
}
|
||||
if (rt6_fill_node(skb, rt, NULL, NULL, 0, event, pid, seq, 0, 0) < 0) {
|
||||
kfree_skb(skb);
|
||||
netlink_set_err(rtnl, 0, RTMGRP_IPV6_ROUTE, EINVAL);
|
||||
netlink_set_err(rtnl, 0, RTNLGRP_IPV6_ROUTE, EINVAL);
|
||||
return;
|
||||
}
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_IPV6_ROUTE;
|
||||
netlink_broadcast(rtnl, skb, 0, RTMGRP_IPV6_ROUTE, gfp_any());
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_IPV6_ROUTE;
|
||||
netlink_broadcast(rtnl, skb, 0, RTNLGRP_IPV6_ROUTE, gfp_any());
|
||||
}
|
||||
|
||||
/*
|
||||
|
@@ -198,7 +198,7 @@ int nfnetlink_send(struct sk_buff *skb, u32 pid, unsigned group, int echo)
|
||||
int allocation = in_interrupt() ? GFP_ATOMIC : GFP_KERNEL;
|
||||
int err = 0;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = group;
|
||||
NETLINK_CB(skb).dst_group = group;
|
||||
if (echo)
|
||||
atomic_inc(&skb->users);
|
||||
netlink_broadcast(nfnl, skb, pid, group, allocation);
|
||||
|
@@ -593,7 +593,7 @@ static int tca_action_flush(struct rtattr *rta, struct nlmsghdr *n, u32 pid)
|
||||
nlh->nlmsg_flags |= NLM_F_ROOT;
|
||||
module_put(a->ops->owner);
|
||||
kfree(a);
|
||||
err = rtnetlink_send(skb, pid, RTMGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
err = rtnetlink_send(skb, pid, RTNLGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
if (err > 0)
|
||||
return 0;
|
||||
|
||||
@@ -656,7 +656,7 @@ tca_action_gd(struct rtattr *rta, struct nlmsghdr *n, u32 pid, int event)
|
||||
|
||||
/* now do the delete */
|
||||
tcf_action_destroy(head, 0);
|
||||
ret = rtnetlink_send(skb, pid, RTMGRP_TC,
|
||||
ret = rtnetlink_send(skb, pid, RTNLGRP_TC,
|
||||
n->nlmsg_flags&NLM_F_ECHO);
|
||||
if (ret > 0)
|
||||
return 0;
|
||||
@@ -698,9 +698,9 @@ static int tcf_add_notify(struct tc_action *a, u32 pid, u32 seq, int event,
|
||||
x->rta_len = skb->tail - (u8*)x;
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
NETLINK_CB(skb).dst_groups = RTMGRP_TC;
|
||||
NETLINK_CB(skb).dst_group = RTNLGRP_TC;
|
||||
|
||||
err = rtnetlink_send(skb, pid, RTMGRP_TC, flags&NLM_F_ECHO);
|
||||
err = rtnetlink_send(skb, pid, RTNLGRP_TC, flags&NLM_F_ECHO);
|
||||
if (err > 0)
|
||||
err = 0;
|
||||
return err;
|
||||
|
@@ -367,7 +367,7 @@ static int tfilter_notify(struct sk_buff *oskb, struct nlmsghdr *n,
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return rtnetlink_send(skb, pid, RTMGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
return rtnetlink_send(skb, pid, RTNLGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
}
|
||||
|
||||
struct tcf_dump_args
|
||||
|
@@ -816,7 +816,7 @@ static int qdisc_notify(struct sk_buff *oskb, struct nlmsghdr *n,
|
||||
}
|
||||
|
||||
if (skb->len)
|
||||
return rtnetlink_send(skb, pid, RTMGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
return rtnetlink_send(skb, pid, RTNLGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
|
||||
err_out:
|
||||
kfree_skb(skb);
|
||||
@@ -1040,7 +1040,7 @@ static int tclass_notify(struct sk_buff *oskb, struct nlmsghdr *n,
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return rtnetlink_send(skb, pid, RTMGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
return rtnetlink_send(skb, pid, RTNLGRP_TC, n->nlmsg_flags&NLM_F_ECHO);
|
||||
}
|
||||
|
||||
struct qdisc_dump_args
|
||||
|
@@ -1125,9 +1125,8 @@ static int xfrm_exp_state_notify(struct xfrm_state *x, struct km_event *c)
|
||||
if (build_expire(skb, x, c->data.hard) < 0)
|
||||
BUG();
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_EXPIRE;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_EXPIRE, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_EXPIRE;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_EXPIRE, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static int xfrm_notify_sa_flush(struct km_event *c)
|
||||
@@ -1152,9 +1151,8 @@ static int xfrm_notify_sa_flush(struct km_event *c)
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_SA;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_SA, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_SA;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_SA, GFP_ATOMIC);
|
||||
|
||||
nlmsg_failure:
|
||||
kfree_skb(skb);
|
||||
@@ -1228,9 +1226,8 @@ static int xfrm_notify_sa(struct xfrm_state *x, struct km_event *c)
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_SA;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_SA, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_SA;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_SA, GFP_ATOMIC);
|
||||
|
||||
nlmsg_failure:
|
||||
rtattr_failure:
|
||||
@@ -1308,9 +1305,8 @@ static int xfrm_send_acquire(struct xfrm_state *x, struct xfrm_tmpl *xt,
|
||||
if (build_acquire(skb, x, xt, xp, dir) < 0)
|
||||
BUG();
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_ACQUIRE;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_ACQUIRE, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_ACQUIRE;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_ACQUIRE, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
/* User gives us xfrm_user_policy_info followed by an array of 0
|
||||
@@ -1409,9 +1405,8 @@ static int xfrm_exp_policy_notify(struct xfrm_policy *xp, int dir, struct km_eve
|
||||
if (build_polexpire(skb, xp, dir, c->data.hard) < 0)
|
||||
BUG();
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_EXPIRE;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_EXPIRE, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_EXPIRE;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_EXPIRE, GFP_ATOMIC);
|
||||
}
|
||||
|
||||
static int xfrm_notify_policy(struct xfrm_policy *xp, int dir, struct km_event *c)
|
||||
@@ -1459,9 +1454,8 @@ static int xfrm_notify_policy(struct xfrm_policy *xp, int dir, struct km_event *
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_POLICY;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_POLICY, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_POLICY;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_POLICY, GFP_ATOMIC);
|
||||
|
||||
nlmsg_failure:
|
||||
rtattr_failure:
|
||||
@@ -1486,9 +1480,8 @@ static int xfrm_notify_policy_flush(struct km_event *c)
|
||||
|
||||
nlh->nlmsg_len = skb->tail - b;
|
||||
|
||||
NETLINK_CB(skb).dst_groups = XFRMGRP_POLICY;
|
||||
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMGRP_POLICY, GFP_ATOMIC);
|
||||
NETLINK_CB(skb).dst_group = XFRMNLGRP_POLICY;
|
||||
return netlink_broadcast(xfrm_nl, skb, 0, XFRMNLGRP_POLICY, GFP_ATOMIC);
|
||||
|
||||
nlmsg_failure:
|
||||
kfree_skb(skb);
|
||||
|
Criar uma nova questão referindo esta
Bloquear um utilizador