fixed segfault at exits
diff --git a/nlsr.c b/nlsr.c
index 266a901..f963b74 100644
--- a/nlsr.c
+++ b/nlsr.c
@@ -69,7 +69,7 @@
{
signal(sig, SIG_IGN);
nlsr_destroy();
- exit(0);
+// exit(0);
}
void
@@ -336,13 +336,14 @@
{
printf("Freeing Allocated Memory....\n");
+
+
/* Destroying every hash table attached to each neighbor in ADL before destorying ADL */
hashtb_destroy(&nlsr->npl);
hashtb_destroy(&nlsr->adl);
hashtb_destroy(&nlsr->lsdb->name_lsdb);
hashtb_destroy(&nlsr->lsdb->adj_lsdb);
-
ccn_schedule_destroy(&nlsr->sched);
ccn_destroy(&nlsr->ccn);
@@ -375,6 +376,7 @@
exit(1);
}
+
nlsr=(struct nlsr *)malloc(sizeof(struct nlsr));
struct hashtb_param param_adl = {0};
@@ -479,10 +481,14 @@
nlsr->event_send_info_interest = ccn_schedule_event(nlsr->sched, 1, &send_info_interest, NULL, 0);
while(1)
- {
- ccn_schedule_run(nlsr->sched);
- res = ccn_run(nlsr->ccn, 500);
+ {
+ if (nlsr->sched)
+ ccn_schedule_run(nlsr->sched);
+ if (nlsr->ccn)
+ res = ccn_run(nlsr->ccn, 500);
+ if (!(nlsr->sched && nlsr->ccn))
+ break;
}
diff --git a/nlsr_ndn.c b/nlsr_ndn.c
index f4a80cf..f05a90d 100644
--- a/nlsr_ndn.c
+++ b/nlsr_ndn.c
@@ -960,6 +960,9 @@
{
printf("send_lsdb_interest called \n");
+ if(flags == CCN_SCHEDULE_CANCEL)
+ return -1;
+
int i, adl_element;
struct ndn_neighbor *nbr;