From nobody Sat Aug 13 21:34:02 2022 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4M4v1k5rm0z4YcRj; Sat, 13 Aug 2022 21:34:02 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4M4v1k5L3Zz4Jtw; Sat, 13 Aug 2022 21:34:02 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1660426442; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=a0amO9QsZSrJTDaoZnmth/r99TJpAPyKyvYQOpZKpkQ=; b=VPiN69qvTsMV8z+MSEJpKpZAfrCRmz+SdjLi4iY/EDJtfC6ddxgRxCsGKxWu6g1UWlAsl8 kpAlTZjacabmaFOflqXUxE/2Qsm4AFTa7n8Pw9/BGv5GZAsvxeCH+jBnfAFOHYMzE7D+EQ RxYliJVzSRxVZQPAyctXrsiU/D66DrYvb/O71/qYuWDe7o3p+tE5DNdUrDpEBTpngCw7ay OfnIfZkTprLHDBqWY+pCsX1HYZRkzRd5/VkEBNIIvKQQvbJQwEp50CZzKqqIDInUIpRdks QxxLIzpMfAYojinZPlvJ4t5Ly3lKIiCF5hg24VVeqSS17ug9yhlEwE22swMU8w== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4M4v1k4NywzR7S; Sat, 13 Aug 2022 21:34:02 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 27DLY2cj099175; Sat, 13 Aug 2022 21:34:02 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 27DLY22m099174; Sat, 13 Aug 2022 21:34:02 GMT (envelope-from git) Date: Sat, 13 Aug 2022 21:34:02 GMT Message-Id: <202208132134.27DLY22m099174@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Andrew Gallatin Subject: git: 2c6ff1d6320d - main - LRO: fix BPF filters for lagg in the hpts path List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: gallatin X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 2c6ff1d6320d57a9d0dc62c10c83145ed49a51dd Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1660426442; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=a0amO9QsZSrJTDaoZnmth/r99TJpAPyKyvYQOpZKpkQ=; b=Lr7gfRifCzli6EJCs5dho5v6kp0KUp20bqQbrx43R2QKzgN6R1PtXqulYT6muaQSI+TFBo NYYYvxylk4jcFpSIhJoK7DDYDujsvwFoxeP3baT8MT+1bzBbXg1N00OH4OmlMQnqLi/Rxw Jl3Aj0kUohU7GyDT498oYWZlZwCz5xerBgFxPnEKY/CXlenjKuDouiOPshL7hYJ95eaT+5 XJF/5spDdMfRsqHQjjetZNZ4ucY4ymK2de4duLOUeF6toXud3beFcgUxVuL+z3UjzeAklf 9T4LkFaRMihhhPEYQ70DFiCH8cawZvUCsuQrpT6u+GrswoSJ+BPdfGBcnwrPaA== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1660426442; a=rsa-sha256; cv=none; b=xJHNYxC+VE0XBK9vLu5kx4CcdE4m1uiGOP7C6rR4D9T4eYmX07beMca2PCiusLeGRVnOeW rWzf4Pes+x93aX3sBL1FlRrFc3XTfwVpoTitsH2B3YeWx4H9MuZ2DD5n3t61ekqXRyrDFr gZsu+oaCUC4DEa+RhLzIiKF0BXfQnKNyauFvMVDYAFpoQBYqG0SdxcQXlZkKHVNu34bxOY Sht/oDFpPDpiB0zZhnKORJeSJns78i6jitbMhlbUS2e47cVjovn9zmsHUKBHICOsLIeiv9 lzJgSMqnaYmIZp4RlMscwWFz7DaghnUf8DywMZIoKHyw76ooM0Oji3Cqq1vhLg== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch main has been updated by gallatin: URL: https://cgit.FreeBSD.org/src/commit/?id=2c6ff1d6320d57a9d0dc62c10c83145ed49a51dd commit 2c6ff1d6320d57a9d0dc62c10c83145ed49a51dd Author: Andrew Gallatin AuthorDate: 2022-08-13 00:15:46 +0000 Commit: Andrew Gallatin CommitDate: 2022-08-13 21:33:36 +0000 LRO: fix BPF filters for lagg in the hpts path When in the hpts path, we need to handle BPF filters since aggregated packets do not pass up the stack in the normal way. This is already done for most interfaces, but lagg needs special handling. This is because packets received via a lagg are passed up the stack with the leaf interface's ifp stored in m_pkthdr.rcvif. To handle lagg packets, we must identify that the passed rcvif is currently a lagg port by checking for IFT_IEEE8023ADLAG or IFT_INFINIBANDLAG (since lagg changes the lagg port's type to that when an interface becomes a lagg member). Then we need to find the lagg's ifp, and handle any BPF listeners on the lagg. Note: It is possible to have multiple BPF filters, one on a member port and one on the lagg itself. That is why we have to have 2 checks and 2 ETHER_BPF_MTAPs. Reviewed by: jhb, rrs Sponsored by: Netflix Differential Revision: https://reviews.freebsd.org/D36136 --- sys/netinet/tcp_lro.c | 30 ++++++++++++++++++++++++++---- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/sys/netinet/tcp_lro.c b/sys/netinet/tcp_lro.c index 2633ccd12afc..fcde002bac53 100644 --- a/sys/netinet/tcp_lro.c +++ b/sys/netinet/tcp_lro.c @@ -53,6 +53,11 @@ __FBSDID("$FreeBSD$"); #include #include #include +#include +#include +#include +#include +#include #include #include @@ -85,7 +90,8 @@ static int tcp_lro_rx_common(struct lro_ctrl *lc, struct mbuf *m, #ifdef TCPHPTS static bool do_bpf_strip_and_compress(struct inpcb *, struct lro_ctrl *, - struct lro_entry *, struct mbuf **, struct mbuf **, struct mbuf **, bool *, bool); + struct lro_entry *, struct mbuf **, struct mbuf **, struct mbuf **, + bool *, bool, bool, struct ifnet *); #endif @@ -1283,7 +1289,8 @@ tcp_lro_flush_tcphpts(struct lro_ctrl *lc, struct lro_entry *le) struct inpcb *inp; struct tcpcb *tp; struct mbuf **pp, *cmp, *mv_to; - bool bpf_req, should_wake; + struct ifnet *lagg_ifp; + bool bpf_req, lagg_bpf_req, should_wake; /* Check if packet doesn't belongs to our network interface. */ if ((tcplro_stacks_wanting_mbufq == 0) || @@ -1341,13 +1348,25 @@ tcp_lro_flush_tcphpts(struct lro_ctrl *lc, struct lro_entry *le) should_wake = true; /* Check if packets should be tapped to BPF. */ bpf_req = bpf_peers_present(lc->ifp->if_bpf); + lagg_bpf_req = false; + lagg_ifp = NULL; + if (lc->ifp->if_type == IFT_IEEE8023ADLAG || + lc->ifp->if_type == IFT_INFINIBANDLAG) { + struct lagg_port *lp = lc->ifp->if_lagg; + struct lagg_softc *sc = lp->lp_softc; + + lagg_ifp = sc->sc_ifp; + if (lagg_ifp != NULL) + lagg_bpf_req = bpf_peers_present(lagg_ifp->if_bpf); + } /* Strip and compress all the incoming packets. */ cmp = NULL; for (pp = &le->m_head; *pp != NULL; ) { mv_to = NULL; if (do_bpf_strip_and_compress(inp, lc, le, pp, - &cmp, &mv_to, &should_wake, bpf_req ) == false) { + &cmp, &mv_to, &should_wake, bpf_req, + lagg_bpf_req, lagg_ifp) == false) { /* Advance to next mbuf. */ pp = &(*pp)->m_nextpkt; } else if (mv_to != NULL) { @@ -1593,7 +1612,7 @@ build_ack_entry(struct tcp_ackent *ae, struct tcphdr *th, struct mbuf *m, static bool do_bpf_strip_and_compress(struct inpcb *inp, struct lro_ctrl *lc, struct lro_entry *le, struct mbuf **pp, struct mbuf **cmp, struct mbuf **mv_to, - bool *should_wake, bool bpf_req) + bool *should_wake, bool bpf_req, bool lagg_bpf_req, struct ifnet *lagg_ifp) { union { void *ptr; @@ -1619,6 +1638,9 @@ do_bpf_strip_and_compress(struct inpcb *inp, struct lro_ctrl *lc, if (__predict_false(bpf_req)) ETHER_BPF_MTAP(lc->ifp, m); + if (__predict_false(lagg_bpf_req)) + ETHER_BPF_MTAP(lagg_ifp, m); + tcp_hdr_offset = m->m_pkthdr.lro_tcp_h_off; lro_type = le->inner.data.lro_type; switch (lro_type) {