blob: 7f7dbf193eb30523e956461bc7126174f2b828f9 [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
Florin Corasc5df8c72019-04-08 07:42:30 -07002 * Copyright (c) 2016-2019 Cisco and/or its affiliates.
Ed Warnickecb9cada2015-12-08 15:45:58 -07003 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
Dave Barach68b0fb02017-02-28 15:15:56 -050015#ifndef __included_tcp_timer_h__
16#define __included_tcp_timer_h__
Ed Warnickecb9cada2015-12-08 15:45:58 -070017
Florin Coras0765d972020-03-18 21:26:41 +000018#include <vnet/tcp/tcp_types.h>
19
20always_inline void
21tcp_timer_set (tcp_timer_wheel_t * tw, tcp_connection_t * tc, u8 timer_id,
22 u32 interval)
23{
24 ASSERT (tc->c_thread_index == vlib_get_thread_index ());
25 ASSERT (tc->timers[timer_id] == TCP_TIMER_HANDLE_INVALID);
Florin Coras49036a52020-10-08 09:28:32 -070026 tc->timers[timer_id] = tw_timer_start_tcp_twsl (tw, tc->c_c_index,
27 timer_id, interval);
Florin Coras0765d972020-03-18 21:26:41 +000028}
29
30always_inline void
31tcp_timer_reset (tcp_timer_wheel_t * tw, tcp_connection_t * tc, u8 timer_id)
32{
33 ASSERT (tc->c_thread_index == vlib_get_thread_index ());
Florin Coras1caf7f12020-07-16 10:05:02 -070034 tc->pending_timers &= ~(1 << timer_id);
Florin Coras0765d972020-03-18 21:26:41 +000035 if (tc->timers[timer_id] == TCP_TIMER_HANDLE_INVALID)
36 return;
37
Florin Coras49036a52020-10-08 09:28:32 -070038 tw_timer_stop_tcp_twsl (tw, tc->timers[timer_id]);
Florin Coras0765d972020-03-18 21:26:41 +000039 tc->timers[timer_id] = TCP_TIMER_HANDLE_INVALID;
40}
41
42always_inline void
43tcp_timer_update (tcp_timer_wheel_t * tw, tcp_connection_t * tc, u8 timer_id,
44 u32 interval)
45{
46 ASSERT (tc->c_thread_index == vlib_get_thread_index ());
47 if (tc->timers[timer_id] != TCP_TIMER_HANDLE_INVALID)
Florin Coras49036a52020-10-08 09:28:32 -070048 tw_timer_update_tcp_twsl (tw, tc->timers[timer_id], interval);
Florin Coras0765d972020-03-18 21:26:41 +000049 else
Florin Coras49036a52020-10-08 09:28:32 -070050 tc->timers[timer_id] = tw_timer_start_tcp_twsl (tw, tc->c_c_index,
51 timer_id, interval);
Florin Coras0765d972020-03-18 21:26:41 +000052}
53
Florin Corasc8144352022-01-06 11:58:24 -080054always_inline u8
55tcp_timer_is_active (tcp_connection_t *tc, tcp_timers_e timer)
56{
57 return tc->timers[timer] != TCP_TIMER_HANDLE_INVALID ||
58 (tc->pending_timers & (1 << timer));
59}
60
Florin Coras0765d972020-03-18 21:26:41 +000061always_inline void
62tcp_retransmit_timer_set (tcp_timer_wheel_t * tw, tcp_connection_t * tc)
63{
Florin Coras55e556c2020-10-23 10:45:48 -070064 ASSERT (tc->snd_una != tc->snd_nxt);
Florin Coras0765d972020-03-18 21:26:41 +000065 tcp_timer_set (tw, tc, TCP_TIMER_RETRANSMIT,
Florin Coras273968c2022-01-03 10:34:52 -080066 clib_max ((u32) tc->rto * TCP_TO_TIMER_TICK, 1));
Florin Coras0765d972020-03-18 21:26:41 +000067}
68
69always_inline void
70tcp_retransmit_timer_reset (tcp_timer_wheel_t * tw, tcp_connection_t * tc)
71{
72 tcp_timer_reset (tw, tc, TCP_TIMER_RETRANSMIT);
73}
74
75always_inline void
Florin Coras0765d972020-03-18 21:26:41 +000076tcp_persist_timer_set (tcp_timer_wheel_t * tw, tcp_connection_t * tc)
77{
78 /* Reuse RTO. It's backed off in handler */
79 tcp_timer_set (tw, tc, TCP_TIMER_PERSIST,
Florin Coras273968c2022-01-03 10:34:52 -080080 clib_max ((u32) tc->rto * TCP_TO_TIMER_TICK, 1));
Florin Coras0765d972020-03-18 21:26:41 +000081}
82
83always_inline void
Florin Coras0765d972020-03-18 21:26:41 +000084tcp_persist_timer_reset (tcp_timer_wheel_t * tw, tcp_connection_t * tc)
85{
86 tcp_timer_reset (tw, tc, TCP_TIMER_PERSIST);
87}
88
89always_inline void
90tcp_retransmit_timer_update (tcp_timer_wheel_t * tw, tcp_connection_t * tc)
91{
92 if (tc->snd_una == tc->snd_nxt)
93 {
94 tcp_retransmit_timer_reset (tw, tc);
Florin Corasc8144352022-01-06 11:58:24 -080095 if (tc->snd_wnd < tc->snd_mss &&
96 !tcp_timer_is_active (tc, TCP_TIMER_PERSIST))
97 tcp_persist_timer_set (tw, tc);
Florin Coras0765d972020-03-18 21:26:41 +000098 }
99 else
100 tcp_timer_update (tw, tc, TCP_TIMER_RETRANSMIT,
Florin Coras273968c2022-01-03 10:34:52 -0800101 clib_max ((u32) tc->rto * TCP_TO_TIMER_TICK, 1));
Florin Coras0765d972020-03-18 21:26:41 +0000102}
103
Florin Coras49036a52020-10-08 09:28:32 -0700104always_inline void
105tcp_timer_expire_timers (tcp_timer_wheel_t * tw, f64 now)
106{
107 tw_timer_expire_timers_tcp_twsl (tw, now);
108}
109
110void tcp_timer_initialize_wheel (tcp_timer_wheel_t * tw,
111 void (*expired_timer_cb) (u32 *), f64 now);
112
Dave Barach68b0fb02017-02-28 15:15:56 -0500113#endif /* __included_tcp_timer_h__ */
114
115/*
116 * fd.io coding-style-patch-verification: ON
117 *
118 * Local Variables:
119 * eval: (c-set-style "gnu")
120 * End:
121 */