The callback currently uses struct rttimer as an argument but the code
only needs the rtt_tableid element from there. Change the callbacks to
be of the form void (*rtt_callback)(struct rtentry *r, u_int rtableid)

Also change the default rttimer callback (in case the function is NULL)
to only handle routes with RTF_HOST and RTF_DYNAMIC set. By doing this
two rttimer queues can be switched to a NULL callback. The other option
would be to require always a callback. Right now nothing uses the default
so it should be removed or made useful.

As a next step I plan to move the callback to struct rttimer_queue since
all rt_timer_add calls use the same callback.

-- 
:wq Claudio

Index: net/route.c
===================================================================
RCS file: /cvs/src/sys/net/route.c,v
retrieving revision 1.407
diff -u -p -r1.407 route.c
--- net/route.c 28 Apr 2022 17:47:41 -0000      1.407
+++ net/route.c 29 Apr 2022 09:42:09 -0000
@@ -1366,12 +1366,14 @@ LIST_HEAD(, rttimer_queue)      rttimer_queue
 
 #define RTTIMER_CALLOUT(r)     {                                       \
        if (r->rtt_func != NULL) {                                      \
-               (*r->rtt_func)(r->rtt_rt, r);                           \
+               (*r->rtt_func)(r->rtt_rt, r->rtt_tableid);              \
        } else {                                                        \
                struct ifnet *ifp;                                      \
                                                                        \
                ifp = if_get(r->rtt_rt->rt_ifidx);                      \
-               if (ifp != NULL)                                        \
+               if (ifp != NULL &&                                      \
+                   (r->rtt_rt->rt_flags & (RTF_DYNAMIC|RTF_HOST)) ==   \
+                   (RTF_DYNAMIC|RTF_HOST))                             \
                        rtdeletemsg(r->rtt_rt, ifp, r->rtt_tableid);    \
                if_put(ifp);                                            \
        }                                                               \
@@ -1484,8 +1486,8 @@ rt_timer_remove_all(struct rtentry *rt)
 }
 
 int
-rt_timer_add(struct rtentry *rt, void (*func)(struct rtentry *,
-    struct rttimer *), struct rttimer_queue *queue, u_int rtableid)
+rt_timer_add(struct rtentry *rt, void (*func)(struct rtentry *, u_int),
+     struct rttimer_queue *queue, u_int rtableid)
 {
        struct rttimer  *r, *rnew;
        time_t           current_time;
Index: net/route.h
===================================================================
RCS file: /cvs/src/sys/net/route.h,v
retrieving revision 1.191
diff -u -p -r1.191 route.h
--- net/route.h 28 Apr 2022 17:47:41 -0000      1.191
+++ net/route.h 29 Apr 2022 09:30:27 -0000
@@ -411,7 +411,7 @@ struct rttimer {
        struct rttimer_queue    *rtt_queue;     /* [T] back pointer to queue */
        struct rtentry          *rtt_rt;        /* [I] back pointer to route */
        void                    (*rtt_func)     /* [I] callback */
-                                   (struct rtentry *, struct rttimer *);
+                                   (struct rtentry *, u_int);
        time_t                  rtt_time;       /* [I] when timer registered */
        u_int                   rtt_tableid;    /* [I] rtable id of rtt_rt */
 };
@@ -459,7 +459,7 @@ struct rtentry *rt_getll(struct rtentry 
 
 void                    rt_timer_init(void);
 int                     rt_timer_add(struct rtentry *,
-                           void(*)(struct rtentry *, struct rttimer *),
+                           void(*)(struct rtentry *, u_int),
                            struct rttimer_queue *, u_int);
 void                    rt_timer_remove_all(struct rtentry *);
 struct rttimer_queue   *rt_timer_queue_create(int);
Index: netinet/ip_icmp.c
===================================================================
RCS file: /cvs/src/sys/netinet/ip_icmp.c,v
retrieving revision 1.188
diff -u -p -r1.188 ip_icmp.c
--- netinet/ip_icmp.c   20 Apr 2022 09:38:26 -0000      1.188
+++ netinet/ip_icmp.c   29 Apr 2022 09:41:25 -0000
@@ -132,9 +132,8 @@ const struct sysctl_bounded_args icmpctl
 };
 
 
-void icmp_mtudisc_timeout(struct rtentry *, struct rttimer *);
+void icmp_mtudisc_timeout(struct rtentry *, u_int);
 int icmp_ratelimit(const struct in_addr *, const int, const int);
-void icmp_redirect_timeout(struct rtentry *, struct rttimer *);
 int icmp_input_if(struct ifnet *, struct mbuf **, int *, int, int);
 int icmp_sysctl_icmpstat(void *, size_t *, void *);
 
@@ -634,8 +633,8 @@ reflect:
                rtredirect(sintosa(&sdst), sintosa(&sgw),
                    sintosa(&ssrc), &newrt, m->m_pkthdr.ph_rtableid);
                if (newrt != NULL && icmp_redirtimeout > 0) {
-                       rt_timer_add(newrt, icmp_redirect_timeout,
-                           icmp_redirect_timeout_q, m->m_pkthdr.ph_rtableid);
+                       rt_timer_add(newrt, NULL, icmp_redirect_timeout_q,
+                           m->m_pkthdr.ph_rtableid);
                }
                rtfree(newrt);
                pfctlinput(PRC_REDIRECT_HOST, sintosa(&sdst));
@@ -1053,7 +1052,7 @@ icmp_mtudisc(struct icmp *icp, u_int rta
 }
 
 void
-icmp_mtudisc_timeout(struct rtentry *rt, struct rttimer *r)
+icmp_mtudisc_timeout(struct rtentry *rt, u_int rtableid)
 {
        struct ifnet *ifp;
 
@@ -1069,13 +1068,13 @@ icmp_mtudisc_timeout(struct rtentry *rt,
 
                sin = *satosin(rt_key(rt));
 
-               rtdeletemsg(rt, ifp, r->rtt_tableid);
+               rtdeletemsg(rt, ifp, rtableid);
 
                /* Notify TCP layer of increased Path MTU estimate */
                ctlfunc = inetsw[ip_protox[IPPROTO_TCP]].pr_ctlinput;
                if (ctlfunc)
                        (*ctlfunc)(PRC_MTUINC, sintosa(&sin),
-                           r->rtt_tableid, NULL);
+                           rtableid, NULL);
        } else {
                if ((rt->rt_locks & RTV_MTU) == 0)
                        rt->rt_mtu = 0;
@@ -1100,24 +1099,6 @@ icmp_ratelimit(const struct in_addr *dst
            icmperrppslim))
                return 1;       /* The packet is subject to rate limit */
        return 0;       /* okay to send */
-}
-
-void
-icmp_redirect_timeout(struct rtentry *rt, struct rttimer *r)
-{
-       struct ifnet *ifp;
-
-       NET_ASSERT_LOCKED();
-
-       ifp = if_get(rt->rt_ifidx);
-       if (ifp == NULL)
-               return;
-
-       if ((rt->rt_flags & (RTF_DYNAMIC|RTF_HOST)) == (RTF_DYNAMIC|RTF_HOST)) {
-               rtdeletemsg(rt, ifp, r->rtt_tableid);
-       }
-
-       if_put(ifp);
 }
 
 int
Index: netinet/ip_mroute.c
===================================================================
RCS file: /cvs/src/sys/netinet/ip_mroute.c,v
retrieving revision 1.132
diff -u -p -r1.132 ip_mroute.c
--- netinet/ip_mroute.c 28 Apr 2022 17:27:14 -0000      1.132
+++ netinet/ip_mroute.c 29 Apr 2022 09:35:45 -0000
@@ -113,7 +113,7 @@ int get_version(struct mbuf *);
 int add_vif(struct socket *, struct mbuf *);
 int del_vif(struct socket *, struct mbuf *);
 void update_mfc_params(struct mfcctl2 *, int, unsigned int);
-void mfc_expire_route(struct rtentry *, struct rttimer *);
+void mfc_expire_route(struct rtentry *, u_int);
 int mfc_add(struct mfcctl2 *, struct in_addr *, struct in_addr *,
     int, unsigned int, int);
 int add_mfc(struct socket *, struct mbuf *);
@@ -777,10 +777,9 @@ vif_delete(struct ifnet *ifp)
 }
 
 void
-mfc_expire_route(struct rtentry *rt, struct rttimer *rtt)
+mfc_expire_route(struct rtentry *rt, u_int rtableid)
 {
        struct mfc      *mfc = (struct mfc *)rt->rt_llinfo;
-       unsigned int     rtableid = rtt->rtt_tableid;
 
        /* Skip entry being deleted. */
        if (mfc == NULL)
Index: netinet6/icmp6.c
===================================================================
RCS file: /cvs/src/sys/netinet6/icmp6.c,v
retrieving revision 1.239
diff -u -p -r1.239 icmp6.c
--- netinet6/icmp6.c    20 Apr 2022 09:38:26 -0000      1.239
+++ netinet6/icmp6.c    29 Apr 2022 09:43:28 -0000
@@ -137,8 +137,7 @@ int icmp6_ratelimit(const struct in6_add
 const char *icmp6_redirect_diag(struct in6_addr *, struct in6_addr *,
            struct in6_addr *);
 int    icmp6_notify_error(struct mbuf *, int, int, int);
-void   icmp6_mtudisc_timeout(struct rtentry *, struct rttimer *);
-void   icmp6_redirect_timeout(struct rtentry *, struct rttimer *);
+void   icmp6_mtudisc_timeout(struct rtentry *, u_int);
 
 void
 icmp6_init(void)
@@ -1405,8 +1404,8 @@ icmp6_redirect_input(struct mbuf *m, int
                rtredirect(sin6tosa(&sdst), sin6tosa(&sgw), sin6tosa(&ssrc),
                    &newrt, m->m_pkthdr.ph_rtableid);
                if (newrt != NULL && icmp6_redirtimeout > 0) {
-                       rt_timer_add(newrt, icmp6_redirect_timeout,
-                           icmp6_redirect_timeout_q, m->m_pkthdr.ph_rtableid);
+                       rt_timer_add(newrt, NULL, icmp6_redirect_timeout_q,
+                           m->m_pkthdr.ph_rtableid);
                }
                rtfree(newrt);
        }
@@ -1841,7 +1840,7 @@ bad:
 }
 
 void
-icmp6_mtudisc_timeout(struct rtentry *rt, struct rttimer *r)
+icmp6_mtudisc_timeout(struct rtentry *rt, u_int rtableid)
 {
        struct ifnet *ifp;
 
@@ -1852,28 +1851,10 @@ icmp6_mtudisc_timeout(struct rtentry *rt
                return;
 
        if ((rt->rt_flags & (RTF_DYNAMIC|RTF_HOST)) == (RTF_DYNAMIC|RTF_HOST)) {
-               rtdeletemsg(rt, ifp, r->rtt_tableid);
+               rtdeletemsg(rt, ifp, rtableid);
        } else {
                if (!(rt->rt_locks & RTV_MTU))
                        rt->rt_mtu = 0;
-       }
-
-       if_put(ifp);
-}
-
-void
-icmp6_redirect_timeout(struct rtentry *rt, struct rttimer *r)
-{
-       struct ifnet *ifp;
-
-       NET_ASSERT_LOCKED();
-
-       ifp = if_get(rt->rt_ifidx);
-       if (ifp == NULL)
-               return;
-
-       if ((rt->rt_flags & (RTF_DYNAMIC|RTF_HOST)) == (RTF_DYNAMIC|RTF_HOST)) {
-               rtdeletemsg(rt, ifp, r->rtt_tableid);
        }
 
        if_put(ifp);
Index: netinet6/ip6_mroute.c
===================================================================
RCS file: /cvs/src/sys/netinet6/ip6_mroute.c,v
retrieving revision 1.128
diff -u -p -r1.128 ip6_mroute.c
--- netinet6/ip6_mroute.c       28 Apr 2022 17:27:14 -0000      1.128
+++ netinet6/ip6_mroute.c       29 Apr 2022 09:32:56 -0000
@@ -176,7 +176,7 @@ struct rtentry *mf6c_find(struct ifnet *
 struct rtentry *mrt6_mcast_add(struct ifnet *, struct sockaddr *,
     struct sockaddr *);
 void mrt6_mcast_del(struct rtentry *, unsigned int);
-void mf6c_expire_route(struct rtentry *, struct rttimer *);
+void mf6c_expire_route(struct rtentry *, u_int);
 
 /*
  * Handle MRT setsockopt commands to modify the multicast routing tables.
@@ -984,10 +984,9 @@ ip6_mforward(struct ip6_hdr *ip6, struct
 }
 
 void
-mf6c_expire_route(struct rtentry *rt, struct rttimer *rtt)
+mf6c_expire_route(struct rtentry *rt, u_int rtableid)
 {
        struct mf6c *mf6c = (struct mf6c *)rt->rt_llinfo;
-       unsigned int rtableid = rtt->rtt_tableid;
 #ifdef MCAST_DEBUG
        char bsrc[INET6_ADDRSTRLEN], bdst[INET6_ADDRSTRLEN];
 #endif /* MCAST_DEBUG */

Reply via email to