blob: 042466a20b2af67703cbc54939783aad51ee7032 [file] [log] [blame]
akmhoque8a5babe2012-08-16 17:39:33 -05001#include<stdio.h>
2#include<string.h>
3#include<stdlib.h>
akmhoque9fa58a82012-10-05 07:56:02 -05004#include<math.h>
akmhoque8a5babe2012-08-16 17:39:33 -05005#include <unistd.h>
6#include <getopt.h>
7#include <sys/time.h>
8#include <assert.h>
9#ifdef HAVE_CONFIG_H
10#include <config.h>
akmhoqueb77b95f2013-02-08 12:28:47 -060011#include <sys/socket.h>
12#include <netdb.h>
13#include <netinet/in.h>
14#include <arpa/inet.h>
akmhoque8a5babe2012-08-16 17:39:33 -050015#endif
16
17
18#include <ccn/ccn.h>
19#include <ccn/uri.h>
20#include <ccn/keystore.h>
21#include <ccn/signing.h>
22#include <ccn/schedule.h>
23#include <ccn/hashtb.h>
24
25#include "nlsr.h"
akmhoque03004e62012-09-06 01:12:28 -050026#include "nlsr_npl.h"
akmhoque8a5babe2012-08-16 17:39:33 -050027#include "nlsr_adl.h"
akmhoque03004e62012-09-06 01:12:28 -050028#include "utility.h"
akmhoquefbfd0982012-09-09 20:59:03 -050029#include "nlsr_npt.h"
akmhoque8a5babe2012-08-16 17:39:33 -050030
akmhoque03004e62012-09-06 01:12:28 -050031void
akmhoqueb77b95f2013-02-08 12:28:47 -060032add_nbr_to_adl(struct name_prefix *new_nbr,int face,char *ip)
akmhoque8a5babe2012-08-16 17:39:33 -050033{
akmhoque03004e62012-09-06 01:12:28 -050034 struct ndn_neighbor *nbr=(struct ndn_neighbor *)malloc(sizeof(struct ndn_neighbor )); //free
akmhoque53f64222012-09-05 13:57:51 -050035
akmhoque8a5babe2012-08-16 17:39:33 -050036 struct hashtb_enumerator ee;
37 struct hashtb_enumerator *e = &ee;
38 int res;
39
40 hashtb_start(nlsr->adl, e);
akmhoque03004e62012-09-06 01:12:28 -050041 res = hashtb_seek(e, new_nbr->name, new_nbr->length, 0);
akmhoque2852a222012-08-21 12:09:00 -040042
akmhoquee7c4b6d2012-08-21 12:30:25 -040043 if(res == HT_NEW_ENTRY )
44 {
akmhoque8a5babe2012-08-16 17:39:33 -050045
akmhoque53f64222012-09-05 13:57:51 -050046 nbr = e->data;
akmhoque8a5babe2012-08-16 17:39:33 -050047
akmhoque03004e62012-09-06 01:12:28 -050048 nbr->neighbor=(struct name_prefix *)malloc(sizeof( struct name_prefix )); //free
49 nbr->neighbor->name=(char *)malloc(new_nbr->length);
50 memcpy(nbr->neighbor->name,new_nbr->name,new_nbr->length);
51 nbr->neighbor->length=new_nbr->length;
akmhoque53f64222012-09-05 13:57:51 -050052 nbr->face=face;
53 nbr->status=NBR_DOWN;
54 nbr->info_interest_timed_out=0;
akmhoque14b3f342012-09-14 10:39:02 -050055 nbr->lsdb_interest_timed_out=0;
56 nbr->lsdb_random_time_component=(int)(LSDB_SYNCH_INTERVAL/2);
57 nbr->lsdb_synch_interval=LSDB_SYNCH_INTERVAL;
58 nbr->metric=LINK_METRIC;
akmhoque53f64222012-09-05 13:57:51 -050059 nbr->is_lsdb_send_interest_scheduled=0;
60
akmhoqueb77b95f2013-02-08 12:28:47 -060061 nbr->ip_address=(char *)malloc(13);
62 memset(nbr->ip_address,0,13);
63 memcpy(nbr->ip_address,ip,strlen(ip));
akmhoque8a5babe2012-08-16 17:39:33 -050064
akmhoque03004e62012-09-06 01:12:28 -050065 char *time_stamp=(char *)malloc(20);
66 get_current_timestamp_micro(time_stamp);
67 nbr->last_lsdb_version=(char *)malloc(strlen(time_stamp)+1); //free
akmhoque53f64222012-09-05 13:57:51 -050068 memcpy(nbr->last_lsdb_version,time_stamp,strlen(time_stamp)+1);
69 memset(nbr->last_lsdb_version,'0',strlen(time_stamp));
akmhoque03004e62012-09-06 01:12:28 -050070 nbr->last_info_version=(char *)malloc(strlen(time_stamp)+1); //free
71 memcpy(nbr->last_info_version,time_stamp,strlen(time_stamp)+1);
72 memset(nbr->last_info_version,'0',strlen(time_stamp));
73 free(time_stamp);
akmhoque53f64222012-09-05 13:57:51 -050074
75 nbr->last_lsdb_requested=0;
akmhoquee7c4b6d2012-08-21 12:30:25 -040076 }
akmhoque53f64222012-09-05 13:57:51 -050077
akmhoque8a5babe2012-08-16 17:39:33 -050078 hashtb_end(e);
akmhoque53f64222012-09-05 13:57:51 -050079}
akmhoque8a5babe2012-08-16 17:39:33 -050080
akmhoque03004e62012-09-06 01:12:28 -050081
akmhoque53f64222012-09-05 13:57:51 -050082void
83print_adjacent(struct ndn_neighbor *nbr)
84{
akmhoque7b791452012-10-30 11:24:56 -050085 if ( nlsr->debugging )
86 {
87 printf("print_adjacent called\n");
88 printf("--------Neighbor---------------------------\n");
89 printf(" Neighbor: %s \n",nbr->neighbor->name);
90 printf(" Length : %d \n",nbr->neighbor->length);
akmhoqueb77b95f2013-02-08 12:28:47 -060091 printf(" Ip Address: %s \n",nbr->ip_address);
akmhoque7b791452012-10-30 11:24:56 -050092 printf(" Face : %d \n",nbr->face);
93 printf(" Metric : %d \n",nbr->metric);
94 printf(" Status : %d \n",nbr->status);
95 printf(" LSDB Version: %s \n",nbr->last_lsdb_version);
96 printf(" Info Version: %s \n",nbr->last_info_version);
97 printf(" Info Interest Timed Out : %d \n",nbr->info_interest_timed_out);
98 printf(" LSDB Interest Timed Out : %d \n",nbr->lsdb_interest_timed_out);
99 printf(" LSDB Synch Interval : %ld \n",nbr->lsdb_synch_interval);
100 printf(" LSDB Random Time comp : %d \n",nbr->lsdb_random_time_component);
101 printf(" Las Time LSDB Requested: %ld \n",nbr->last_lsdb_requested);
102 printf(" IS_lsdb_send_interest_scheduled : %d \n",nbr->is_lsdb_send_interest_scheduled);
akmhoque03004e62012-09-06 01:12:28 -0500103
akmhoque7b791452012-10-30 11:24:56 -0500104 printf("\n");
105 }
106
107 if ( nlsr->detailed_logging )
108 {
109
110 writeLogg(__FILE__,__FUNCTION__,__LINE__,"print_adjacent called\n");
111 writeLogg(__FILE__,__FUNCTION__,__LINE__,"--------Neighbor---------------------------\n");
112 writeLogg(__FILE__,__FUNCTION__,__LINE__," Neighbor: %s \n",nbr->neighbor->name);
113 writeLogg(__FILE__,__FUNCTION__,__LINE__," Length : %d \n",nbr->neighbor->length);
114 writeLogg(__FILE__,__FUNCTION__,__LINE__," Face : %d \n",nbr->face);
115 writeLogg(__FILE__,__FUNCTION__,__LINE__," Metric : %d \n",nbr->metric);
116 writeLogg(__FILE__,__FUNCTION__,__LINE__," Status : %d \n",nbr->status);
117 writeLogg(__FILE__,__FUNCTION__,__LINE__," LSDB Version: %s \n",nbr->last_lsdb_version);
118 writeLogg(__FILE__,__FUNCTION__,__LINE__," Info Version: %s \n",nbr->last_info_version);
119 writeLogg(__FILE__,__FUNCTION__,__LINE__," Info Interest Timed Out : %d \n",nbr->info_interest_timed_out);
120 writeLogg(__FILE__,__FUNCTION__,__LINE__," LSDB Interest Timed Out : %d \n",nbr->lsdb_interest_timed_out);
121 writeLogg(__FILE__,__FUNCTION__,__LINE__," LSDB Synch Interval : %ld \n",nbr->lsdb_synch_interval);
122 writeLogg(__FILE__,__FUNCTION__,__LINE__," LSDB Random Time comp : %d \n",nbr->lsdb_random_time_component);
123 writeLogg(__FILE__,__FUNCTION__,__LINE__," Las Time LSDB Requested: %ld \n",nbr->last_lsdb_requested);
124 writeLogg(__FILE__,__FUNCTION__,__LINE__," IS_lsdb_send_interest_scheduled : %d \n",nbr->is_lsdb_send_interest_scheduled);
125
126 writeLogg(__FILE__,__FUNCTION__,__LINE__,"\n");
127 }
akmhoque8a5babe2012-08-16 17:39:33 -0500128
129}
130
131void
132print_adjacent_from_adl(void)
133{
akmhoque7b791452012-10-30 11:24:56 -0500134 if ( nlsr->debugging )
135 printf("print_adjacent_from_adl called \n");
136 if ( nlsr->detailed_logging )
137 writeLogg(__FILE__,__FUNCTION__,__LINE__,"print_adjacent_from_adl called \n");
138
akmhoque8a5babe2012-08-16 17:39:33 -0500139 int i, adl_element;
140 struct ndn_neighbor *nbr;
141
142 struct hashtb_enumerator ee;
143 struct hashtb_enumerator *e = &ee;
144
145 hashtb_start(nlsr->adl, e);
146 adl_element=hashtb_n(nlsr->adl);
147
148 for(i=0;i<adl_element;i++)
149 {
150 nbr=e->data;
akmhoque53f64222012-09-05 13:57:51 -0500151 print_adjacent(nbr);
akmhoque8a5babe2012-08-16 17:39:33 -0500152 hashtb_next(e);
153 }
154
155 hashtb_end(e);
156
akmhoque8a5babe2012-08-16 17:39:33 -0500157}
158
akmhoque03004e62012-09-06 01:12:28 -0500159int
160get_adjacent_status(struct name_prefix *nbr)
161{
akmhoque7b791452012-10-30 11:24:56 -0500162
163 if ( nlsr->debugging )
164 printf("get_adjacent_status called \n");
165 if ( nlsr->detailed_logging )
166 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_adjacent_status called \n");
akmhoque03004e62012-09-06 01:12:28 -0500167
168 int res;
169 int status=-1;
170 struct ndn_neighbor *nnbr;
171
172 struct hashtb_enumerator ee;
173 struct hashtb_enumerator *e = &ee;
174
175 hashtb_start(nlsr->adl, e);
176 res = hashtb_seek(e, nbr->name, nbr->length, 0);
177
178 if (res == HT_OLD_ENTRY)
179 {
180 nnbr=e->data;
181 status=nnbr->status;
182 }
183 else if(res == HT_NEW_ENTRY)
184 {
185 hashtb_delete(e);
186 }
187
188 hashtb_end(e);
189
190 return status;
191
192}
193
194int
195get_timed_out_number(struct name_prefix *nbr)
196{
akmhoque7b791452012-10-30 11:24:56 -0500197
198 if ( nlsr->debugging )
199 printf("get_timed_out_number called \n");
200 if ( nlsr->detailed_logging )
201 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_timed_out_number called \n");
202
akmhoque03004e62012-09-06 01:12:28 -0500203
204 int res,ret=-1;
205 struct ndn_neighbor *nnbr;
206
207 struct hashtb_enumerator ee;
208 struct hashtb_enumerator *e = &ee;
209
210 hashtb_start(nlsr->adl, e);
211 res = hashtb_seek(e, nbr->name, nbr->length, 0);
212
213 if( res == HT_OLD_ENTRY )
214 {
215 nnbr=e->data;
216 ret=nnbr->info_interest_timed_out;
217 }
218 else if(res == HT_NEW_ENTRY)
219 {
220 hashtb_delete(e);
221 }
222
223 hashtb_end(e);
224
225 return ret;
226}
227
akmhoque14b3f342012-09-14 10:39:02 -0500228int
229get_lsdb_interest_timed_out_number(struct name_prefix *nbr)
230{
akmhoque7b791452012-10-30 11:24:56 -0500231
232 if ( nlsr->debugging )
233 printf("get_lsdb_interest_timed_out_number called \n");
234 if ( nlsr->detailed_logging )
235 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_lsdb_interest_timed_out_number called \n");
akmhoque14b3f342012-09-14 10:39:02 -0500236
237 int res,ret=-1;
238 struct ndn_neighbor *nnbr;
239
240 struct hashtb_enumerator ee;
241 struct hashtb_enumerator *e = &ee;
242
243 hashtb_start(nlsr->adl, e);
244 res = hashtb_seek(e, nbr->name, nbr->length, 0);
245
246 if( res == HT_OLD_ENTRY )
247 {
248 nnbr=e->data;
249 ret=nnbr->lsdb_interest_timed_out;
250 }
251 else if(res == HT_NEW_ENTRY)
252 {
253 hashtb_delete(e);
254 }
255
256 hashtb_end(e);
257
258 return ret;
259}
akmhoque03004e62012-09-06 01:12:28 -0500260
261void
262update_adjacent_timed_out_to_adl(struct name_prefix *nbr, int increment)
263{
akmhoque7b791452012-10-30 11:24:56 -0500264 if ( nlsr->debugging )
265 printf("update_adjacent_timed_out_to_adl called \n");
266 if ( nlsr->detailed_logging )
267 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_timed_out_to_adl called \n");
akmhoque03004e62012-09-06 01:12:28 -0500268
269 int res;
270 struct ndn_neighbor *nnbr;
271
272 struct hashtb_enumerator ee;
273 struct hashtb_enumerator *e = &ee;
274
275 hashtb_start(nlsr->adl, e);
276 res = hashtb_seek(e, nbr->name, nbr->length, 0);
277
278 if( res == HT_OLD_ENTRY )
279 {
280 nnbr=e->data;
281 nnbr->info_interest_timed_out += increment;
282 }
283 else if(res == HT_NEW_ENTRY)
284 {
285 hashtb_delete(e);
286 }
287
288 hashtb_end(e);
289}
290
291void
292update_adjacent_timed_out_zero_to_adl(struct name_prefix *nbr)
293{
akmhoque7b791452012-10-30 11:24:56 -0500294 if ( nlsr->debugging )
295 printf("update_adjacent_timed_out_zero_to_adl called \n");
296 if ( nlsr->detailed_logging )
297 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_timed_out_zero_to_adl called \n");
298
akmhoque03004e62012-09-06 01:12:28 -0500299 int time_out_number=get_timed_out_number(nbr);
300 update_adjacent_timed_out_to_adl(nbr,-time_out_number);
301
302}
303
akmhoque14b3f342012-09-14 10:39:02 -0500304
305void
306update_lsdb_interest_timed_out_to_adl(struct name_prefix *nbr, int increment)
307{
akmhoque7b791452012-10-30 11:24:56 -0500308 if ( nlsr->debugging )
309 printf("update_lsdb_interest_timed_out_to_adl called\n");
310 if ( nlsr->detailed_logging )
311 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_lsdb_interest_timed_out_to_adl called \n");
akmhoque14b3f342012-09-14 10:39:02 -0500312
313 int res;
314 struct ndn_neighbor *nnbr;
315
316 struct hashtb_enumerator ee;
317 struct hashtb_enumerator *e = &ee;
318
319 hashtb_start(nlsr->adl, e);
akmhoque62c0c192012-09-24 07:49:25 -0500320
akmhoque14b3f342012-09-14 10:39:02 -0500321 res = hashtb_seek(e, nbr->name, nbr->length, 0);
322
323 if( res == HT_OLD_ENTRY )
324 {
325 nnbr=e->data;
326 nnbr->lsdb_interest_timed_out += increment;
327 }
328 else if(res == HT_NEW_ENTRY)
329 {
330 hashtb_delete(e);
akmhoqueb77b95f2013-02-08 12:28:47 -0600331 }
akmhoque14b3f342012-09-14 10:39:02 -0500332 hashtb_end(e);
333}
334
335void
336update_lsdb_interest_timed_out_zero_to_adl(struct name_prefix *nbr)
337{
akmhoque7b791452012-10-30 11:24:56 -0500338 if ( nlsr->debugging )
339 printf("update_adjacent_timed_out_zero_to_adl called\n");
340 if ( nlsr->detailed_logging )
341 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_timed_out_zero_to_adl called\n");
342
akmhoque14b3f342012-09-14 10:39:02 -0500343 int time_out_number=get_lsdb_interest_timed_out_number(nbr);
344 update_lsdb_interest_timed_out_to_adl(nbr,-time_out_number);
345
346}
347
akmhoque8a5babe2012-08-16 17:39:33 -0500348void
akmhoque53f64222012-09-05 13:57:51 -0500349update_adjacent_status_to_adl(struct name_prefix *nbr, int status)
akmhoque8a5babe2012-08-16 17:39:33 -0500350{
akmhoque7b791452012-10-30 11:24:56 -0500351 if ( nlsr->debugging )
352 printf("update_adjacent_status_to_adl called\n");
353 if ( nlsr->detailed_logging )
354 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_status_to_adl called \n");
akmhoque03004e62012-09-06 01:12:28 -0500355
akmhoque8a5babe2012-08-16 17:39:33 -0500356 int res;
357 struct ndn_neighbor *nnbr;
358
359 struct hashtb_enumerator ee;
360 struct hashtb_enumerator *e = &ee;
361
362 hashtb_start(nlsr->adl, e);
akmhoque53f64222012-09-05 13:57:51 -0500363 res = hashtb_seek(e, nbr->name, nbr->length, 0);
364
akmhoque918ff9a2012-08-21 11:34:49 -0400365
akmhoquee7c4b6d2012-08-21 12:30:25 -0400366 if (res == HT_OLD_ENTRY)
367 {
368 nnbr=e->data;
akmhoque42098b12012-08-27 22:54:23 -0500369 if ( nnbr->status!=status )
370 {
371 nnbr->status=status;
372 nlsr->adj_build_flag++;
373 }
akmhoquee7c4b6d2012-08-21 12:30:25 -0400374 }
akmhoqueb903ded2012-08-21 12:56:28 -0400375 else if(res == HT_NEW_ENTRY)
376 {
377 hashtb_delete(e);
378 }
akmhoque53f64222012-09-05 13:57:51 -0500379
akmhoque8a5babe2012-08-16 17:39:33 -0500380 hashtb_end(e);
381}
382
akmhoque3171d652012-11-13 11:44:33 -0600383
384void
385delete_nbr_from_adl(struct name_prefix *nbr)
386{
387 if ( nlsr->debugging )
388 printf("delete_nbr_from_adl called\n");
389 if ( nlsr->detailed_logging )
390 writeLogg(__FILE__,__FUNCTION__,__LINE__,"delete_nbr_from_adl called \n");
391
392 int res;
393 struct hashtb_enumerator ee;
394 struct hashtb_enumerator *e = &ee;
395
396 hashtb_start(nlsr->adl, e);
397 res = hashtb_seek(e, nbr->name, nbr->length, 0);
398
399
400 if (res == HT_OLD_ENTRY)
401 {
402 hashtb_delete(e);
403 }
404 else if(res == HT_NEW_ENTRY)
405 {
406 hashtb_delete(e);
407 }
408
409 hashtb_end(e);
410}
411
akmhoque8a5babe2012-08-16 17:39:33 -0500412void
akmhoque53f64222012-09-05 13:57:51 -0500413update_lsdb_synch_interval_to_adl(struct name_prefix *nbr, long int interval)
akmhoque8a5babe2012-08-16 17:39:33 -0500414{
akmhoque7b791452012-10-30 11:24:56 -0500415 if ( nlsr->debugging )
416 printf("update_lsdb_synch_interval_to_adl called\n");
417 if ( nlsr->detailed_logging )
418 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_lsdb_synch_interval_to_adl called \n");
akmhoque8a5babe2012-08-16 17:39:33 -0500419
420 int res;
421 struct ndn_neighbor *nnbr;
422
423 struct hashtb_enumerator ee;
424 struct hashtb_enumerator *e = &ee;
425
426 hashtb_start(nlsr->adl, e);
akmhoque53f64222012-09-05 13:57:51 -0500427 res = hashtb_seek(e, nbr->name, nbr->length, 0);
akmhoque8a5babe2012-08-16 17:39:33 -0500428
akmhoque53f64222012-09-05 13:57:51 -0500429
430 if (res == HT_OLD_ENTRY)
akmhoquee7c4b6d2012-08-21 12:30:25 -0400431 {
432 nnbr=e->data;
akmhoque53f64222012-09-05 13:57:51 -0500433 if ( nnbr->lsdb_synch_interval!= interval )
434 {
435 nnbr->lsdb_synch_interval=interval;
akmhoque14b3f342012-09-14 10:39:02 -0500436 nnbr->lsdb_random_time_component=(int)(interval/2);
akmhoque03004e62012-09-06 01:12:28 -0500437
akmhoque53f64222012-09-05 13:57:51 -0500438 }
akmhoquee7c4b6d2012-08-21 12:30:25 -0400439 }
akmhoqueb903ded2012-08-21 12:56:28 -0400440 else if(res == HT_NEW_ENTRY)
441 {
442 hashtb_delete(e);
443 }
akmhoque53f64222012-09-05 13:57:51 -0500444
akmhoque8a5babe2012-08-16 17:39:33 -0500445 hashtb_end(e);
446}
akmhoqued79438d2012-08-27 13:31:42 -0500447
akmhoque53f64222012-09-05 13:57:51 -0500448
akmhoque53f64222012-09-05 13:57:51 -0500449int
akmhoque03004e62012-09-06 01:12:28 -0500450no_active_nbr(void)
akmhoque53f64222012-09-05 13:57:51 -0500451{
akmhoque03004e62012-09-06 01:12:28 -0500452 int i, adl_element;
453 int no_link=0;
454 struct ndn_neighbor *nbr;
akmhoqued79438d2012-08-27 13:31:42 -0500455 struct hashtb_enumerator ee;
456 struct hashtb_enumerator *e = &ee;
akmhoque03004e62012-09-06 01:12:28 -0500457 hashtb_start(nlsr->adl, e);
458 adl_element=hashtb_n(nlsr->adl);
akmhoqued79438d2012-08-27 13:31:42 -0500459
akmhoque03004e62012-09-06 01:12:28 -0500460 for(i=0;i<adl_element;i++)
akmhoqued79438d2012-08-27 13:31:42 -0500461 {
akmhoque03004e62012-09-06 01:12:28 -0500462 nbr=e->data;
463 if( nbr->status == 1 )
464 no_link++;
465 hashtb_next(e);
akmhoqued79438d2012-08-27 13:31:42 -0500466 }
akmhoque53f64222012-09-05 13:57:51 -0500467
akmhoqued79438d2012-08-27 13:31:42 -0500468 hashtb_end(e);
469
akmhoque03004e62012-09-06 01:12:28 -0500470 return no_link;
akmhoque53f64222012-09-05 13:57:51 -0500471
akmhoqued79438d2012-08-27 13:31:42 -0500472}
akmhoque53f64222012-09-05 13:57:51 -0500473
474int
475is_adj_lsa_build(void)
476{
477 int ret=0;
478
479 int nbr_count=0;
480
481 int i, adl_element;
482 struct ndn_neighbor *nbr;
483
484 struct hashtb_enumerator ee;
485 struct hashtb_enumerator *e = &ee;
486
487 hashtb_start(nlsr->adl, e);
488 adl_element=hashtb_n(nlsr->adl);
489
490 for(i=0;i<adl_element;i++)
491 {
492 nbr=e->data;
493 if(nbr->status == 1 )
494 {
495 nbr_count++;
496 }
akmhoque62c0c192012-09-24 07:49:25 -0500497 else if ( (nbr->status == 0) && (nbr->info_interest_timed_out >= nlsr->interest_retry || nbr->lsdb_interest_timed_out >= nlsr->interest_retry))
akmhoque53f64222012-09-05 13:57:51 -0500498 {
499 nbr_count++;
500 }
501 hashtb_next(e);
502 }
503
504 hashtb_end(e);
505 if(nbr_count == adl_element)
506 ret=1;
akmhoque03004e62012-09-06 01:12:28 -0500507
akmhoque53f64222012-09-05 13:57:51 -0500508 return ret;
509}
510
akmhoque53f64222012-09-05 13:57:51 -0500511
512void
513get_active_nbr_adj_data(struct ccn_charbuf *c)
514{
515
516 int i, adl_element;
517 struct ndn_neighbor *nbr;
518 struct hashtb_enumerator ee;
519 struct hashtb_enumerator *e = &ee;
520 hashtb_start(nlsr->adl, e);
521 adl_element=hashtb_n(nlsr->adl);
522
523 for(i=0;i<adl_element;i++)
524 {
525 nbr=e->data;
526 if( nbr->status == 1 )
527 {
528 ccn_charbuf_append_string(c,nbr->neighbor->name);
529 ccn_charbuf_append_string(c,"|");
akmhoque03004e62012-09-06 01:12:28 -0500530
akmhoque53f64222012-09-05 13:57:51 -0500531 char *temp_length=(char *)malloc(20);
532 memset(temp_length,0,20);
533 sprintf(temp_length,"%d",nbr->neighbor->length);
534 ccn_charbuf_append_string(c,temp_length);
535 free(temp_length);
536 ccn_charbuf_append_string(c,"|");
537
538 char *temp_face=(char *)malloc(20);
539 memset(temp_face,0,20);
540 sprintf(temp_face,"%d",nbr->face);
541 ccn_charbuf_append_string(c,temp_face);
542 free(temp_face);
543 ccn_charbuf_append_string(c,"|");
544
545 char *temp_metric=(char *)malloc(20);
546 memset(temp_metric,0,20);
547 sprintf(temp_metric,"%d",nbr->metric);
548 ccn_charbuf_append_string(c,temp_metric);
549 free(temp_metric);
550 ccn_charbuf_append_string(c,"|");
551
552 }
553 hashtb_next(e);
554 }
555
556 hashtb_end(e);
557}
558
akmhoque03004e62012-09-06 01:12:28 -0500559long int
560get_nbr_time_diff_lsdb_req(char *nbr)
561{
akmhoque7b791452012-10-30 11:24:56 -0500562 if ( nlsr->debugging )
563 printf("get_nbr_time_diff_lsdb_req called\n");
564 if ( nlsr->detailed_logging )
565 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_nbr_time_diff_lsdb_req called\n");
akmhoque03004e62012-09-06 01:12:28 -0500566
567 long int time_diff=get_lsdb_synch_interval(nbr)+1;
568 int res;
569 struct ndn_neighbor *nnbr;
570
571 struct hashtb_enumerator ee;
572 struct hashtb_enumerator *e = &ee;
573
574 hashtb_start(nlsr->adl, e);
575 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
576
577 if (res == HT_OLD_ENTRY)
578 {
579 nnbr=e->data;
580
581 if (nnbr->last_lsdb_requested == 0)
582 time_diff=get_lsdb_synch_interval(nbr)+1;
583 else time_diff=get_current_time_sec() - get_nbr_last_lsdb_requested(nbr);
584
585 }
586 else if(res == HT_NEW_ENTRY)
587 {
588 hashtb_delete(e);
589 }
590
591 hashtb_end(e);
592
593 return time_diff;
594}
595
596long int
597get_nbr_last_lsdb_requested(char *nbr)
598{
akmhoque7b791452012-10-30 11:24:56 -0500599 if ( nlsr->debugging )
600 printf("get_timed_out_number called\n");
601 if ( nlsr->detailed_logging )
602 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_timed_out_number called\n");
akmhoque03004e62012-09-06 01:12:28 -0500603
604 long int last_lsdb_requested=0;
605
606 int res;
607 struct ndn_neighbor *nnbr;
608
609 struct hashtb_enumerator ee;
610 struct hashtb_enumerator *e = &ee;
611
612 hashtb_start(nlsr->adl, e);
613 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
614
615 if (res == HT_OLD_ENTRY)
616 {
617 nnbr=e->data;
618 last_lsdb_requested=nnbr->last_lsdb_requested;
619 }
620 else if(res == HT_NEW_ENTRY)
621 {
622 hashtb_delete(e);
623 }
624
625 hashtb_end(e);
626
627 return last_lsdb_requested;
628}
629
akmhoque14b3f342012-09-14 10:39:02 -0500630
631int
632get_nbr_random_time_component(char *nbr)
633{
akmhoque7b791452012-10-30 11:24:56 -0500634 if ( nlsr->debugging )
635 printf("get_nbr_random_time_component called\n");
636 if ( nlsr->detailed_logging )
637 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_nbr_random_time_component called\n");
akmhoque14b3f342012-09-14 10:39:02 -0500638
639 int time=0;
640
641 int res;
642 struct ndn_neighbor *nnbr;
643
644 struct hashtb_enumerator ee;
645 struct hashtb_enumerator *e = &ee;
646
647 hashtb_start(nlsr->adl, e);
648 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
649
650 if (res == HT_OLD_ENTRY)
651 {
652 nnbr=e->data;
akmhoque9fa58a82012-10-05 07:56:02 -0500653 time=nnbr->lsdb_random_time_component * (int)pow(-1,nnbr->lsdb_interest_timed_out+1);
akmhoque14b3f342012-09-14 10:39:02 -0500654 }
655 else if(res == HT_NEW_ENTRY)
656 {
657 hashtb_delete(e);
658 }
659
660 hashtb_end(e);
661
662 return time;
663}
664
akmhoque03004e62012-09-06 01:12:28 -0500665long int
666get_lsdb_synch_interval(char *nbr)
667{
akmhoque7b791452012-10-30 11:24:56 -0500668 if ( nlsr->debugging )
669 printf("get_lsdb_synch_interval called \n");
670 if ( nlsr->detailed_logging )
671 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_lsdb_synch_interval called \n");
akmhoque03004e62012-09-06 01:12:28 -0500672
673 long int lsdb_synch_interval=300;
674
675
676 int res;
677 struct ndn_neighbor *nnbr;
678
679 struct hashtb_enumerator ee;
680 struct hashtb_enumerator *e = &ee;
681
682 hashtb_start(nlsr->adl, e);
683 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
684
685 if (res == HT_OLD_ENTRY)
686 {
687 nnbr=e->data;
688 lsdb_synch_interval=nnbr->lsdb_synch_interval;
689 }
690 else if(res == HT_NEW_ENTRY)
691 {
692 hashtb_delete(e);
693 }
694
695 hashtb_end(e);
696
697 return lsdb_synch_interval;
698
699}
700
akmhoque53f64222012-09-05 13:57:51 -0500701char *
702get_nbr_lsdb_version(char *nbr)
703{
akmhoque7b791452012-10-30 11:24:56 -0500704 if ( nlsr->debugging )
705 printf("get_nbr_lsdb_version called \n");
706 if ( nlsr->detailed_logging )
707 writeLogg(__FILE__,__FUNCTION__,__LINE__,"get_nbr_lsdb_version called \n");
akmhoque53f64222012-09-05 13:57:51 -0500708
709 char *version=NULL;
710
711 int res;
712 struct ndn_neighbor *nnbr;
713
714 struct hashtb_enumerator ee;
715 struct hashtb_enumerator *e = &ee;
716
717 hashtb_start(nlsr->adl, e);
718 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
akmhoque03004e62012-09-06 01:12:28 -0500719
akmhoque53f64222012-09-05 13:57:51 -0500720 if (res == HT_OLD_ENTRY)
721 {
722 nnbr=e->data;
723 version=(char *)malloc(strlen(nnbr->last_lsdb_version)+1);
724 memset(version,0,strlen(nnbr->last_lsdb_version)+1);
725 memcpy(version,nnbr->last_lsdb_version,strlen(nnbr->last_lsdb_version)+1);
726 }
727 else if(res == HT_NEW_ENTRY)
728 {
729 hashtb_delete(e);
730 }
731
732 hashtb_end(e);
733
734 return version;
735}
736
737void
738update_adjacent_last_lsdb_requested_to_adl(char *nbr, long int timestamp)
739{
akmhoque7b791452012-10-30 11:24:56 -0500740 if ( nlsr->debugging )
741 printf("update_adjacent_last_lsdb_requested_to_adl called \n");
742 if ( nlsr->detailed_logging )
743 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_last_lsdb_requested_to_adl called \n");
akmhoque53f64222012-09-05 13:57:51 -0500744
745 int res;
746 struct ndn_neighbor *nnbr;
747
748 struct hashtb_enumerator ee;
749 struct hashtb_enumerator *e = &ee;
750
751 hashtb_start(nlsr->adl, e);
752 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
753
754 if( res == HT_OLD_ENTRY )
755 {
756 nnbr=e->data;
757 nnbr->last_lsdb_requested=timestamp;
akmhoque03004e62012-09-06 01:12:28 -0500758
759 }
760 else if(res == HT_NEW_ENTRY)
761 {
762 hashtb_delete(e);
763 }
764
765 hashtb_end(e);
766}
767
768void
769set_is_lsdb_send_interest_scheduled_to_zero(char *nbr)
770{
akmhoque7b791452012-10-30 11:24:56 -0500771 if ( nlsr->debugging )
772 printf("set_is_lsdb_send_interest_scheduled_to_zero called \n");
773 if ( nlsr->detailed_logging )
774 writeLogg(__FILE__,__FUNCTION__,__LINE__,"set_is_lsdb_send_interest_scheduled_to_zero called\n");
775
akmhoque03004e62012-09-06 01:12:28 -0500776
777 int res;
778 struct ndn_neighbor *nnbr;
779
780 struct hashtb_enumerator ee;
781 struct hashtb_enumerator *e = &ee;
782
783 hashtb_start(nlsr->adl, e);
784 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
785
786 if (res == HT_OLD_ENTRY)
787 {
788 nnbr=e->data;
789 nnbr->is_lsdb_send_interest_scheduled=0;
790 }
791 else if(res == HT_NEW_ENTRY)
792 {
793 hashtb_delete(e);
794 }
795
796 hashtb_end(e);
797}
798
799void
800update_adjacent_lsdb_version_to_adl(struct name_prefix *nbr, char *version)
801{
akmhoque7b791452012-10-30 11:24:56 -0500802 if ( nlsr->debugging )
803 printf("update_adjacent_timed_out_to_adl called \n");
804 if ( nlsr->detailed_logging )
805 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_timed_out_to_adl called\n");
akmhoque03004e62012-09-06 01:12:28 -0500806
807 int res;
808 struct ndn_neighbor *nnbr;
809
810 struct hashtb_enumerator ee;
811 struct hashtb_enumerator *e = &ee;
812
813 hashtb_start(nlsr->adl, e);
814 res = hashtb_seek(e, nbr->name, nbr->length, 0);
815
816 if( res == HT_OLD_ENTRY )
817 {
818 nnbr=e->data;
819 free(nnbr->last_lsdb_version);
820 nnbr->last_lsdb_version=(char *)malloc(strlen(version)+1);
821 memset(nnbr->last_lsdb_version,0,strlen(version)+1);
822 memcpy(nnbr->last_lsdb_version,version,strlen(version)+1);
akmhoque53f64222012-09-05 13:57:51 -0500823 }
824 else if(res == HT_NEW_ENTRY)
825 {
826 hashtb_delete(e);
827 }
828
829 hashtb_end(e);
830
831}
832
833void
834adjust_adjacent_last_lsdb_requested_to_adl(char *nbr, long int sec)
835{
836 printf("update_adjacent_last_lsdb_requested_to_adl called \n");
837
akmhoque7b791452012-10-30 11:24:56 -0500838 if ( nlsr->debugging )
839 printf("update_adjacent_last_lsdb_requested_to_adl called \n");
840 if ( nlsr->detailed_logging )
841 writeLogg(__FILE__,__FUNCTION__,__LINE__,"update_adjacent_last_lsdb_requested_to_adl called\n");
842
843
akmhoque53f64222012-09-05 13:57:51 -0500844 int res;
845 struct ndn_neighbor *nnbr;
846
847 struct hashtb_enumerator ee;
848 struct hashtb_enumerator *e = &ee;
849
850 hashtb_start(nlsr->adl, e);
851 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
852
853 if( res == HT_OLD_ENTRY )
854 {
855 nnbr=e->data;
856 nnbr->last_lsdb_requested=nnbr->last_lsdb_requested-sec;
akmhoque03004e62012-09-06 01:12:28 -0500857
akmhoque53f64222012-09-05 13:57:51 -0500858 }
859 else if(res == HT_NEW_ENTRY)
860 {
861 hashtb_delete(e);
862 }
863
864 hashtb_end(e);
865
866}
867
akmhoquefbfd0982012-09-09 20:59:03 -0500868int
869get_next_hop_face_from_adl(char *nbr)
870{
871 int res;
872 int connecting_face=NO_FACE;
873 struct ndn_neighbor *nnbr;
874
875 struct hashtb_enumerator ee;
876 struct hashtb_enumerator *e = &ee;
877
878 hashtb_start(nlsr->adl, e);
879 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
880
881 if( res == HT_OLD_ENTRY )
882 {
883 nnbr=e->data;
884 connecting_face=nnbr->face;
885
886 }
887 else if(res == HT_NEW_ENTRY)
888 {
889 hashtb_delete(e);
890 }
891
892 hashtb_end(e);
893 return connecting_face;
894}
895
akmhoqueb77b95f2013-02-08 12:28:47 -0600896void
897update_face_to_adl_for_nbr(char *nbr, int face)
898{
899 int res;
900 struct ndn_neighbor *nnbr;
901
902 struct hashtb_enumerator ee;
903 struct hashtb_enumerator *e = &ee;
904
905 hashtb_start(nlsr->adl, e);
906 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
907
908 if( res == HT_OLD_ENTRY )
909 {
910 nnbr=e->data;
911 nnbr->face=face;
912
913 }
914 else if(res == HT_NEW_ENTRY)
915 {
916 hashtb_delete(e);
917 }
918
919 hashtb_end(e);
920}
921
akmhoquede61ba92012-09-20 22:19:12 -0500922int
923is_neighbor(char *nbr)
924{
925 int ret=0;
926
927 int res;
928 struct hashtb_enumerator ee;
929 struct hashtb_enumerator *e = &ee;
930
931 hashtb_start(nlsr->adl, e);
932 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
933
934 if( res == HT_OLD_ENTRY )
935 {
936 ret=1;
937 }
938 else if(res == HT_NEW_ENTRY)
939 {
940 hashtb_delete(e);
941 }
942
943 hashtb_end(e);
944
945 return ret;
946}
akmhoque53f64222012-09-05 13:57:51 -0500947
akmhoqueb77b95f2013-02-08 12:28:47 -0600948int
949is_active_neighbor(char *nbr)
950{
951 int ret=0;
952
953 int res;
954 struct hashtb_enumerator ee;
955 struct hashtb_enumerator *e = &ee;
956
957 hashtb_start(nlsr->adl, e);
958 res = hashtb_seek(e, nbr, strlen(nbr)+1, 0);
959
960 if( res == HT_OLD_ENTRY )
961 {
962 struct ndn_neighbor *nnbr;
963 nnbr=e->data;
964 if (nnbr->status == NBR_ACTIVE )
965 {
966 ret=1;
967 }
968 }
969 else if(res == HT_NEW_ENTRY)
970 {
971 hashtb_delete(e);
972 }
973
974 hashtb_end(e);
975
976 return ret;
977}
978