Select one of the symbols to view example projects that use it.
 
Outline
...
...
...
...
#define NX_SOURCE_CODE
#include "nx_api.h"
#include "nx_arp.h"
...
_nx_arp_entry_allocate(NX_IP *, NX_ARP **, UINT)
Files
loading...
SourceVuSTM32 Libraries and Samplesnetxduocommon/src/nx_arp_entry_allocate.c
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/**************************************************************************/ /* */ /* Copyright (c) Microsoft Corporation. All rights reserved. */ /* */ /* This software is licensed under the Microsoft Software License */ /* Terms for Microsoft Azure RTOS. Full text of the license can be */ /* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */ /* and in the root directory of this software. */ /* */... /**************************************************************************/ ... /**************************************************************************/ /**************************************************************************/ /** */ /** NetX Component */ /** */ /** Address Resolution Protocol (ARP) */ /** */... /**************************************************************************/ /**************************************************************************/ #define NX_SOURCE_CODE /* Include necessary system files. */ #include "nx_api.h" #include "nx_arp.h" #ifndef NX_DISABLE_IPV4... /**************************************************************************/ /* */ /* FUNCTION RELEASE */ /* */ /* _nx_arp_entry_allocate PORTABLE C */ /* 6.1 */ /* AUTHOR */ /* */ /* Yuxin Zhou, Microsoft Corporation */ /* */ /* DESCRIPTION */ /* */ /* This function allocates an ARP entry for a specific new IP */ /* destination. */ /* */ /* INPUT */ /* */ /* ip_ptr IP instance pointer */ /* arp_list_ptr List head of where to place */ /* the newly allocated ARP */ /* entry */ /* is_static Entry attribute static/dynamic*/ /* */ /* OUTPUT */ /* */ /* status Completion status */ /* */ /* CALLS */ /* */ /* _nx_arp_dynamic_entry_delete Delete the dynamic entry */ /* */ /* CALLED BY */ /* */ /* NetX Source Code */ /* */ /* RELEASE HISTORY */ /* */ /* DATE NAME DESCRIPTION */ /* */ /* 05-19-2020 Yuxin Zhou Initial Version 6.0 */ /* 09-30-2020 Yuxin Zhou Modified comment(s), */ /* resulting in version 6.1 */ /* */... /**************************************************************************/ UINT _nx_arp_entry_allocate(NX_IP *ip_ptr, NX_ARP **arp_list_ptr, UINT is_static) { TX_INTERRUPT_SAVE_AREA NX_ARP *arp_entry; UINT status; /* Determine if there is an ARP entry available in the dynamic list. */ if (ip_ptr -> nx_ip_arp_dynamic_list) { /* Yes there are one or more free entries. */ /* Pickup pointer to last used dynamic ARP entry. */ arp_entry = (ip_ptr -> nx_ip_arp_dynamic_list) -> nx_arp_pool_previous; /* Remove from the dynamic list. */ _nx_arp_dynamic_entry_delete(ip_ptr, arp_entry); /* Disable interrupts temporarily. */ TX_DISABLE /* Link the ARP entry at the head of the IP list. */ /* Determine if the ARP entry is being added to an empty list. */ if (*arp_list_ptr) { /* Add the ARP entry to the beginning of the nonempty ARP list. *//* ... */ arp_entry -> nx_arp_active_list_head = arp_list_ptr; arp_entry -> nx_arp_active_next = *arp_list_ptr; arp_entry -> nx_arp_active_previous = (*arp_list_ptr) -> nx_arp_active_previous; (arp_entry -> nx_arp_active_previous) -> nx_arp_active_next = arp_entry; (*arp_list_ptr) -> nx_arp_active_previous = arp_entry; }if (*arp_list_ptr) { ... } else { /* Empty list, just put the ARP entry at the beginning. */ arp_entry -> nx_arp_active_list_head = arp_list_ptr; arp_entry -> nx_arp_active_next = arp_entry; arp_entry -> nx_arp_active_previous = arp_entry; /* Now setup the list head. */ *arp_list_ptr = arp_entry; }else { ... } /* Determine if this is a static entry. */ if (is_static == NX_TRUE) { /* Remove this entry from the ARP dynamic list. */ /* Determine if this is the only ARP entry on the dynamic list. */ if (arp_entry == arp_entry -> nx_arp_pool_next) { /* Remove the sole entry from the dynamic list head. */ ip_ptr -> nx_ip_arp_dynamic_list = NX_NULL; }if (arp_entry == arp_entry -> nx_arp_pool_next) { ... } else { /* Remove the entry from a list of more than one entry. */ /* Update the links of the adjacent ARP dynamic pool entries. */ (arp_entry -> nx_arp_pool_next) -> nx_arp_pool_previous = arp_entry -> nx_arp_pool_previous; (arp_entry -> nx_arp_pool_previous) -> nx_arp_pool_next = arp_entry -> nx_arp_pool_next; }else { ... } /* Add the entry to the ARP static list. */ /* Determine if the ARP static list is empty. */ if (ip_ptr -> nx_ip_arp_static_list == NX_NULL) { /* Just place this single ARP entry on the list. */ arp_entry -> nx_arp_pool_next = arp_entry; arp_entry -> nx_arp_pool_previous = arp_entry; ip_ptr -> nx_ip_arp_static_list = arp_entry; }if (ip_ptr -> nx_ip_arp_static_list == NX_NULL) { ... } else { /* Add to the end of the ARP static list. */ arp_entry -> nx_arp_pool_next = ip_ptr -> nx_ip_arp_static_list; arp_entry -> nx_arp_pool_previous = (ip_ptr -> nx_ip_arp_static_list) -> nx_arp_pool_previous; ((ip_ptr -> nx_ip_arp_static_list) -> nx_arp_pool_previous) -> nx_arp_pool_next = arp_entry; (ip_ptr -> nx_ip_arp_static_list) -> nx_arp_pool_previous = arp_entry; }else { ... } #ifndef NX_DISABLE_ARP_INFO /* Increment the ARP static entry count. */ ip_ptr -> nx_ip_arp_static_entries++;/* ... */ #endif }if (is_static == NX_TRUE) { ... } else /* Allocate entry from dynamic list. */ { /* Move this ARP entry to the front of the general ARP dynamic entry pool. */ if (arp_entry != ip_ptr -> nx_ip_arp_dynamic_list) { /* The current ARP entry is not at the front of the list, so it must be moved. *//* ... */ /* Link up the neighbors first. */ (arp_entry -> nx_arp_pool_next) -> nx_arp_pool_previous = arp_entry -> nx_arp_pool_previous; (arp_entry -> nx_arp_pool_previous) -> nx_arp_pool_next = arp_entry -> nx_arp_pool_next; /* Now link this ARP entry to the head of the list. */ arp_entry -> nx_arp_pool_next = ip_ptr -> nx_ip_arp_dynamic_list; arp_entry -> nx_arp_pool_previous = (arp_entry -> nx_arp_pool_next) -> nx_arp_pool_previous; (arp_entry -> nx_arp_pool_previous) -> nx_arp_pool_next = arp_entry; (arp_entry -> nx_arp_pool_next) -> nx_arp_pool_previous = arp_entry; /* Now set the list head to this ARP entry. */ ip_ptr -> nx_ip_arp_dynamic_list = arp_entry; }if (arp_entry != ip_ptr -> nx_ip_arp_dynamic_list) { ... } /* Increment the number of active dynamic entries. */ ip_ptr -> nx_ip_arp_dynamic_active_count++; }else { ... } /* Set the entry type. */ arp_entry -> nx_arp_route_static = is_static; /* Restore interrupts. */ TX_RESTORE /* Setup a successful status return. */ status = NX_SUCCESS; }if (ip_ptr -> nx_ip_arp_dynamic_list) { ... } else { /* No more ARP entries are available, all the ARP entries must be allocated on the static list. *//* ... */ status = NX_NO_MORE_ENTRIES; }else { ... } /* Return status to the caller. */ return(status); }{ ... } #endif/* ... */ /* !NX_DISABLE_IPV4 */
Details