The branch main has been updated by melifaro:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=6d4f6e4c704d17084144ac3fe0c8507015f1357f

commit 6d4f6e4c704d17084144ac3fe0c8507015f1357f
Author:     Alexander V. Chernikov <melif...@freebsd.org>
AuthorDate: 2022-08-09 11:45:59 +0000
Commit:     Alexander V. Chernikov <melif...@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);
 }
 

Reply via email to