blob: 345635bfb7f9819491b7904682332b273acf5cd6 [file] [log] [blame]
akmhoque59980a52012-08-09 12:36:09 -05001#include<stdio.h>
2#include<string.h>
3#include<stdlib.h>
4#include <unistd.h>
5#include <getopt.h>
6#include <sys/time.h>
7#include <assert.h>
8#ifdef HAVE_CONFIG_H
9#include <config.h>
10#endif
akmhoque03004e62012-09-06 01:12:28 -050011#include <sys/types.h>
12#include <signal.h>
13
akmhoque59980a52012-08-09 12:36:09 -050014
15
16#include <ccn/ccn.h>
17#include <ccn/uri.h>
18#include <ccn/keystore.h>
19#include <ccn/signing.h>
20#include <ccn/schedule.h>
21#include <ccn/hashtb.h>
22
23#include "nlsr.h"
24#include "nlsr_ndn.h"
akmhoque902d57e2012-08-17 09:24:38 -050025#include "nlsr_lsdb.h"
akmhoque53f64222012-09-05 13:57:51 -050026#include "utility.h"
akmhoque03004e62012-09-06 01:12:28 -050027#include "nlsr_npl.h"
28#include "nlsr_adl.h"
akmhoque3560cb62012-09-09 10:52:30 -050029#include "nlsr_npt.h"
30#include "nlsr_route.h"
31
32
akmhoque81c25e02012-09-10 14:50:33 -050033#define ON_ERROR_DESTROY(resval) \
34{ \
35 if ((resval) < 0) { \
36 nlsr_destroy(); \
akmhoqueffacaa82012-09-13 17:48:30 -050037 exit(1);\
akmhoque81c25e02012-09-10 14:50:33 -050038 } \
39}
40
41
42#define ON_ERROR_EXIT(resval) \
43{ \
44 if ((resval) < 0) { \
akmhoqueffacaa82012-09-13 17:48:30 -050045 exit(1); \
akmhoque81c25e02012-09-10 14:50:33 -050046 } \
47}
akmhoque59980a52012-08-09 12:36:09 -050048
49struct option longopts[] =
50{
51 { "daemon", no_argument, NULL, 'd'},
52 { "config_file", required_argument, NULL, 'f'},
53 { "help", no_argument, NULL, 'h'},
54 { 0 }
55};
56
57static int
58usage(char *progname)
59{
60
61 printf("Usage: %s [OPTIONS...]\n\
62 NDN routing....\n\
63 -d, --daemon Run in daemon mode\n\
64 -f, --config_file Specify configuration file name\n\
65 -h, --help Display this help message\n", progname);
66
67 exit(1);
68}
69
70void ndn_rtr_gettime(const struct ccn_gettime *self, struct ccn_timeval *result)
71{
72 struct timeval now = {0};
73 gettimeofday(&now, 0);
74 result->s = now.tv_sec;
75 result->micros = now.tv_usec;
76}
77
78static struct ccn_gettime ndn_rtr_ticker = {
79 "timer",
80 &ndn_rtr_gettime,
81 1000000,
82 NULL
83};
84
akmhoqueffacaa82012-09-13 17:48:30 -050085void
86nlsr_lock(void)
87{
88 nlsr->semaphor=NLSR_LOCKED;
89}
90
91void
92nlsr_unlock(void)
93{
94 nlsr->semaphor=NLSR_UNLOCKED;
95}
akmhoque42098b12012-08-27 22:54:23 -050096
97void
akmhoque03004e62012-09-06 01:12:28 -050098nlsr_stop_signal_handler(int sig)
akmhoque42098b12012-08-27 22:54:23 -050099{
akmhoque03004e62012-09-06 01:12:28 -0500100 signal(sig, SIG_IGN);
akmhoqueffacaa82012-09-13 17:48:30 -0500101 nlsr_destroy();
102 exit(0);
akmhoque59980a52012-08-09 12:36:09 -0500103}
104
105void
106process_command_ccnneighbor(char *command)
107{
108 if(command==NULL)
109 {
akmhoque28c45022012-08-09 15:38:02 -0500110 printf(" Wrong Command Format ( ccnneighbor router_name faceX)\n");
akmhoque59980a52012-08-09 12:36:09 -0500111 return;
112 }
113 char *rem;
114 const char *sep=" \t\n";
akmhoque28c45022012-08-09 15:38:02 -0500115 char *rtr_name,*face;
akmhoque59980a52012-08-09 12:36:09 -0500116
akmhoque28c45022012-08-09 15:38:02 -0500117 rtr_name=strtok_r(command,sep,&rem);
118 if(rtr_name==NULL)
akmhoque59980a52012-08-09 12:36:09 -0500119 {
akmhoque28c45022012-08-09 15:38:02 -0500120 printf(" Wrong Command Format ( ccnneighbor router_name faceX)\n");
akmhoque59980a52012-08-09 12:36:09 -0500121 return;
122 }
123
124 face=strtok_r(NULL,sep,&rem);
125 if(face==NULL)
126 {
akmhoque28c45022012-08-09 15:38:02 -0500127 printf(" Wrong Command Format ( ccnneighbor router_name faceX)\n");
akmhoque59980a52012-08-09 12:36:09 -0500128 return;
129 }
130
akmhoque28c45022012-08-09 15:38:02 -0500131 printf("Router: %s face: %s\n",rtr_name,face);
132 int face_id;
133 int res;
134 res=sscanf(face,"face%d",&face_id);
135
136 if(res != 1 )
137 {
138 printf(" Wrong Command Format ( ccnneighbor router_name faceX) where X is integer\n");
139 return;
140 }
141
akmhoqued5152122012-09-19 06:44:23 -0500142 if ( rtr_name[strlen(rtr_name)-1] == '/' )
143 {
144 rtr_name[strlen(rtr_name)-1]='\0';
145 }
akmhoque03004e62012-09-06 01:12:28 -0500146 struct name_prefix *nbr=(struct name_prefix *)malloc(sizeof(struct name_prefix ));
147 nbr->name=(char *)malloc(strlen(rtr_name)+1);
148 memset(nbr->name,0,strlen(rtr_name)+1);
149 memcpy(nbr->name,rtr_name,strlen(rtr_name)+1);
150 nbr->length=strlen(rtr_name)+1;
151
152 add_nbr_to_adl(nbr,face_id);
153
154 free(nbr->name);
155 free(nbr);
156}
157
158void
159process_command_ccnname(char *command)
160{
161
162 if(command==NULL)
163 {
164 printf(" Wrong Command Format ( ccnname /name/prefix)\n");
165 return;
166 }
167 char *rem;
168 const char *sep=" \t\n";
169 char *name;
170 name=strtok_r(command,sep,&rem);
171 if(name==NULL)
172 {
173 printf(" Wrong Command Format ( ccnname /name/prefix/ )\n");
174 return;
175 }
176
177 printf("Name Prefix: %s \n",name);
178
akmhoqued5152122012-09-19 06:44:23 -0500179 if ( name[strlen(name)-1] == '/' )
180 name[strlen(name)-1]='\0';
181
akmhoque53f64222012-09-05 13:57:51 -0500182 struct name_prefix *np=(struct name_prefix *)malloc(sizeof(struct name_prefix ));
akmhoque03004e62012-09-06 01:12:28 -0500183 np->name=(char *)malloc(strlen(name)+1);
184 memset(np->name,0,strlen(name)+1);
185 memcpy(np->name,name,strlen(name)+1);
186 np->length=strlen(name)+1;
akmhoque386081b2012-08-10 10:53:21 -0500187
akmhoque03004e62012-09-06 01:12:28 -0500188 add_name_to_npl(np);
akmhoque28c45022012-08-09 15:38:02 -0500189
akmhoque03004e62012-09-06 01:12:28 -0500190 free(np->name);
akmhoque53f64222012-09-05 13:57:51 -0500191 free(np);
akmhoque59980a52012-08-09 12:36:09 -0500192}
193
akmhoque03004e62012-09-06 01:12:28 -0500194
195void
196process_command_router_name(char *command)
197{
198 if(command==NULL)
199 {
200 printf(" Wrong Command Format ( router-name /router/name )\n");
201 return;
202 }
203 char *rem;
204 const char *sep=" \t\n";
205 char *rtr_name;
206
207 rtr_name=strtok_r(command,sep,&rem);
208 if(rtr_name==NULL)
209 {
210 printf(" Wrong Command Format ( router-name /router/name )\n");
211 return;
212 }
213
214
akmhoqued5152122012-09-19 06:44:23 -0500215 if ( rtr_name[strlen(rtr_name)-1] == '/' )
216 rtr_name[strlen(rtr_name)-1]='\0';
217
akmhoque03004e62012-09-06 01:12:28 -0500218 nlsr->router_name=(char *)malloc(strlen(rtr_name)+1);
219 memset(nlsr->router_name,0,strlen(rtr_name)+1);
220 memcpy(nlsr->router_name,rtr_name,strlen(rtr_name)+1);
221
222
223}
224
akmhoque59980a52012-08-09 12:36:09 -0500225void
akmhoqued79438d2012-08-27 13:31:42 -0500226process_command_lsdb_synch_interval(char *command)
227{
228 if(command==NULL)
229 {
230 printf(" Wrong Command Format ( lsdb-synch-interval secs )\n");
231 return;
232 }
233 char *rem;
234 const char *sep=" \t\n";
235 char *secs;
236 long int seconds;
237
238 secs=strtok_r(command,sep,&rem);
239 if(secs==NULL)
240 {
241 printf(" Wrong Command Format ( lsdb-synch-interval secs)\n");
242 return;
243 }
244
245 seconds=atoi(secs);
akmhoqueffacaa82012-09-13 17:48:30 -0500246 if ( seconds >= 120 && seconds <= 3600 )
247 {
248 nlsr->lsdb_synch_interval=seconds;
249 }
akmhoqued79438d2012-08-27 13:31:42 -0500250
251}
252
253
254void
255process_command_interest_retry(char *command)
256{
257 if(command==NULL)
258 {
259 printf(" Wrong Command Format ( interest-retry number )\n");
260 return;
261 }
262 char *rem;
263 const char *sep=" \t\n";
akmhoqueffacaa82012-09-13 17:48:30 -0500264 char *retry;
265 long int retry_number;
akmhoqued79438d2012-08-27 13:31:42 -0500266
akmhoqueffacaa82012-09-13 17:48:30 -0500267 retry=strtok_r(command,sep,&rem);
268 if(retry==NULL)
akmhoqued79438d2012-08-27 13:31:42 -0500269 {
270 printf(" Wrong Command Format ( interest-retry number)\n");
271 return;
272 }
273
akmhoqueffacaa82012-09-13 17:48:30 -0500274 retry_number=atoi(retry);
275 if ( retry_number >= 1 && retry_number<=10 )
276 {
277 nlsr->interest_retry=retry_number;
278 }
akmhoqued79438d2012-08-27 13:31:42 -0500279
280}
281
282void
283process_command_interest_resend_time(char *command)
284{
285 if(command==NULL)
286 {
287 printf(" Wrong Command Format ( interest-resend-time secs )\n");
288 return;
289 }
290 char *rem;
291 const char *sep=" \t\n";
292 char *secs;
293 long int seconds;
294
295 secs=strtok_r(command,sep,&rem);
296 if(secs==NULL)
297 {
298 printf(" Wrong Command Format ( interest-resend-time secs)\n");
299 return;
300 }
301
302 seconds=atoi(secs);
akmhoqueffacaa82012-09-13 17:48:30 -0500303 if ( seconds <= 60 && seconds >= 1 )
304 {
305 nlsr->interest_resend_time=seconds;
306 }
akmhoqued79438d2012-08-27 13:31:42 -0500307}
308
akmhoque03004e62012-09-06 01:12:28 -0500309
akmhoqued5152122012-09-19 06:44:23 -0500310void
311process_command_lsa_refresh_time(char *command)
312{
313 if(command==NULL)
314 {
315 printf(" Wrong Command Format ( lsa-refresh-time secs )\n");
316 return;
317 }
318 char *rem;
319 const char *sep=" \t\n";
320 char *secs;
321 long int seconds;
322
323 secs=strtok_r(command,sep,&rem);
324 if(secs==NULL)
325 {
326 printf(" Wrong Command Format ( lsa-refresh-time secs)\n");
327 return;
328 }
329
330 seconds=atoi(secs);
331 if ( seconds >= 240 && seconds <= 3600 )
332 {
333 nlsr->lsa_refresh_time=seconds;
334 }
335
336}
337
338void
339process_command_router_dead_interval(char *command)
340{
341 if(command==NULL)
342 {
343 printf(" Wrong Command Format ( router-dead-interval secs )\n");
344 return;
345 }
346 char *rem;
347 const char *sep=" \t\n";
348 char *secs;
349 long int seconds;
350
351 secs=strtok_r(command,sep,&rem);
352 if(secs==NULL)
353 {
354 printf(" Wrong Command Format ( router-dead-interval secs)\n");
355 return;
356 }
357
358 seconds=atoi(secs);
359 if ( seconds >= 360 && seconds <= 5400 )
360 {
361 nlsr->router_dead_interval=seconds;
362 }
363
364}
akmhoque03004e62012-09-06 01:12:28 -0500365
akmhoqued79438d2012-08-27 13:31:42 -0500366void
akmhoque3cced642012-09-24 16:20:20 -0500367process_command_multi_path_face_num(char *command)
368{
369 if(command==NULL)
370 {
371 printf(" Wrong Command Format ( multi-path-face-num n )\n");
372 return;
373 }
374 char *rem;
375 const char *sep=" \t\n";
376 char *num;
377 long int number;
378
379 num=strtok_r(command,sep,&rem);
380 if(num==NULL)
381 {
382 printf(" Wrong Command Format ( multi-path-face-num n)\n");
383 return;
384 }
385
386 number=atoi(num);
387 if ( number >= 0 && number <= 60 )
388 {
389 nlsr->multi_path_face_num=number;
390 }
391
392}
393
394void
akmhoque59980a52012-08-09 12:36:09 -0500395process_conf_command(char *command)
396{
397 const char *separators=" \t\n";
398 char *remainder=NULL;
399 char *cmd_type=NULL;
400
401 if(command==NULL || strlen(command)==0 || command[0]=='!')
402 return;
403
404 cmd_type=strtok_r(command,separators,&remainder);
405
406 if(!strcmp(cmd_type,"router-name") )
407 {
408 process_command_router_name(remainder);
409 }
410 else if(!strcmp(cmd_type,"ccnneighbor") )
411 {
412 process_command_ccnneighbor(remainder);
413 }
414 else if(!strcmp(cmd_type,"ccnname") )
415 {
416 process_command_ccnname(remainder);
417 }
akmhoqued79438d2012-08-27 13:31:42 -0500418 else if(!strcmp(cmd_type,"lsdb-synch-interval") )
419 {
420 process_command_lsdb_synch_interval(remainder);
421 }
422 else if(!strcmp(cmd_type,"interest-retry") )
423 {
424 process_command_interest_retry(remainder);
425 }
426 else if(!strcmp(cmd_type,"interest-resend-time") )
427 {
428 process_command_interest_resend_time(remainder);
429 }
akmhoqued5152122012-09-19 06:44:23 -0500430 else if(!strcmp(cmd_type,"lsa-refresh-time") )
431 {
432 process_command_lsa_refresh_time(remainder);
433 }
434 else if(!strcmp(cmd_type,"router-dead-interval") )
435 {
436 process_command_router_dead_interval(remainder);
437 }
akmhoque3cced642012-09-24 16:20:20 -0500438 else if(!strcmp(cmd_type,"multi-path-face-num") )
439 {
440 process_command_multi_path_face_num(remainder);
441 }
akmhoqued5152122012-09-19 06:44:23 -0500442 else
akmhoque59980a52012-08-09 12:36:09 -0500443 {
444 printf("Wrong configuration Command %s \n",cmd_type);
445 }
446}
447
akmhoque03004e62012-09-06 01:12:28 -0500448
akmhoque59980a52012-08-09 12:36:09 -0500449int
450readConfigFile(const char *filename)
451{
452 FILE *cfg;
453 char buf[1024];
454 int len;
455
456 cfg=fopen(filename, "r");
457
458 if(cfg == NULL)
459 {
460 printf("\nConfiguration File does not exists\n");
461 exit(1);
462 }
463
464 while(fgets((char *)buf, sizeof(buf), cfg))
465 {
466 len=strlen(buf);
467 if(buf[len-1] == '\n')
468 buf[len-1]='\0';
akmhoqued5152122012-09-19 06:44:23 -0500469 if ( buf[0] != '#' && buf[0] != '!')
470 process_conf_command(buf);
akmhoque59980a52012-08-09 12:36:09 -0500471 }
472
473 fclose(cfg);
474
475 return 0;
476}
477
akmhoque386081b2012-08-10 10:53:21 -0500478void
479nlsr_destroy( void )
480{
481
akmhoque53f64222012-09-05 13:57:51 -0500482 printf("Freeing Allocated Memory....\n");
akmhoquefbfd0982012-09-09 20:59:03 -0500483 /* Destroying all face created by nlsr in CCND */
484 destroy_all_face_by_nlsr();
485
akmhoque386081b2012-08-10 10:53:21 -0500486 /* Destroying every hash table attached to each neighbor in ADL before destorying ADL */
akmhoque53f64222012-09-05 13:57:51 -0500487 hashtb_destroy(&nlsr->npl);
akmhoque03004e62012-09-06 01:12:28 -0500488 hashtb_destroy(&nlsr->adl);
489 hashtb_destroy(&nlsr->lsdb->name_lsdb);
490 hashtb_destroy(&nlsr->lsdb->adj_lsdb);
akmhoque29c1db52012-09-07 14:47:43 -0500491 hashtb_destroy(&nlsr->pit_alsa);
akmhoque3cced642012-09-24 16:20:20 -0500492
493 //To Do: has to destroy the face_list one by one
494
akmhoque3560cb62012-09-09 10:52:30 -0500495 hashtb_destroy(&nlsr->routing_table);
496
497
498 int i, npt_element;
499 struct npt_entry *ne;
500 struct hashtb_enumerator ee;
501 struct hashtb_enumerator *e = &ee;
502 hashtb_start(nlsr->npt, e);
503 npt_element=hashtb_n(nlsr->npt);
504 for(i=0;i<npt_element;i++)
505 {
506 ne=e->data;
akmhoque3cced642012-09-24 16:20:20 -0500507 hashtb_destroy(&ne->name_list);
508 hashtb_destroy(&ne->face_list);
akmhoque3560cb62012-09-09 10:52:30 -0500509 hashtb_next(e);
510 }
511
512 hashtb_end(e);
513 hashtb_destroy(&nlsr->npt);
514
akmhoque03004e62012-09-06 01:12:28 -0500515
akmhoque386081b2012-08-10 10:53:21 -0500516 ccn_schedule_destroy(&nlsr->sched);
517 ccn_destroy(&nlsr->ccn);
akmhoque03004e62012-09-06 01:12:28 -0500518
519 free(nlsr->lsdb->lsdb_version);
520 free(nlsr->lsdb);
521 free(nlsr->router_name);
akmhoque386081b2012-08-10 10:53:21 -0500522 free(nlsr);
523
akmhoque53f64222012-09-05 13:57:51 -0500524 printf("Finished freeing allocated memory\n");
525
akmhoque386081b2012-08-10 10:53:21 -0500526}
527
akmhoque03004e62012-09-06 01:12:28 -0500528
akmhoque81c25e02012-09-10 14:50:33 -0500529int
akmhoque902d57e2012-08-17 09:24:38 -0500530init_nlsr(void)
akmhoque59980a52012-08-09 12:36:09 -0500531{
akmhoque03004e62012-09-06 01:12:28 -0500532 if (signal(SIGQUIT, nlsr_stop_signal_handler ) == SIG_ERR)
533 {
534 perror("SIGQUIT install error\n");
akmhoque81c25e02012-09-10 14:50:33 -0500535 return -1;
akmhoque03004e62012-09-06 01:12:28 -0500536 }
537 if (signal(SIGTERM, nlsr_stop_signal_handler ) == SIG_ERR)
538 {
539 perror("SIGTERM install error\n");
akmhoque81c25e02012-09-10 14:50:33 -0500540 return -1;
akmhoque03004e62012-09-06 01:12:28 -0500541 }
542 if (signal(SIGINT, nlsr_stop_signal_handler ) == SIG_ERR)
543 {
544 perror("SIGTERM install error\n");
akmhoque81c25e02012-09-10 14:50:33 -0500545 return -1;
akmhoque03004e62012-09-06 01:12:28 -0500546 }
akmhoque902d57e2012-08-17 09:24:38 -0500547
akmhoque59980a52012-08-09 12:36:09 -0500548 nlsr=(struct nlsr *)malloc(sizeof(struct nlsr));
akmhoque03004e62012-09-06 01:12:28 -0500549
550 struct hashtb_param param_adl = {0};
akmhoque28c45022012-08-09 15:38:02 -0500551 nlsr->adl=hashtb_create(sizeof(struct ndn_neighbor), &param_adl);
akmhoque03004e62012-09-06 01:12:28 -0500552 struct hashtb_param param_npl = {0};
553 nlsr->npl = hashtb_create(sizeof(struct name_prefix), &param_npl);
akmhoque29c1db52012-09-07 14:47:43 -0500554 struct hashtb_param param_pit_alsa = {0};
akmhoque1ce71052012-09-13 22:51:32 -0500555 nlsr->pit_alsa = hashtb_create(sizeof(struct pending_interest), &param_pit_alsa);
akmhoque3560cb62012-09-09 10:52:30 -0500556 struct hashtb_param param_npt = {0};
557 nlsr->npt = hashtb_create(sizeof(struct npt_entry), &param_npt);
558 struct hashtb_param param_rte = {0};
559 nlsr->routing_table = hashtb_create(sizeof(struct routing_table_entry), &param_rte);
akmhoque29c1db52012-09-07 14:47:43 -0500560
akmhoque59980a52012-08-09 12:36:09 -0500561 nlsr->in_interest.p = &incoming_interest;
562 nlsr->in_content.p = &incoming_content;
akmhoque07dd8cc2012-08-16 10:23:01 -0500563
akmhoque03004e62012-09-06 01:12:28 -0500564 nlsr->lsdb=(struct linkStateDatabase *)malloc(sizeof(struct linkStateDatabase));
akmhoque07dd8cc2012-08-16 10:23:01 -0500565
akmhoque03004e62012-09-06 01:12:28 -0500566 char *time_stamp=(char *)malloc(20);
567 memset(time_stamp,0,20);
568 get_current_timestamp_micro(time_stamp);
569 nlsr->lsdb->lsdb_version=(char *)malloc(strlen(time_stamp)+1);
570 memset(nlsr->lsdb->lsdb_version,'0',strlen(time_stamp));
571 free(time_stamp);
572
573 struct hashtb_param param_adj_lsdb = {0};
akmhoquef71d9082012-08-22 12:51:53 -0400574 nlsr->lsdb->adj_lsdb = hashtb_create(sizeof(struct alsa), &param_adj_lsdb);
akmhoque03004e62012-09-06 01:12:28 -0500575 struct hashtb_param param_name_lsdb = {0};
akmhoquef71d9082012-08-22 12:51:53 -0400576 nlsr->lsdb->name_lsdb = hashtb_create(sizeof(struct nlsa), &param_name_lsdb);
akmhoque29c1db52012-09-07 14:47:43 -0500577
578
akmhoque902d57e2012-08-17 09:24:38 -0500579
akmhoque53f64222012-09-05 13:57:51 -0500580
akmhoque59980a52012-08-09 12:36:09 -0500581 nlsr->is_synch_init=1;
akmhoquec9286692012-08-16 09:57:58 -0500582 nlsr->nlsa_id=0;
akmhoqued79438d2012-08-27 13:31:42 -0500583 nlsr->adj_build_flag=0;
akmhoque53f64222012-09-05 13:57:51 -0500584 nlsr->adj_build_count=0;
585 nlsr->is_build_adj_lsa_sheduled=0;
akmhoque29c1db52012-09-07 14:47:43 -0500586 nlsr->is_send_lsdb_interest_scheduled=0;
587 nlsr->is_route_calculation_scheduled=0;
akmhoqued79438d2012-08-27 13:31:42 -0500588
589 nlsr->lsdb_synch_interval = LSDB_SYNCH_INTERVAL;
590 nlsr->interest_retry = INTEREST_RETRY;
591 nlsr->interest_resend_time = INTEREST_RESEND_TIME;
akmhoqueda5b6832012-09-13 22:33:55 -0500592 nlsr->lsa_refresh_time=LSA_REFRESH_TIME;
593 nlsr->router_dead_interval=ROUTER_DEAD_INTERVAL;
akmhoque3cced642012-09-24 16:20:20 -0500594 nlsr->multi_path_face_num=MULTI_PATH_FACE_NUM;
akmhoqueda5b6832012-09-13 22:33:55 -0500595
akmhoque42098b12012-08-27 22:54:23 -0500596
akmhoqueffacaa82012-09-13 17:48:30 -0500597 nlsr->semaphor=NLSR_UNLOCKED;
akmhoque81c25e02012-09-10 14:50:33 -0500598
599 return 0;
akmhoque902d57e2012-08-17 09:24:38 -0500600}
601
akmhoque03004e62012-09-06 01:12:28 -0500602
akmhoque902d57e2012-08-17 09:24:38 -0500603int
604main(int argc, char *argv[])
605{
akmhoque81c25e02012-09-10 14:50:33 -0500606 int res, ret;
akmhoque902d57e2012-08-17 09:24:38 -0500607 char *config_file;
akmhoqueffacaa82012-09-13 17:48:30 -0500608 //int daemon_mode;
akmhoque902d57e2012-08-17 09:24:38 -0500609
akmhoque81c25e02012-09-10 14:50:33 -0500610 ret=init_nlsr();
611 ON_ERROR_EXIT(ret);
612
akmhoque59980a52012-08-09 12:36:09 -0500613 while ((res = getopt_long(argc, argv, "df:h", longopts, 0)) != -1)
614 {
615 switch (res)
616 {
617 case 'd':
akmhoqueffacaa82012-09-13 17:48:30 -0500618 //daemon_mode = 1;
akmhoque59980a52012-08-09 12:36:09 -0500619 break;
620 case 'f':
621 config_file = optarg;
622 break;
623 case 'h':
624 default:
625 usage(argv[0]);
626 }
627 }
628
629 readConfigFile(config_file);
630
631 nlsr->ccn=ccn_create();
632 if(ccn_connect(nlsr->ccn, NULL) == -1)
akmhoque03004e62012-09-06 01:12:28 -0500633 {
634 fprintf(stderr,"Could not connect to ccnd\n");
akmhoque81c25e02012-09-10 14:50:33 -0500635 ON_ERROR_DESTROY(-1);
akmhoque03004e62012-09-06 01:12:28 -0500636 }
akmhoque53f64222012-09-05 13:57:51 -0500637 struct ccn_charbuf *router_prefix;
akmhoque03004e62012-09-06 01:12:28 -0500638 router_prefix=ccn_charbuf_create();
639 res=ccn_name_from_uri(router_prefix,nlsr->router_name);
akmhoque59980a52012-08-09 12:36:09 -0500640 if(res<0)
akmhoque03004e62012-09-06 01:12:28 -0500641 {
642 fprintf(stderr, "Bad ccn URI: %s\n",nlsr->router_name);
akmhoque81c25e02012-09-10 14:50:33 -0500643 ON_ERROR_DESTROY(res);
akmhoque03004e62012-09-06 01:12:28 -0500644 }
akmhoque59980a52012-08-09 12:36:09 -0500645
646 ccn_name_append_str(router_prefix,"nlsr");
akmhoque03004e62012-09-06 01:12:28 -0500647 nlsr->in_interest.data=nlsr->router_name;
akmhoque59980a52012-08-09 12:36:09 -0500648 res=ccn_set_interest_filter(nlsr->ccn,router_prefix,&nlsr->in_interest);
649 if ( res < 0 )
akmhoque03004e62012-09-06 01:12:28 -0500650 {
651 fprintf(stderr,"Failed to register interest for router\n");
akmhoque81c25e02012-09-10 14:50:33 -0500652 ON_ERROR_DESTROY(res);
akmhoque03004e62012-09-06 01:12:28 -0500653 }
654 ccn_charbuf_destroy(&router_prefix);
655
656 printf("Router Name : %s\n",nlsr->router_name);
657 printf("lsdb_version: %s\n",nlsr->lsdb->lsdb_version);
akmhoque59980a52012-08-09 12:36:09 -0500658
akmhoque53f64222012-09-05 13:57:51 -0500659 print_name_prefix_from_npl();
660 print_adjacent_from_adl();
akmhoque53f64222012-09-05 13:57:51 -0500661 build_and_install_name_lsas();
662 print_name_lsdb();
663
664 nlsr->sched = ccn_schedule_create(nlsr, &ndn_rtr_ticker);
akmhoque03004e62012-09-06 01:12:28 -0500665 nlsr->event_send_info_interest = ccn_schedule_event(nlsr->sched, 1, &send_info_interest, NULL, 0);
akmhoqueffacaa82012-09-13 17:48:30 -0500666 nlsr->event = ccn_schedule_event(nlsr->sched, 60000000, &refresh_lsdb, NULL, 0);
akmhoque1c9b92f2012-08-13 10:57:50 -0500667
akmhoque59980a52012-08-09 12:36:09 -0500668 while(1)
akmhoque29c1db52012-09-07 14:47:43 -0500669 {
akmhoqueffacaa82012-09-13 17:48:30 -0500670 if ( nlsr->semaphor == NLSR_UNLOCKED )
akmhoque29c1db52012-09-07 14:47:43 -0500671 {
akmhoqueffacaa82012-09-13 17:48:30 -0500672 if( nlsr->sched != NULL )
673 {
674 ccn_schedule_run(nlsr->sched);
675 }
676 if(nlsr->ccn != NULL)
677 {
678 res = ccn_run(nlsr->ccn, 500);
679 }
680 if (!(nlsr->sched && nlsr->ccn))
681 {
682 break;
683 }
akmhoque29c1db52012-09-07 14:47:43 -0500684 }
685
akmhoque59980a52012-08-09 12:36:09 -0500686 }
akmhoque59980a52012-08-09 12:36:09 -0500687
akmhoque59980a52012-08-09 12:36:09 -0500688 return 0;
689}
690