Lines Matching defs:nsim_dev
30 struct nsim_dev *nsim_dev;
69 if (state->nsim_dev->bpf_bind_verifier_delay && !insn_idx)
70 msleep(state->nsim_dev->bpf_bind_verifier_delay);
75 if (!state->nsim_dev->bpf_bind_verifier_accept)
218 static int nsim_bpf_create_prog(struct nsim_dev *nsim_dev,
229 state->nsim_dev = nsim_dev;
234 sprintf(name, "%u", nsim_dev->prog_id_gen++);
235 state->ddir = debugfs_create_dir(name, nsim_dev->ddir_bpf_bound_progs);
247 list_add_tail(&state->l, &nsim_dev->bpf_bound_progs);
256 struct nsim_dev *nsim_dev =
259 if (!nsim_dev->bpf_bind_accept)
262 return nsim_bpf_create_prog(nsim_dev, prog);
520 list_add_tail(&nmap->l, &ns->nsim_dev->bpf_bound_maps);
580 int nsim_bpf_dev_init(struct nsim_dev *nsim_dev)
584 INIT_LIST_HEAD(&nsim_dev->bpf_bound_progs);
585 INIT_LIST_HEAD(&nsim_dev->bpf_bound_maps);
587 nsim_dev->ddir_bpf_bound_progs = debugfs_create_dir("bpf_bound_progs",
588 nsim_dev->ddir);
589 if (IS_ERR(nsim_dev->ddir_bpf_bound_progs))
590 return PTR_ERR(nsim_dev->ddir_bpf_bound_progs);
592 nsim_dev->bpf_dev = bpf_offload_dev_create(&nsim_bpf_dev_ops, nsim_dev);
593 err = PTR_ERR_OR_ZERO(nsim_dev->bpf_dev);
597 nsim_dev->bpf_bind_accept = true;
598 debugfs_create_bool("bpf_bind_accept", 0600, nsim_dev->ddir,
599 &nsim_dev->bpf_bind_accept);
600 debugfs_create_u32("bpf_bind_verifier_delay", 0600, nsim_dev->ddir,
601 &nsim_dev->bpf_bind_verifier_delay);
602 nsim_dev->bpf_bind_verifier_accept = true;
603 debugfs_create_bool("bpf_bind_verifier_accept", 0600, nsim_dev->ddir,
604 &nsim_dev->bpf_bind_verifier_accept);
608 void nsim_bpf_dev_exit(struct nsim_dev *nsim_dev)
610 WARN_ON(!list_empty(&nsim_dev->bpf_bound_progs));
611 WARN_ON(!list_empty(&nsim_dev->bpf_bound_maps));
612 bpf_offload_dev_destroy(nsim_dev->bpf_dev);
620 err = bpf_offload_dev_netdev_register(ns->nsim_dev->bpf_dev,
652 bpf_offload_dev_netdev_unregister(ns->nsim_dev->bpf_dev, ns->netdev);