Commit dd27c2e3 authored by Jakub Kicinski's avatar Jakub Kicinski Committed by Daniel Borkmann

bpf: offload: add priv field for drivers

Currently bpf_offload_dev does not have any priv pointer, forcing
the drivers to work backwards from the netdev in program metadata.
This is not great given programs are conceptually associated with
the offload device, and it means one or two unnecessary deferences.
Add a priv pointer to bpf_offload_dev.
Signed-off-by: default avatarJakub Kicinski <jakub.kicinski@netronome.com>
Reviewed-by: default avatarQuentin Monnet <quentin.monnet@netronome.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
parent ebbed0f4
...@@ -465,7 +465,7 @@ static int nfp_bpf_init(struct nfp_app *app) ...@@ -465,7 +465,7 @@ static int nfp_bpf_init(struct nfp_app *app)
app->ctrl_mtu = nfp_bpf_ctrl_cmsg_mtu(bpf); app->ctrl_mtu = nfp_bpf_ctrl_cmsg_mtu(bpf);
} }
bpf->bpf_dev = bpf_offload_dev_create(&nfp_bpf_dev_ops); bpf->bpf_dev = bpf_offload_dev_create(&nfp_bpf_dev_ops, bpf);
err = PTR_ERR_OR_ZERO(bpf->bpf_dev); err = PTR_ERR_OR_ZERO(bpf->bpf_dev);
if (err) if (err)
goto err_free_neutral_maps; goto err_free_neutral_maps;
......
...@@ -185,8 +185,6 @@ static void nfp_prog_free(struct nfp_prog *nfp_prog) ...@@ -185,8 +185,6 @@ static void nfp_prog_free(struct nfp_prog *nfp_prog)
static int nfp_bpf_verifier_prep(struct bpf_prog *prog) static int nfp_bpf_verifier_prep(struct bpf_prog *prog)
{ {
struct nfp_net *nn = netdev_priv(prog->aux->offload->netdev);
struct nfp_app *app = nn->app;
struct nfp_prog *nfp_prog; struct nfp_prog *nfp_prog;
int ret; int ret;
...@@ -197,7 +195,7 @@ static int nfp_bpf_verifier_prep(struct bpf_prog *prog) ...@@ -197,7 +195,7 @@ static int nfp_bpf_verifier_prep(struct bpf_prog *prog)
INIT_LIST_HEAD(&nfp_prog->insns); INIT_LIST_HEAD(&nfp_prog->insns);
nfp_prog->type = prog->type; nfp_prog->type = prog->type;
nfp_prog->bpf = app->priv; nfp_prog->bpf = bpf_offload_dev_priv(prog->aux->offload->offdev);
ret = nfp_prog_prepare(nfp_prog, prog->insnsi, prog->len); ret = nfp_prog_prepare(nfp_prog, prog->insnsi, prog->len);
if (ret) if (ret)
......
...@@ -248,7 +248,7 @@ static int nsim_bpf_create_prog(struct netdevsim *ns, struct bpf_prog *prog) ...@@ -248,7 +248,7 @@ static int nsim_bpf_create_prog(struct netdevsim *ns, struct bpf_prog *prog)
static int nsim_bpf_verifier_prep(struct bpf_prog *prog) static int nsim_bpf_verifier_prep(struct bpf_prog *prog)
{ {
struct netdevsim *ns = netdev_priv(prog->aux->offload->netdev); struct netdevsim *ns = bpf_offload_dev_priv(prog->aux->offload->offdev);
if (!ns->bpf_bind_accept) if (!ns->bpf_bind_accept)
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -589,7 +589,8 @@ int nsim_bpf_init(struct netdevsim *ns) ...@@ -589,7 +589,8 @@ int nsim_bpf_init(struct netdevsim *ns)
if (IS_ERR_OR_NULL(ns->sdev->ddir_bpf_bound_progs)) if (IS_ERR_OR_NULL(ns->sdev->ddir_bpf_bound_progs))
return -ENOMEM; return -ENOMEM;
ns->sdev->bpf_dev = bpf_offload_dev_create(&nsim_bpf_dev_ops); ns->sdev->bpf_dev = bpf_offload_dev_create(&nsim_bpf_dev_ops,
ns);
err = PTR_ERR_OR_ZERO(ns->sdev->bpf_dev); err = PTR_ERR_OR_ZERO(ns->sdev->bpf_dev);
if (err) if (err)
return err; return err;
......
...@@ -773,8 +773,9 @@ int bpf_map_offload_get_next_key(struct bpf_map *map, ...@@ -773,8 +773,9 @@ int bpf_map_offload_get_next_key(struct bpf_map *map,
bool bpf_offload_prog_map_match(struct bpf_prog *prog, struct bpf_map *map); bool bpf_offload_prog_map_match(struct bpf_prog *prog, struct bpf_map *map);
struct bpf_offload_dev * struct bpf_offload_dev *
bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops); bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops, void *priv);
void bpf_offload_dev_destroy(struct bpf_offload_dev *offdev); void bpf_offload_dev_destroy(struct bpf_offload_dev *offdev);
void *bpf_offload_dev_priv(struct bpf_offload_dev *offdev);
int bpf_offload_dev_netdev_register(struct bpf_offload_dev *offdev, int bpf_offload_dev_netdev_register(struct bpf_offload_dev *offdev,
struct net_device *netdev); struct net_device *netdev);
void bpf_offload_dev_netdev_unregister(struct bpf_offload_dev *offdev, void bpf_offload_dev_netdev_unregister(struct bpf_offload_dev *offdev,
......
...@@ -35,6 +35,7 @@ static DECLARE_RWSEM(bpf_devs_lock); ...@@ -35,6 +35,7 @@ static DECLARE_RWSEM(bpf_devs_lock);
struct bpf_offload_dev { struct bpf_offload_dev {
const struct bpf_prog_offload_ops *ops; const struct bpf_prog_offload_ops *ops;
struct list_head netdevs; struct list_head netdevs;
void *priv;
}; };
struct bpf_offload_netdev { struct bpf_offload_netdev {
...@@ -669,7 +670,7 @@ void bpf_offload_dev_netdev_unregister(struct bpf_offload_dev *offdev, ...@@ -669,7 +670,7 @@ void bpf_offload_dev_netdev_unregister(struct bpf_offload_dev *offdev,
EXPORT_SYMBOL_GPL(bpf_offload_dev_netdev_unregister); EXPORT_SYMBOL_GPL(bpf_offload_dev_netdev_unregister);
struct bpf_offload_dev * struct bpf_offload_dev *
bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops) bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops, void *priv)
{ {
struct bpf_offload_dev *offdev; struct bpf_offload_dev *offdev;
int err; int err;
...@@ -688,6 +689,7 @@ bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops) ...@@ -688,6 +689,7 @@ bpf_offload_dev_create(const struct bpf_prog_offload_ops *ops)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
offdev->ops = ops; offdev->ops = ops;
offdev->priv = priv;
INIT_LIST_HEAD(&offdev->netdevs); INIT_LIST_HEAD(&offdev->netdevs);
return offdev; return offdev;
...@@ -700,3 +702,9 @@ void bpf_offload_dev_destroy(struct bpf_offload_dev *offdev) ...@@ -700,3 +702,9 @@ void bpf_offload_dev_destroy(struct bpf_offload_dev *offdev)
kfree(offdev); kfree(offdev);
} }
EXPORT_SYMBOL_GPL(bpf_offload_dev_destroy); EXPORT_SYMBOL_GPL(bpf_offload_dev_destroy);
void *bpf_offload_dev_priv(struct bpf_offload_dev *offdev)
{
return offdev->priv;
}
EXPORT_SYMBOL_GPL(bpf_offload_dev_priv);
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