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;