git: 6d4f6e4c704d - main - routing: make rib_add_redirect() use new nhop-based KPI
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Mon, 29 Aug 2022 10:23:50 UTC
The branch main has been updated by melifaro: URL: https://cgit.FreeBSD.org/src/commit/?id=6d4f6e4c704d17084144ac3fe0c8507015f1357f commit 6d4f6e4c704d17084144ac3fe0c8507015f1357f Author: Alexander V. Chernikov <melifaro@FreeBSD.org> AuthorDate: 2022-08-09 11:45:59 +0000 Commit: Alexander V. Chernikov <melifaro@FreeBSD.org> CommitDate: 2022-08-29 10:23:26 +0000 routing: make rib_add_redirect() use new nhop-based KPI MFC after: 1 month Differential Revision: https://reviews.freebsd.org/D36169 --- sys/net/route.c | 44 ++++++++++++++++++++++---------------------- sys/netinet6/nd6.c | 7 ++----- 2 files changed, 24 insertions(+), 27 deletions(-) diff --git a/sys/net/route.c b/sys/net/route.c index 2ea8d4ab5c47..08cee070847f 100644 --- a/sys/net/route.c +++ b/sys/net/route.c @@ -188,11 +188,10 @@ int rib_add_redirect(u_int fibnum, struct sockaddr *dst, struct sockaddr *gateway, struct sockaddr *author, struct ifnet *ifp, int flags, int lifetime_sec) { + struct route_nhop_data rnd = { .rnd_weight = RT_DEFAULT_WEIGHT }; struct rib_cmd_info rc; - int error; - struct rt_addrinfo info; - struct rt_metrics rti_rmx; struct ifaddr *ifa; + int error; NET_EPOCH_ASSERT(); @@ -208,21 +207,21 @@ rib_add_redirect(u_int fibnum, struct sockaddr *dst, struct sockaddr *gateway, if ((ifa = ifaof_ifpforaddr(gateway, ifp)) == NULL) return (ENETUNREACH); - bzero(&info, sizeof(info)); - info.rti_info[RTAX_DST] = dst; - info.rti_info[RTAX_GATEWAY] = gateway; - info.rti_ifa = ifa; - info.rti_ifp = ifp; - info.rti_flags = flags; - - /* Setup route metrics to define expire time. */ - bzero(&rti_rmx, sizeof(rti_rmx)); - /* Set expire time as absolute. */ - rti_rmx.rmx_expire = lifetime_sec + time_second; - info.rti_mflags |= RTV_EXPIRE; - info.rti_rmx = &rti_rmx; - - error = rib_action(fibnum, RTM_ADD, &info, &rc); + struct nhop_object *nh = nhop_alloc(fibnum, dst->sa_family); + if (nh == NULL) + return (ENOMEM); + + nhop_set_gw(nh, gateway, flags & RTF_GATEWAY); + nhop_set_transmit_ifp(nh, ifp); + nhop_set_src(nh, ifa); + nhop_set_pxtype_flag(nh, NHF_HOST); + nhop_set_expire(nh, lifetime_sec + time_uptime); + nhop_set_redirect(nh, true); + rnd.rnd_nhop = nhop_get_nhop(nh, &error); + if (error == 0) { + error = rib_add_route_px(fibnum, dst, -1, + &rnd, RTM_F_CREATE, &rc); + } if (error != 0) { /* TODO: add per-fib redirect stats. */ @@ -232,10 +231,11 @@ rib_add_redirect(u_int fibnum, struct sockaddr *dst, struct sockaddr *gateway, RTSTAT_INC(rts_dynamic); /* Send notification of a route addition to userland. */ - bzero(&info, sizeof(info)); - info.rti_info[RTAX_DST] = dst; - info.rti_info[RTAX_GATEWAY] = gateway; - info.rti_info[RTAX_AUTHOR] = author; + struct rt_addrinfo info = { + .rti_info[RTAX_DST] = dst, + .rti_info[RTAX_GATEWAY] = gateway, + .rti_info[RTAX_AUTHOR] = author, + }; rt_missmsg_fib(RTM_REDIRECT, &info, flags | RTF_UP, error, fibnum); return (0); diff --git a/sys/netinet6/nd6.c b/sys/netinet6/nd6.c index 0ab629c7fcd0..0382b1525d4a 100644 --- a/sys/netinet6/nd6.c +++ b/sys/netinet6/nd6.c @@ -1575,18 +1575,15 @@ nd6_free_redirect(const struct llentry *ln) { int fibnum; struct sockaddr_in6 sin6; - struct rt_addrinfo info; struct rib_cmd_info rc; struct epoch_tracker et; lltable_fill_sa_entry(ln, (struct sockaddr *)&sin6); - memset(&info, 0, sizeof(info)); - info.rti_info[RTAX_DST] = (struct sockaddr *)&sin6; - info.rti_filter = nd6_isdynrte; NET_EPOCH_ENTER(et); for (fibnum = 0; fibnum < rt_numfibs; fibnum++) - rib_action(fibnum, RTM_DELETE, &info, &rc); + rib_del_route_px(fibnum, (struct sockaddr *)&sin6, 128, + nd6_isdynrte, NULL, 0, &rc); NET_EPOCH_EXIT(et); }