Date: Thu, 18 Dec 2025 16:47:07 +0000 From: Gleb Smirnoff <glebius@FreeBSD.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org Subject: git: a4d766caf711 - main - bpf: add a crutch to support if_vmove Message-ID: <6944300b.c8c6.e13af2c@gitrepo.freebsd.org>
index | next in thread | raw e-mail
The branch main has been updated by glebius: URL: https://cgit.FreeBSD.org/src/commit/?id=a4d766caf7114392b80793c8306d5a712f31557c commit a4d766caf7114392b80793c8306d5a712f31557c Author: Gleb Smirnoff <glebius@FreeBSD.org> AuthorDate: 2025-12-18 16:46:20 +0000 Commit: Gleb Smirnoff <glebius@FreeBSD.org> CommitDate: 2025-12-18 16:46:20 +0000 bpf: add a crutch to support if_vmove Fixes: 0bf42a0a05b9c802a6d9ca4a6b8696b29a26e08b --- sys/net/bpf.c | 16 ++++++++++++++++ sys/net/bpf.h | 1 + sys/net/if.c | 1 + 3 files changed, 18 insertions(+) diff --git a/sys/net/bpf.c b/sys/net/bpf.c index 54da49f3d656..9f0b57728e88 100644 --- a/sys/net/bpf.c +++ b/sys/net/bpf.c @@ -2722,6 +2722,22 @@ bpf_detach(struct bpf_if *bp) BPF_UNLOCK(); } +#ifdef VIMAGE +/* + * Move bpf to a different VNET. This KPI is a crutch to support if_vmove + * and is not supposed to be used anywhere else. + */ +void +bpf_vmove(struct bpf_if *bp) +{ + + BPF_LOCK(); + LIST_REMOVE(bp, bif_next); + LIST_INSERT_HEAD(&V_bpf_iflist, bp, bif_next); + BPF_UNLOCK(); +} +#endif + bool bpf_peers_present_if(struct ifnet *ifp) { diff --git a/sys/net/bpf.h b/sys/net/bpf.h index f6bcb0e34ed4..6d2ecd985225 100644 --- a/sys/net/bpf.h +++ b/sys/net/bpf.h @@ -425,6 +425,7 @@ CK_LIST_HEAD(bpfd_list, bpf_d); struct bpf_if * bpf_attach(const char *, u_int, u_int, const struct bif_methods *, void *); void bpf_detach(struct bpf_if *); +void bpf_vmove(struct bpf_if *bp); void bpf_bufheld(struct bpf_d *d); int bpf_validate(const struct bpf_insn *, int); void bpf_tap(struct bpf_if *, u_char *, u_int); diff --git a/sys/net/if.c b/sys/net/if.c index f5006781541c..d7c6b22821e2 100644 --- a/sys/net/if.c +++ b/sys/net/if.c @@ -1285,6 +1285,7 @@ if_vmove(struct ifnet *ifp, struct vnet *new_vnet) */ CURVNET_SET_QUIET(new_vnet); if_attach_internal(ifp, true); + bpf_vmove(ifp->if_bpf); CURVNET_RESTORE(); }help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?6944300b.c8c6.e13af2c>
