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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
101
102
103
104
111
112
113
114
115
116
117
118
119
120
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
149
150
151
...
...
...
#define NX_SOURCE_CODE
#include "nx_api.h"
#include "nx_rarp.h"
...
...
UINT _nx_rarp_enable(NX_IP *ip_ptr)
{
#ifndef NX_DISABLE_IPV4
TX_INTERRUPT_SAVE_AREA
UINT i, rarp_enable;
NX_TRACE_IN_LINE_INSERT(NX_TRACE_RARP_ENABLE, ip_ptr, 0, 0, 0, NX_TRACE_RARP_EVENTS, 0, 0);
TX_DISABLE
rarp_enable = NX_FALSE;
for (i = 0; i < NX_MAX_PHYSICAL_INTERFACES; i++)
{
if ((ip_ptr -> nx_ip_interface[i].nx_interface_valid == 0) ||
(ip_ptr -> nx_ip_interface[i].nx_interface_address_mapping_needed == 0))
{
continue;
}if ((ip_ptr -> nx_ip_interface[i].nx_interface_valid == 0) || (ip_ptr -> nx_ip_interface[i].nx_interface_address_mapping_needed == 0)) { ... }
if (ip_ptr -> nx_ip_interface[i].nx_interface_ip_address == 0)
{
rarp_enable = NX_TRUE;
break;
}if (ip_ptr -> nx_ip_interface[i].nx_interface_ip_address == 0) { ... }
}for (i = 0; i < NX_MAX_PHYSICAL_INTERFACES; i++) { ... }
if (rarp_enable == NX_FALSE)
{
TX_RESTORE
return(NX_IP_ADDRESS_ERROR);
}if (rarp_enable == NX_FALSE) { ... }
if (ip_ptr -> nx_ip_rarp_periodic_update)
{
TX_RESTORE
return(NX_ALREADY_ENABLED);
}if (ip_ptr -> nx_ip_rarp_periodic_update) { ... }
ip_ptr -> nx_ip_rarp_periodic_update = _nx_rarp_periodic_update;
TX_RESTORE
return(NX_SUCCESS);/* ... */
#else
NX_PARAMETER_NOT_USED(ip_ptr);
return(NX_NOT_SUPPORTED);/* ... */
#endif
}{ ... }