mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-17 18:14:34 +08:00
net: sched: push chain dump to a separate function
Since there will be multiple chains to dump, push chain dumping code to a separate function. Signed-off-by: Jiri Pirko <jiri@mellanox.com> Acked-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2190d1d094
commit
acb31fae3b
@ -640,21 +640,65 @@ static int tcf_node_dump(struct tcf_proto *tp, unsigned long n,
|
|||||||
RTM_NEWTFILTER);
|
RTM_NEWTFILTER);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void tcf_chain_dump(struct tcf_chain *chain, struct sk_buff *skb,
|
||||||
|
struct netlink_callback *cb,
|
||||||
|
long index_start, long *p_index)
|
||||||
|
{
|
||||||
|
struct net *net = sock_net(skb->sk);
|
||||||
|
struct tcmsg *tcm = nlmsg_data(cb->nlh);
|
||||||
|
struct tcf_dump_args arg;
|
||||||
|
struct tcf_proto *tp;
|
||||||
|
|
||||||
|
for (tp = rtnl_dereference(chain->filter_chain);
|
||||||
|
tp; tp = rtnl_dereference(tp->next), (*p_index)++) {
|
||||||
|
if (*p_index < index_start)
|
||||||
|
continue;
|
||||||
|
if (TC_H_MAJ(tcm->tcm_info) &&
|
||||||
|
TC_H_MAJ(tcm->tcm_info) != tp->prio)
|
||||||
|
continue;
|
||||||
|
if (TC_H_MIN(tcm->tcm_info) &&
|
||||||
|
TC_H_MIN(tcm->tcm_info) != tp->protocol)
|
||||||
|
continue;
|
||||||
|
if (*p_index > index_start)
|
||||||
|
memset(&cb->args[1], 0,
|
||||||
|
sizeof(cb->args) - sizeof(cb->args[0]));
|
||||||
|
if (cb->args[1] == 0) {
|
||||||
|
if (tcf_fill_node(net, skb, tp, 0,
|
||||||
|
NETLINK_CB(cb->skb).portid,
|
||||||
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
|
RTM_NEWTFILTER) <= 0)
|
||||||
|
break;
|
||||||
|
|
||||||
|
cb->args[1] = 1;
|
||||||
|
}
|
||||||
|
if (!tp->ops->walk)
|
||||||
|
continue;
|
||||||
|
arg.w.fn = tcf_node_dump;
|
||||||
|
arg.skb = skb;
|
||||||
|
arg.cb = cb;
|
||||||
|
arg.w.stop = 0;
|
||||||
|
arg.w.skip = cb->args[1] - 1;
|
||||||
|
arg.w.count = 0;
|
||||||
|
tp->ops->walk(tp, &arg.w);
|
||||||
|
cb->args[1] = arg.w.count + 1;
|
||||||
|
if (arg.w.stop)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* called with RTNL */
|
/* called with RTNL */
|
||||||
static int tc_dump_tfilter(struct sk_buff *skb, struct netlink_callback *cb)
|
static int tc_dump_tfilter(struct sk_buff *skb, struct netlink_callback *cb)
|
||||||
{
|
{
|
||||||
struct net *net = sock_net(skb->sk);
|
struct net *net = sock_net(skb->sk);
|
||||||
int t;
|
|
||||||
int s_t;
|
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
struct Qdisc *q;
|
struct Qdisc *q;
|
||||||
struct tcf_block *block;
|
struct tcf_block *block;
|
||||||
struct tcf_proto *tp;
|
|
||||||
struct tcf_chain *chain;
|
struct tcf_chain *chain;
|
||||||
struct tcmsg *tcm = nlmsg_data(cb->nlh);
|
struct tcmsg *tcm = nlmsg_data(cb->nlh);
|
||||||
unsigned long cl = 0;
|
unsigned long cl = 0;
|
||||||
const struct Qdisc_class_ops *cops;
|
const struct Qdisc_class_ops *cops;
|
||||||
struct tcf_dump_args arg;
|
long index_start;
|
||||||
|
long index;
|
||||||
|
|
||||||
if (nlmsg_len(cb->nlh) < sizeof(*tcm))
|
if (nlmsg_len(cb->nlh) < sizeof(*tcm))
|
||||||
return skb->len;
|
return skb->len;
|
||||||
@ -683,45 +727,10 @@ static int tc_dump_tfilter(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
goto errout;
|
goto errout;
|
||||||
chain = block->chain;
|
chain = block->chain;
|
||||||
|
|
||||||
s_t = cb->args[0];
|
index_start = cb->args[0];
|
||||||
|
index = 0;
|
||||||
for (tp = rtnl_dereference(chain->filter_chain), t = 0;
|
tcf_chain_dump(chain, skb, cb, index_start, &index);
|
||||||
tp; tp = rtnl_dereference(tp->next), t++) {
|
cb->args[0] = index;
|
||||||
if (t < s_t)
|
|
||||||
continue;
|
|
||||||
if (TC_H_MAJ(tcm->tcm_info) &&
|
|
||||||
TC_H_MAJ(tcm->tcm_info) != tp->prio)
|
|
||||||
continue;
|
|
||||||
if (TC_H_MIN(tcm->tcm_info) &&
|
|
||||||
TC_H_MIN(tcm->tcm_info) != tp->protocol)
|
|
||||||
continue;
|
|
||||||
if (t > s_t)
|
|
||||||
memset(&cb->args[1], 0,
|
|
||||||
sizeof(cb->args)-sizeof(cb->args[0]));
|
|
||||||
if (cb->args[1] == 0) {
|
|
||||||
if (tcf_fill_node(net, skb, tp, 0,
|
|
||||||
NETLINK_CB(cb->skb).portid,
|
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
|
||||||
RTM_NEWTFILTER) <= 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
cb->args[1] = 1;
|
|
||||||
}
|
|
||||||
if (tp->ops->walk == NULL)
|
|
||||||
continue;
|
|
||||||
arg.w.fn = tcf_node_dump;
|
|
||||||
arg.skb = skb;
|
|
||||||
arg.cb = cb;
|
|
||||||
arg.w.stop = 0;
|
|
||||||
arg.w.skip = cb->args[1] - 1;
|
|
||||||
arg.w.count = 0;
|
|
||||||
tp->ops->walk(tp, &arg.w);
|
|
||||||
cb->args[1] = arg.w.count + 1;
|
|
||||||
if (arg.w.stop)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
cb->args[0] = t;
|
|
||||||
|
|
||||||
errout:
|
errout:
|
||||||
if (cl)
|
if (cl)
|
||||||
|
Loading…
Reference in New Issue
Block a user