git: 6c741ffbfa7f - main - Revert "mbuf: do not restore dying interfaces"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Tue, 03 May 2022 17:28:58 UTC
The branch main has been updated by zec: URL: https://cgit.FreeBSD.org/src/commit/?id=6c741ffbfa7f3dabb6af23dbbfe1d1e9f535d16b commit 6c741ffbfa7f3dabb6af23dbbfe1d1e9f535d16b Author: Marko Zec <zec@FreeBSD.org> AuthorDate: 2022-05-03 14:56:57 +0000 Commit: Marko Zec <zec@FreeBSD.org> CommitDate: 2022-05-03 17:11:40 +0000 Revert "mbuf: do not restore dying interfaces" This reverts commit 703e533da5e2e4743d38bbf4605fec041bc69976. Revert "ifnet/mbuf: provide KPI to serialize/restore m->m_pkthdr.rcvif" This reverts commit e1882428dcbbafd2814d7e17b977a8f686784b39. Obtained from: github.com/glebius/FreeBSD/commits/backout-ifindex --- sys/kern/kern_mbuf.c | 27 --------------------------- sys/net/if.c | 49 +++++++++++++------------------------------------ sys/net/if_var.h | 9 +-------- sys/sys/mbuf.h | 6 ------ 4 files changed, 14 insertions(+), 77 deletions(-) diff --git a/sys/kern/kern_mbuf.c b/sys/kern/kern_mbuf.c index 23050e991418..f1e76ef00c65 100644 --- a/sys/kern/kern_mbuf.c +++ b/sys/kern/kern_mbuf.c @@ -1635,33 +1635,6 @@ m_snd_tag_destroy(struct m_snd_tag *mst) counter_u64_add(snd_tag_count, -1); } -void -m_rcvif_serialize(struct mbuf *m) -{ - u_short idx, gen; - - M_ASSERTPKTHDR(m); - idx = m->m_pkthdr.rcvif->if_index; - gen = m->m_pkthdr.rcvif->if_idxgen; - m->m_pkthdr.rcvidx = idx; - m->m_pkthdr.rcvgen = gen; -} - -struct ifnet * -m_rcvif_restore(struct mbuf *m) -{ - struct ifnet *ifp; - - M_ASSERTPKTHDR(m); - NET_EPOCH_ASSERT(); - - ifp = ifnet_byindexgen(m->m_pkthdr.rcvidx, m->m_pkthdr.rcvgen); - if (ifp == NULL || (ifp->if_flags & IFF_DYING)) - return (NULL); - - return (m->m_pkthdr.rcvif = ifp); -} - /* * Allocate an mbuf with anonymous external pages. */ diff --git a/sys/net/if.c b/sys/net/if.c index ff7071cea364..3b303fe42e99 100644 --- a/sys/net/if.c +++ b/sys/net/if.c @@ -313,10 +313,7 @@ VNET_DEFINE(struct ifgrouphead, ifg_head); /* Table of ifnet by index. */ static int if_index; static int if_indexlim = 8; -static struct ifindex_entry { - struct ifnet *ife_ifnet; - uint16_t ife_gencnt; -} *ifindex_table; +static struct ifnet **ifindex_table; SYSCTL_NODE(_net_link_generic, IFMIB_SYSTEM, system, CTLFLAG_RW | CTLFLAG_MPSAFE, 0, @@ -328,8 +325,8 @@ sysctl_ifcount(SYSCTL_HANDLER_ARGS) IFNET_RLOCK(); for (int i = 1; i <= if_index; i++) - if (ifindex_table[i].ife_ifnet != NULL && - ifindex_table[i].ife_ifnet->if_vnet == curvnet) + if (ifindex_table[i] != NULL && + ifindex_table[i]->if_vnet == curvnet) rv = i; IFNET_RUNLOCK(); @@ -373,7 +370,7 @@ ifnet_byindex(u_int idx) if (__predict_false(idx > if_index)) return (NULL); - ifp = ck_pr_load_ptr(&ifindex_table[idx].ife_ifnet); + ifp = ck_pr_load_ptr(&ifindex_table[idx]); if (curvnet != NULL && ifp != NULL && ifp->if_vnet != curvnet) ifp = NULL; @@ -394,24 +391,6 @@ ifnet_byindex_ref(u_int idx) return (ifp); } -struct ifnet * -ifnet_byindexgen(uint16_t idx, uint16_t gen) -{ - struct ifnet *ifp; - - NET_EPOCH_ASSERT(); - - if (__predict_false(idx > if_index)) - return (NULL); - - ifp = ck_pr_load_ptr(&ifindex_table[idx].ife_ifnet); - - if (ifindex_table[idx].ife_gencnt == gen) - return (ifp); - else - return (NULL); -} - /* * Network interface utility routines. * @@ -578,13 +557,13 @@ if_alloc_domain(u_char type, int numa_domain) * next slot. */ for (idx = 1; idx <= if_index; idx++) { - if (ifindex_table[idx].ife_ifnet == NULL) + if (ifindex_table[idx] == NULL) break; } /* Catch if_index overflow. */ if (idx >= if_indexlim) { - struct ifindex_entry *new, *old; + struct ifnet **new, **old; int newlim; newlim = if_indexlim * 2; @@ -600,8 +579,7 @@ if_alloc_domain(u_char type, int numa_domain) if_index = idx; ifp->if_index = idx; - ifp->if_idxgen = ifindex_table[idx].ife_gencnt; - ck_pr_store_ptr(&ifindex_table[idx].ife_ifnet, ifp); + ck_pr_store_ptr(&ifindex_table[idx], ifp); IFNET_WUNLOCK(); return (ifp); @@ -676,10 +654,9 @@ if_free(struct ifnet *ifp) * virtualized and interface would outlive the vnet. */ IFNET_WLOCK(); - MPASS(ifindex_table[ifp->if_index].ife_ifnet == ifp); - ck_pr_store_ptr(&ifindex_table[ifp->if_index].ife_ifnet, NULL); - ifindex_table[ifp->if_index].ife_gencnt++; - while (if_index > 0 && ifindex_table[if_index].ife_ifnet == NULL) + MPASS(ifindex_table[ifp->if_index] == ifp); + ck_pr_store_ptr(&ifindex_table[ifp->if_index], NULL); + while (if_index > 0 && ifindex_table[if_index] == NULL) if_index--; IFNET_WUNLOCK(); @@ -828,7 +805,7 @@ if_attach_internal(struct ifnet *ifp, bool vmove) struct sockaddr_dl *sdl; struct ifaddr *ifa; - MPASS(ifindex_table[ifp->if_index].ife_ifnet == ifp); + MPASS(ifindex_table[ifp->if_index] == ifp); #ifdef VIMAGE ifp->if_vnet = curvnet; @@ -4517,8 +4494,8 @@ if_show_ifnet(struct ifnet *ifp) IF_DB_PRINTF("%d", if_dunit); IF_DB_PRINTF("%s", if_description); IF_DB_PRINTF("%u", if_index); - IF_DB_PRINTF("%d", if_idxgen); IF_DB_PRINTF("%u", if_refcount); + IF_DB_PRINTF("%d", if_index_reserved); IF_DB_PRINTF("%p", if_softc); IF_DB_PRINTF("%p", if_l2com); IF_DB_PRINTF("%p", if_llsoftc); @@ -4573,7 +4550,7 @@ DB_SHOW_ALL_COMMAND(ifnets, db_show_all_ifnets) u_short idx; for (idx = 1; idx <= if_index; idx++) { - ifp = ifindex_table[idx].ife_ifnet; + ifp = ifindex_table[idx]; if (ifp == NULL) continue; db_printf( "%20s ifp=%p\n", ifp->if_xname, ifp); diff --git a/sys/net/if_var.h b/sys/net/if_var.h index e054c613e9e6..d741d8abee2e 100644 --- a/sys/net/if_var.h +++ b/sys/net/if_var.h @@ -334,7 +334,7 @@ struct ifnet { const char *if_dname; /* driver name */ int if_dunit; /* unit or IF_DUNIT_NONE */ u_short if_index; /* numeric abbreviation for this if */ - u_short if_idxgen; /* ... and its generation count */ + short if_index_reserved; /* spare space to grow if_index */ char if_xname[IFNAMSIZ]; /* external name (name + unit) */ char *if_description; /* interface description */ @@ -644,13 +644,6 @@ extern struct sx ifnet_sxlock; struct ifnet *ifnet_byindex(u_int); struct ifnet *ifnet_byindex_ref(u_int); -/* - * ifnet_byindexgen() looks up ifnet by index and generation count, - * attempting to restore a weak pointer that had been stored across - * the epoch. - */ -struct ifnet *ifnet_byindexgen(uint16_t idx, uint16_t gen); - VNET_DECLARE(struct ifnethead, ifnet); VNET_DECLARE(struct ifgrouphead, ifg_head); VNET_DECLARE(struct ifnet *, loif); /* first loopback interface */ diff --git a/sys/sys/mbuf.h b/sys/sys/mbuf.h index 78b175ebe2c0..8ca23b60269d 100644 --- a/sys/sys/mbuf.h +++ b/sys/sys/mbuf.h @@ -159,10 +159,6 @@ struct pkthdr { union { struct m_snd_tag *snd_tag; /* send tag, if any */ struct ifnet *rcvif; /* rcv interface */ - struct { - uint16_t rcvidx; /* rcv interface index ... */ - uint16_t rcvgen; /* ... and generation count */ - }; }; SLIST_HEAD(packet_tags, m_tag) tags; /* list of packet tags */ int32_t len; /* total packet length */ @@ -866,8 +862,6 @@ int m_snd_tag_alloc(struct ifnet *, void m_snd_tag_init(struct m_snd_tag *, struct ifnet *, const struct if_snd_tag_sw *); void m_snd_tag_destroy(struct m_snd_tag *); -void m_rcvif_serialize(struct mbuf *); -struct ifnet *m_rcvif_restore(struct mbuf *); static __inline int m_gettype(int size)