Blame view
net/x25/x25_timer.c
3.58 KB
ee5d8f4d8 treewide: Replace... |
1 |
// SPDX-License-Identifier: GPL-2.0-or-later |
1da177e4c Linux-2.6.12-rc2 |
2 3 4 5 6 |
/* * X.25 Packet Layer release 002 * * This is ALPHA test software. This code may break your machine, * randomly fail to work with new releases, misbehave and/or generally |
f8e1d2018 [NET] X25: Fix wh... |
7 |
* screw up. It might even work. |
1da177e4c Linux-2.6.12-rc2 |
8 9 10 |
* * This code REQUIRES 2.1.15 or higher * |
1da177e4c Linux-2.6.12-rc2 |
11 12 13 14 15 16 17 18 19 20 |
* History * X.25 001 Jonathan Naylor Started coding. * X.25 002 Jonathan Naylor New timer architecture. * Centralised disconnection processing. */ #include <linux/errno.h> #include <linux/jiffies.h> #include <linux/timer.h> #include <net/sock.h> |
c752f0739 [TCP]: Move the t... |
21 |
#include <net/tcp_states.h> |
1da177e4c Linux-2.6.12-rc2 |
22 |
#include <net/x25.h> |
99767f278 net/core: Convert... |
23 24 |
static void x25_heartbeat_expiry(struct timer_list *t); static void x25_timer_expiry(struct timer_list *t); |
1da177e4c Linux-2.6.12-rc2 |
25 26 27 28 |
void x25_init_timers(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); |
99767f278 net/core: Convert... |
29 |
timer_setup(&x25->timer, x25_timer_expiry, 0); |
1da177e4c Linux-2.6.12-rc2 |
30 31 |
/* initialized by sock_init_data */ |
841b86f32 treewide: Remove ... |
32 |
sk->sk_timer.function = x25_heartbeat_expiry; |
1da177e4c Linux-2.6.12-rc2 |
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
} void x25_start_heartbeat(struct sock *sk) { mod_timer(&sk->sk_timer, jiffies + 5 * HZ); } void x25_stop_heartbeat(struct sock *sk) { del_timer(&sk->sk_timer); } void x25_start_t2timer(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); mod_timer(&x25->timer, jiffies + x25->t2); } void x25_start_t21timer(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); mod_timer(&x25->timer, jiffies + x25->t21); } void x25_start_t22timer(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); mod_timer(&x25->timer, jiffies + x25->t22); } void x25_start_t23timer(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); mod_timer(&x25->timer, jiffies + x25->t23); } void x25_stop_timer(struct sock *sk) { del_timer(&x25_sk(sk)->timer); } unsigned long x25_display_timer(struct sock *sk) { struct x25_sock *x25 = x25_sk(sk); if (!timer_pending(&x25->timer)) return 0; return x25->timer.expires - jiffies; } |
99767f278 net/core: Convert... |
87 |
static void x25_heartbeat_expiry(struct timer_list *t) |
1da177e4c Linux-2.6.12-rc2 |
88 |
{ |
99767f278 net/core: Convert... |
89 |
struct sock *sk = from_timer(sk, t, sk_timer); |
1da177e4c Linux-2.6.12-rc2 |
90 |
|
f8e1d2018 [NET] X25: Fix wh... |
91 92 |
bh_lock_sock(sk); if (sock_owned_by_user(sk)) /* can currently only occur in state 3 */ |
1da177e4c Linux-2.6.12-rc2 |
93 94 95 96 97 98 99 100 101 102 103 104 105 |
goto restart_heartbeat; switch (x25_sk(sk)->state) { case X25_STATE_0: /* * Magic here: If we listen() and a new link dies * before it is accepted() it isn't 'dead' so doesn't * get removed. */ if (sock_flag(sk, SOCK_DESTROY) || (sk->sk_state == TCP_LISTEN && sock_flag(sk, SOCK_DEAD))) { |
43dff98b0 [X25]: fix for sp... |
106 |
bh_unlock_sock(sk); |
14ebaf81e x25: Fix sleep fr... |
107 |
x25_destroy_socket_from_timer(sk); |
43dff98b0 [X25]: fix for sp... |
108 |
return; |
1da177e4c Linux-2.6.12-rc2 |
109 110 111 112 113 114 115 116 117 118 119 120 |
} break; case X25_STATE_3: /* * Check for the state of the receive buffer. */ x25_check_rbuf(sk); break; } restart_heartbeat: x25_start_heartbeat(sk); |
1da177e4c Linux-2.6.12-rc2 |
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 |
bh_unlock_sock(sk); } /* * Timer has expired, it may have been T2, T21, T22, or T23. We can tell * by the state machine state. */ static inline void x25_do_timer_expiry(struct sock * sk) { struct x25_sock *x25 = x25_sk(sk); switch (x25->state) { case X25_STATE_3: /* T2 */ if (x25->condition & X25_COND_ACK_PENDING) { x25->condition &= ~X25_COND_ACK_PENDING; x25_enquiry_response(sk); } break; case X25_STATE_1: /* T21 */ case X25_STATE_4: /* T22 */ x25_write_internal(sk, X25_CLEAR_REQUEST); x25->state = X25_STATE_2; x25_start_t23timer(sk); break; case X25_STATE_2: /* T23 */ x25_disconnect(sk, ETIMEDOUT, 0, 0); break; } } |
99767f278 net/core: Convert... |
153 |
static void x25_timer_expiry(struct timer_list *t) |
1da177e4c Linux-2.6.12-rc2 |
154 |
{ |
99767f278 net/core: Convert... |
155 156 |
struct x25_sock *x25 = from_timer(x25, t, timer); struct sock *sk = &x25->sk; |
1da177e4c Linux-2.6.12-rc2 |
157 158 159 160 161 162 163 164 165 |
bh_lock_sock(sk); if (sock_owned_by_user(sk)) { /* can currently only occur in state 3 */ if (x25_sk(sk)->state == X25_STATE_3) x25_start_t2timer(sk); } else x25_do_timer_expiry(sk); bh_unlock_sock(sk); } |