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
84
90
91
92
100
101
103
104
109
114
120
121
122
123
128
129
130
131
136
137
138
139
140
...
...
...
#define NX_SECURE_SOURCE_CODE
#include "nx_secure_dtls.h"
#ifdef NX_SECURE_ENABLE_DTLS...
...
UINT _nx_secure_dtls_session_sliding_window_check(NX_SECURE_DTLS_SESSION *dtls_session, ULONG *sequence_number)
{
ULONG window;
ULONG delta;
ULONG mask;
NX_SECURE_TLS_SESSION *tls_session;
tls_session = &dtls_session -> nx_secure_dtls_tls_session;
window = dtls_session -> nx_secure_dtls_sliding_window;
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_FALSE);
}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]))
{
/* ... */
return(NX_TRUE);
}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] + 1 == tls_session -> nx_secure_tls_remote_sequence_number[0])
{
delta = (0xFFFFFFFFul - sequence_number[1]) + tls_session -> nx_secure_tls_remote_sequence_number[1];
}if (sequence_number[0] + 1 == tls_session -> nx_secure_tls_remote_sequence_number[0]) { ... }
else 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];
}else if (sequence_number[0] == tls_session -> nx_secure_tls_remote_sequence_number[0]) { ... }
else
{
/* ... */
return(NX_FALSE);
}else { ... }
if(delta > (sizeof(window) * 8))
{
return(NX_FALSE);
}if (delta > (sizeof(window) * 8)) { ... }
mask = 0x1ul << delta;
if(window & mask)
{
return(NX_FALSE);
}if (window & mask) { ... }
return(NX_TRUE);
}_nx_secure_dtls_session_sliding_window_check (NX_SECURE_DTLS_SESSION *dtls_session, ULONG *sequence_number) { ... }
...#endif/* ... */