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 */