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
93
94
95
102
103
107
108
109
113
114
115
116
117
118
119
120
121
122
123
127
128
129
...
...
...
#define NX_SOURCE_CODE
#include "nx_api.h"
#include "nx_ip.h"
#include "nx_arp.h"
NX_CALLER_CHECKING_EXTERNS
...
...
UINT _nxe_arp_gratuitous_send(NX_IP *ip_ptr, VOID (*response_handler)(NX_IP *ip_ptr, NX_PACKET *packet_ptr))
{
#ifndef NX_DISABLE_IPV4
UINT status;
UINT i;
if ((ip_ptr == NX_NULL) || (ip_ptr -> nx_ip_id != NX_IP_ID))
{
return(NX_PTR_ERROR);
}if ((ip_ptr == NX_NULL) || (ip_ptr -> nx_ip_id != NX_IP_ID)) { ... }
for (i = 0; i < NX_MAX_PHYSICAL_INTERFACES; i++)
{
if (ip_ptr -> nx_ip_interface[i].nx_interface_ip_address)
{
break;
}if (ip_ptr -> nx_ip_interface[i].nx_interface_ip_address) { ... }
}for (i = 0; i < NX_MAX_PHYSICAL_INTERFACES; i++) { ... }
if (i == NX_MAX_PHYSICAL_INTERFACES)
{
return(NX_IP_ADDRESS_ERROR);
}if (i == NX_MAX_PHYSICAL_INTERFACES) { ... }
if (!ip_ptr -> nx_ip_arp_allocate)
{
return(NX_NOT_ENABLED);
}if (!ip_ptr -> nx_ip_arp_allocate) { ... }
NX_THREADS_ONLY_CALLER_CHECKING
status = _nx_arp_gratuitous_send(ip_ptr, response_handler);
return(status);/* ... */
#else
NX_PARAMETER_NOT_USED(ip_ptr);
NX_PARAMETER_NOT_USED(response_handler);
return(NX_NOT_SUPPORTED);/* ... */
#endif
}{ ... }