Date: Tue, 4 Nov 2014 17:01:41 +0000 (UTC) From: "Alexander V. Chernikov" <melifaro@FreeBSD.org> To: src-committers@freebsd.org, svn-src-projects@freebsd.org Subject: svn commit: r274093 - projects/routing/sys/netinet Message-ID: <201411041701.sA4H1fNY088578@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: melifaro Date: Tue Nov 4 17:01:40 2014 New Revision: 274093 URL: https://svnweb.freebsd.org/changeset/base/274093 Log: Convert tcp_maxmtu6() to use new routing api. Modified: projects/routing/sys/netinet/tcp_subr.c Modified: projects/routing/sys/netinet/tcp_subr.c ============================================================================== --- projects/routing/sys/netinet/tcp_subr.c Tue Nov 4 16:35:56 2014 (r274092) +++ projects/routing/sys/netinet/tcp_subr.c Tue Nov 4 17:01:40 2014 (r274093) @@ -1829,39 +1829,36 @@ tcp_maxmtu(struct in_conninfo *inc, stru u_long tcp_maxmtu6(struct in_conninfo *inc, struct tcp_ifcap *cap) { - struct route_in6 sro6; struct ifnet *ifp; + struct nhop6_extended nh_ext; + struct in6_addr dst; + uint32_t scopeid; + uint32_t fibnum; u_long maxmtu = 0; KASSERT(inc != NULL, ("tcp_maxmtu6 with NULL in_conninfo pointer")); - bzero(&sro6, sizeof(sro6)); - if (!IN6_IS_ADDR_UNSPECIFIED(&inc->inc6_faddr)) { - sro6.ro_dst.sin6_family = AF_INET6; - sro6.ro_dst.sin6_len = sizeof(struct sockaddr_in6); - sro6.ro_dst.sin6_addr = inc->inc6_faddr; - in6_rtalloc_ign(&sro6, 0, inc->inc_fibnum); - } - if (sro6.ro_rt != NULL) { - ifp = sro6.ro_rt->rt_ifp; - if (sro6.ro_rt->rt_mtu == 0) - maxmtu = IN6_LINKMTU(sro6.ro_rt->rt_ifp); - else - maxmtu = min(sro6.ro_rt->rt_mtu, - IN6_LINKMTU(sro6.ro_rt->rt_ifp)); - - /* Report additional interface capabilities. */ - if (cap != NULL) { - if (ifp->if_capenable & IFCAP_TSO6 && - ifp->if_hwassist & CSUM_TSO) { - cap->ifcap |= CSUM_TSO; - cap->tsomax = ifp->if_hw_tsomax; - cap->tsomaxsegcount = ifp->if_hw_tsomaxsegcount; - cap->tsomaxsegsize = ifp->if_hw_tsomaxsegsize; - } + in6_splitscope(&inc->inc6_faddr, &dst, &scopeid); + fibnum = inc->inc_fibnum; + + if (fib6_lookup_nh_ext(fibnum, &dst, scopeid, 0, + NHOP_LOOKUP_REF, &nh_ext) != 0) + return (0); + + maxmtu = nh_ext.nh_mtu; + ifp = nh_ext.nh_ifp; + + /* Report additional interface capabilities. */ + if (cap != NULL) { + if (ifp->if_capenable & IFCAP_TSO6 && + ifp->if_hwassist & CSUM_TSO) { + cap->ifcap |= CSUM_TSO; + cap->tsomax = ifp->if_hw_tsomax; + cap->tsomaxsegcount = ifp->if_hw_tsomaxsegcount; + cap->tsomaxsegsize = ifp->if_hw_tsomaxsegsize; } - RTFREE(sro6.ro_rt); } + fib6_free_nh_ext(fibnum, &nh_ext); return (maxmtu); }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201411041701.sA4H1fNY088578>