Commit fae52d93 authored by Zhengchao Shao's avatar Zhengchao Shao Committed by David S. Miller

net: sched: act_api: implement generic walker and search for tc action

Being able to get tc_action_net by using net_id stored in tc_action_ops
and execute the generic walk/search function, add __tcf_generic_walker()
and __tcf_idr_search() helpers.
Signed-off-by: default avatarZhengchao Shao <shaozhengchao@huawei.com>
Acked-by: default avatarJamal Hadi Salim <jhs@mojatatu.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent acd0a7ab
...@@ -676,6 +676,31 @@ int tcf_idr_search(struct tc_action_net *tn, struct tc_action **a, u32 index) ...@@ -676,6 +676,31 @@ int tcf_idr_search(struct tc_action_net *tn, struct tc_action **a, u32 index)
} }
EXPORT_SYMBOL(tcf_idr_search); EXPORT_SYMBOL(tcf_idr_search);
static int __tcf_generic_walker(struct net *net, struct sk_buff *skb,
struct netlink_callback *cb, int type,
const struct tc_action_ops *ops,
struct netlink_ext_ack *extack)
{
struct tc_action_net *tn = net_generic(net, ops->net_id);
if (unlikely(ops->walk))
return ops->walk(net, skb, cb, type, ops, extack);
return tcf_generic_walker(tn, skb, cb, type, ops, extack);
}
static int __tcf_idr_search(struct net *net,
const struct tc_action_ops *ops,
struct tc_action **a, u32 index)
{
struct tc_action_net *tn = net_generic(net, ops->net_id);
if (unlikely(ops->lookup))
return ops->lookup(net, a, index);
return tcf_idr_search(tn, a, index);
}
static int tcf_idr_delete_index(struct tcf_idrinfo *idrinfo, u32 index) static int tcf_idr_delete_index(struct tcf_idrinfo *idrinfo, u32 index)
{ {
struct tc_action *p; struct tc_action *p;
...@@ -926,7 +951,7 @@ int tcf_register_action(struct tc_action_ops *act, ...@@ -926,7 +951,7 @@ int tcf_register_action(struct tc_action_ops *act,
struct tc_action_ops *a; struct tc_action_ops *a;
int ret; int ret;
if (!act->act || !act->dump || !act->init || !act->walk || !act->lookup) if (!act->act || !act->dump || !act->init)
return -EINVAL; return -EINVAL;
/* We have to register pernet ops before making the action ops visible, /* We have to register pernet ops before making the action ops visible,
...@@ -1638,7 +1663,7 @@ static struct tc_action *tcf_action_get_1(struct net *net, struct nlattr *nla, ...@@ -1638,7 +1663,7 @@ static struct tc_action *tcf_action_get_1(struct net *net, struct nlattr *nla,
goto err_out; goto err_out;
} }
err = -ENOENT; err = -ENOENT;
if (ops->lookup(net, &a, index) == 0) { if (__tcf_idr_search(net, ops, &a, index) == 0) {
NL_SET_ERR_MSG(extack, "TC action with specified index not found"); NL_SET_ERR_MSG(extack, "TC action with specified index not found");
goto err_mod; goto err_mod;
} }
...@@ -1703,7 +1728,7 @@ static int tca_action_flush(struct net *net, struct nlattr *nla, ...@@ -1703,7 +1728,7 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,
goto out_module_put; goto out_module_put;
} }
err = ops->walk(net, skb, &dcb, RTM_DELACTION, ops, extack); err = __tcf_generic_walker(net, skb, &dcb, RTM_DELACTION, ops, extack);
if (err <= 0) { if (err <= 0) {
nla_nest_cancel(skb, nest); nla_nest_cancel(skb, nest);
goto out_module_put; goto out_module_put;
...@@ -2121,7 +2146,7 @@ static int tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb) ...@@ -2121,7 +2146,7 @@ static int tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb)
if (nest == NULL) if (nest == NULL)
goto out_module_put; goto out_module_put;
ret = a_o->walk(net, skb, cb, RTM_GETACTION, a_o, NULL); ret = __tcf_generic_walker(net, skb, cb, RTM_GETACTION, a_o, NULL);
if (ret < 0) if (ret < 0)
goto out_module_put; goto out_module_put;
......
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