1
10
13
14
20
21
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
83
89
90
91
92
93
94
95
96
101
106
107
108
109
110
111
112
113
115
120
125
126
127
132
138
139
140
141
142
143
144
145
146
147
...
...
...
#define NX_SECURE_SOURCE_CODE
#include "nx_secure_dtls.h"
#ifdef NX_SECURE_ENABLE_DTLS...
...
UINT _nx_secure_dtls_session_sliding_window_update(NX_SECURE_DTLS_SESSION *dtls_session, ULONG *sequence_number)
{
ULONG delta;
ULONG mask;
NX_SECURE_TLS_SESSION *tls_session;
tls_session = &dtls_session -> nx_secure_dtls_tls_session;
if (sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0] &&
sequence_number[1] == tls_session -> nx_secure_tls_remote_sequence_number[1])
{
return(NX_SECURE_TLS_OUT_OF_ORDER_MESSAGE);
}if (sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0] && sequence_number[1] == tls_session -> nx_secure_tls_remote_sequence_number[1]) { ... }
if (sequence_number[0] < tls_session -> nx_secure_tls_remote_sequence_number[0] ||
(sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0] &&
sequence_number[1] < tls_session -> nx_secure_tls_remote_sequence_number[1]))
{
delta = 0;
if(sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0])
{
delta = tls_session -> nx_secure_tls_remote_sequence_number[1] - sequence_number[1];
}if (sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0]) { ... }
else
{
delta = (0xFFFFFFFFul - sequence_number[1]) + tls_session -> nx_secure_tls_remote_sequence_number[1];
}else { ... }
mask = 0x1ul << delta;
dtls_session -> nx_secure_dtls_sliding_window = dtls_session -> nx_secure_dtls_sliding_window | mask;
}if (sequence_number[0] < tls_session -> nx_secure_tls_remote_sequence_number[0] || (sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0] && sequence_number[1] < tls_session -> nx_secure_tls_remote_sequence_number[1])) { ... }
else
{
/* ... */
if(sequence_number[0] > tls_session -> nx_secure_tls_remote_sequence_number[0])
{
delta = (0xFFFFFFFFul - tls_session -> nx_secure_tls_remote_sequence_number[1]) + sequence_number[1];
}if (sequence_number[0] > tls_session -> nx_secure_tls_remote_sequence_number[0]) { ... }
else
{
delta = sequence_number[1] - tls_session -> nx_secure_tls_remote_sequence_number[1];
}else { ... }
if(delta > (sizeof(dtls_session -> nx_secure_dtls_sliding_window) * 8))
{
dtls_session -> nx_secure_dtls_sliding_window = 1;
}if (delta > (sizeof(dtls_session -> nx_secure_dtls_sliding_window) * 8)) { ... }
else
{
dtls_session -> nx_secure_dtls_sliding_window <<= delta;
dtls_session -> nx_secure_dtls_sliding_window |= 0x1;
}else { ... }
tls_session -> nx_secure_tls_remote_sequence_number[1] = sequence_number[1];
tls_session -> nx_secure_tls_remote_sequence_number[0] = sequence_number[0];
}else { ... }
return(NX_SUCCESS);
}_nx_secure_dtls_session_sliding_window_update (NX_SECURE_DTLS_SESSION *dtls_session, ULONG *sequence_number) { ... }
...#endif/* ... */