1
10
13
14
20
21
22
23
24
25
26
27
28
29
30
31
32
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
87
88
90
91
92
93
94
95
97
98
99
100
109
110
111
112
113
114
115
116
117
118
119
120
126
127
128
129
130
132
139
140
141
...
...
...
#define NX_SOURCE_CODE
#include "nx_api.h"
#include "nx_ip.h"
#include "nx_tcp.h"
...
...
VOID _nx_tcp_socket_state_established(NX_TCP_SOCKET *socket_ptr)
{
#if !defined(NX_DISABLE_TCP_INFO) || defined(TX_ENABLE_EVENT_TRACE)
NX_IP *ip_ptr;
ip_ptr = socket_ptr -> nx_tcp_socket_ip_ptr;/* ... */
#endif
/* ... */
if ((socket_ptr -> nx_tcp_socket_fin_received) &&
(socket_ptr -> nx_tcp_socket_fin_sequence == socket_ptr -> nx_tcp_socket_rx_sequence))
{
#ifndef NX_DISABLE_TCP_INFO
ip_ptr -> nx_ip_tcp_disconnections++;/* ... */
#endif
#ifdef NX_ENABLE_TCP_KEEPALIVE
if (socket_ptr -> nx_tcp_socket_keepalive_enabled)
{
/* ... */
socket_ptr -> nx_tcp_socket_keepalive_timeout = 0;
socket_ptr -> nx_tcp_socket_keepalive_retries = 0;
}if (socket_ptr -> nx_tcp_socket_keepalive_enabled) { ... }
/* ... */#endif
NX_TRACE_IN_LINE_INSERT(NX_TRACE_INTERNAL_TCP_STATE_CHANGE, ip_ptr, socket_ptr, socket_ptr -> nx_tcp_socket_state, NX_TCP_CLOSE_WAIT, NX_TRACE_INTERNAL_EVENTS, 0, 0);
socket_ptr -> nx_tcp_socket_state = NX_TCP_CLOSE_WAIT;
socket_ptr -> nx_tcp_socket_rx_sequence++;
while (socket_ptr -> nx_tcp_socket_receive_suspension_list)
{
_nx_tcp_receive_cleanup(socket_ptr -> nx_tcp_socket_receive_suspension_list NX_CLEANUP_ARGUMENT);
}while (socket_ptr -> nx_tcp_socket_receive_suspension_list) { ... }
_nx_tcp_packet_send_ack(socket_ptr, socket_ptr -> nx_tcp_socket_tx_sequence);
/* ... */
if (socket_ptr -> nx_tcp_disconnect_callback)
{
/* ... */
(socket_ptr -> nx_tcp_disconnect_callback)(socket_ptr);
}if (socket_ptr -> nx_tcp_disconnect_callback) { ... }
}if ((socket_ptr -> nx_tcp_socket_fin_received) && (socket_ptr -> nx_tcp_socket_fin_sequence == socket_ptr -> nx_tcp_socket_rx_sequence)) { ... }
}{ ... }