]>
git.proxmox.com Git - mirror_frr.git/blob - bfdd/event.c
1 /*********************************************************************
2 * Copyright 2017-2018 Network Device Education Foundation, Inc. ("NetDEF")
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License as published by the Free
6 * Software Foundation; either version 2 of the License, or (at your option)
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * You should have received a copy of the GNU General Public License along
15 * with this program; see the file COPYING; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18 * event.c: implements the BFD loop event handlers.
22 * Rafael Zalamena <rzalamena@opensourcerouting.org>
29 void tv_normalize(struct timeval
*tv
);
31 void tv_normalize(struct timeval
*tv
)
33 /* Remove seconds part from microseconds. */
34 tv
->tv_sec
= tv
->tv_usec
/ 1000000;
35 tv
->tv_usec
= tv
->tv_usec
% 1000000;
38 void bfd_recvtimer_update(struct bfd_session
*bs
)
40 struct timeval tv
= {.tv_sec
= 0, .tv_usec
= bs
->detect_TO
};
42 /* Remove previous schedule if any. */
43 bfd_recvtimer_delete(bs
);
45 /* Don't add event if peer is deactivated. */
46 if (CHECK_FLAG(bs
->flags
, BFD_SESS_FLAG_SHUTDOWN
) ||
51 #ifdef BFD_EVENT_DEBUG
52 zlog_debug("%s: sec = %ld, usec = %ld", __func__
, tv
.tv_sec
,
54 #endif /* BFD_EVENT_DEBUG */
56 thread_add_timer_tv(master
, bfd_recvtimer_cb
, bs
, &tv
,
60 void bfd_echo_recvtimer_update(struct bfd_session
*bs
)
62 struct timeval tv
= {.tv_sec
= 0, .tv_usec
= bs
->echo_detect_TO
};
64 /* Remove previous schedule if any. */
65 bfd_echo_recvtimer_delete(bs
);
67 /* Don't add event if peer is deactivated. */
68 if (CHECK_FLAG(bs
->flags
, BFD_SESS_FLAG_SHUTDOWN
) ||
73 #ifdef BFD_EVENT_DEBUG
74 zlog_debug("%s: sec = %ld, usec = %ld", __func__
, tv
.tv_sec
,
76 #endif /* BFD_EVENT_DEBUG */
78 thread_add_timer_tv(master
, bfd_echo_recvtimer_cb
, bs
, &tv
,
79 &bs
->echo_recvtimer_ev
);
82 void bfd_xmttimer_update(struct bfd_session
*bs
, uint64_t jitter
)
84 struct timeval tv
= {.tv_sec
= 0, .tv_usec
= jitter
};
86 /* Remove previous schedule if any. */
87 bfd_xmttimer_delete(bs
);
89 /* Don't add event if peer is deactivated. */
90 if (CHECK_FLAG(bs
->flags
, BFD_SESS_FLAG_SHUTDOWN
) ||
95 #ifdef BFD_EVENT_DEBUG
96 zlog_debug("%s: sec = %ld, usec = %ld", __func__
, tv
.tv_sec
,
98 #endif /* BFD_EVENT_DEBUG */
100 thread_add_timer_tv(master
, bfd_xmt_cb
, bs
, &tv
, &bs
->xmttimer_ev
);
103 void bfd_echo_xmttimer_update(struct bfd_session
*bs
, uint64_t jitter
)
105 struct timeval tv
= {.tv_sec
= 0, .tv_usec
= jitter
};
107 /* Remove previous schedule if any. */
108 bfd_echo_xmttimer_delete(bs
);
110 /* Don't add event if peer is deactivated. */
111 if (CHECK_FLAG(bs
->flags
, BFD_SESS_FLAG_SHUTDOWN
) ||
116 #ifdef BFD_EVENT_DEBUG
117 zlog_debug("%s: sec = %ld, usec = %ld", __func__
, tv
.tv_sec
,
119 #endif /* BFD_EVENT_DEBUG */
121 thread_add_timer_tv(master
, bfd_echo_xmt_cb
, bs
, &tv
,
122 &bs
->echo_xmttimer_ev
);
125 void bfd_recvtimer_delete(struct bfd_session
*bs
)
127 THREAD_OFF(bs
->recvtimer_ev
);
130 void bfd_echo_recvtimer_delete(struct bfd_session
*bs
)
132 THREAD_OFF(bs
->echo_recvtimer_ev
);
135 void bfd_xmttimer_delete(struct bfd_session
*bs
)
137 THREAD_OFF(bs
->xmttimer_ev
);
140 void bfd_echo_xmttimer_delete(struct bfd_session
*bs
)
142 THREAD_OFF(bs
->echo_xmttimer_ev
);