mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-26 18:43:33 -05:00
net: flow_offload: remove netns parameter from flow_block_cb_alloc()
No need to annotate the netns on the flow block callback object,
flow_block_cb_is_busy() already checks for used blocks.
Fixes: d63db30c85
("net: flow_offload: add flow_block_cb_alloc() and flow_block_cb_free()")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Acked-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
aef833c58d
commit
0c7294ddae
8 changed files with 12 additions and 21 deletions
|
@ -735,8 +735,7 @@ mlx5e_rep_indr_setup_tc_block(struct net_device *netdev,
|
|||
list_add(&indr_priv->list,
|
||||
&rpriv->uplink_priv.tc_indr_block_priv_list);
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net,
|
||||
mlx5e_rep_indr_setup_block_cb,
|
||||
block_cb = flow_block_cb_alloc(mlx5e_rep_indr_setup_block_cb,
|
||||
indr_priv, indr_priv,
|
||||
mlx5e_rep_indr_tc_block_unbind);
|
||||
if (IS_ERR(block_cb)) {
|
||||
|
|
|
@ -1610,8 +1610,7 @@ mlxsw_sp_setup_tc_block_flower_bind(struct mlxsw_sp_port *mlxsw_sp_port,
|
|||
acl_block = mlxsw_sp_acl_block_create(mlxsw_sp, f->net);
|
||||
if (!acl_block)
|
||||
return -ENOMEM;
|
||||
block_cb = flow_block_cb_alloc(f->net,
|
||||
mlxsw_sp_setup_tc_block_cb_flower,
|
||||
block_cb = flow_block_cb_alloc(mlxsw_sp_setup_tc_block_cb_flower,
|
||||
mlxsw_sp, acl_block,
|
||||
mlxsw_sp_tc_block_flower_release);
|
||||
if (IS_ERR(block_cb)) {
|
||||
|
@ -1702,7 +1701,7 @@ static int mlxsw_sp_setup_tc_block(struct mlxsw_sp_port *mlxsw_sp_port,
|
|||
&mlxsw_sp_block_cb_list))
|
||||
return -EBUSY;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net, cb, mlxsw_sp_port,
|
||||
block_cb = flow_block_cb_alloc(cb, mlxsw_sp_port,
|
||||
mlxsw_sp_port, NULL);
|
||||
if (IS_ERR(block_cb))
|
||||
return PTR_ERR(block_cb);
|
||||
|
|
|
@ -323,8 +323,7 @@ int ocelot_setup_tc_block_flower_bind(struct ocelot_port *port,
|
|||
if (!port_block)
|
||||
return -ENOMEM;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net,
|
||||
ocelot_setup_tc_block_cb_flower,
|
||||
block_cb = flow_block_cb_alloc(ocelot_setup_tc_block_cb_flower,
|
||||
port, port_block,
|
||||
ocelot_tc_block_unbind);
|
||||
if (IS_ERR(block_cb)) {
|
||||
|
|
|
@ -156,7 +156,7 @@ static int ocelot_setup_tc_block(struct ocelot_port *port,
|
|||
if (flow_block_cb_is_busy(cb, port, &ocelot_block_cb_list))
|
||||
return -EBUSY;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net, cb, port, port, NULL);
|
||||
block_cb = flow_block_cb_alloc(cb, port, port, NULL);
|
||||
if (IS_ERR(block_cb))
|
||||
return PTR_ERR(block_cb);
|
||||
|
||||
|
|
|
@ -1318,8 +1318,7 @@ static int nfp_flower_setup_tc_block(struct net_device *netdev,
|
|||
&nfp_block_cb_list))
|
||||
return -EBUSY;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net,
|
||||
nfp_flower_setup_tc_block_cb,
|
||||
block_cb = flow_block_cb_alloc(nfp_flower_setup_tc_block_cb,
|
||||
repr, repr, NULL);
|
||||
if (IS_ERR(block_cb))
|
||||
return PTR_ERR(block_cb);
|
||||
|
@ -1424,8 +1423,7 @@ nfp_flower_setup_indr_tc_block(struct net_device *netdev, struct nfp_app *app,
|
|||
cb_priv->app = app;
|
||||
list_add(&cb_priv->list, &priv->indr_block_cb_priv);
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net,
|
||||
nfp_flower_setup_indr_block_cb,
|
||||
block_cb = flow_block_cb_alloc(nfp_flower_setup_indr_block_cb,
|
||||
cb_priv, cb_priv,
|
||||
nfp_flower_setup_indr_tc_release);
|
||||
if (IS_ERR(block_cb)) {
|
||||
|
|
|
@ -264,7 +264,6 @@ struct flow_block_offload {
|
|||
struct flow_block_cb {
|
||||
struct list_head driver_list;
|
||||
struct list_head list;
|
||||
struct net *net;
|
||||
tc_setup_cb_t *cb;
|
||||
void *cb_ident;
|
||||
void *cb_priv;
|
||||
|
@ -272,7 +271,7 @@ struct flow_block_cb {
|
|||
unsigned int refcnt;
|
||||
};
|
||||
|
||||
struct flow_block_cb *flow_block_cb_alloc(struct net *net, tc_setup_cb_t *cb,
|
||||
struct flow_block_cb *flow_block_cb_alloc(tc_setup_cb_t *cb,
|
||||
void *cb_ident, void *cb_priv,
|
||||
void (*release)(void *cb_priv));
|
||||
void flow_block_cb_free(struct flow_block_cb *block_cb);
|
||||
|
|
|
@ -165,7 +165,7 @@ void flow_rule_match_enc_opts(const struct flow_rule *rule,
|
|||
}
|
||||
EXPORT_SYMBOL(flow_rule_match_enc_opts);
|
||||
|
||||
struct flow_block_cb *flow_block_cb_alloc(struct net *net, tc_setup_cb_t *cb,
|
||||
struct flow_block_cb *flow_block_cb_alloc(tc_setup_cb_t *cb,
|
||||
void *cb_ident, void *cb_priv,
|
||||
void (*release)(void *cb_priv))
|
||||
{
|
||||
|
@ -175,7 +175,6 @@ struct flow_block_cb *flow_block_cb_alloc(struct net *net, tc_setup_cb_t *cb,
|
|||
if (!block_cb)
|
||||
return ERR_PTR(-ENOMEM);
|
||||
|
||||
block_cb->net = net;
|
||||
block_cb->cb = cb;
|
||||
block_cb->cb_ident = cb_ident;
|
||||
block_cb->cb_priv = cb_priv;
|
||||
|
@ -200,8 +199,7 @@ struct flow_block_cb *flow_block_cb_lookup(struct flow_block_offload *f,
|
|||
struct flow_block_cb *block_cb;
|
||||
|
||||
list_for_each_entry(block_cb, f->driver_block_list, driver_list) {
|
||||
if (block_cb->net == f->net &&
|
||||
block_cb->cb == cb &&
|
||||
if (block_cb->cb == cb &&
|
||||
block_cb->cb_ident == cb_ident)
|
||||
return block_cb;
|
||||
}
|
||||
|
@ -261,8 +259,7 @@ int flow_block_cb_setup_simple(struct flow_block_offload *f,
|
|||
if (flow_block_cb_is_busy(cb, cb_ident, driver_block_list))
|
||||
return -EBUSY;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net, cb, cb_ident,
|
||||
cb_priv, NULL);
|
||||
block_cb = flow_block_cb_alloc(cb, cb_ident, cb_priv, NULL);
|
||||
if (IS_ERR(block_cb))
|
||||
return PTR_ERR(block_cb);
|
||||
|
||||
|
|
|
@ -967,7 +967,7 @@ static int dsa_slave_setup_tc_block(struct net_device *dev,
|
|||
if (flow_block_cb_is_busy(cb, dev, &dsa_slave_block_cb_list))
|
||||
return -EBUSY;
|
||||
|
||||
block_cb = flow_block_cb_alloc(f->net, cb, dev, dev, NULL);
|
||||
block_cb = flow_block_cb_alloc(cb, dev, dev, NULL);
|
||||
if (IS_ERR(block_cb))
|
||||
return PTR_ERR(block_cb);
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue