Free Some Unfreed Memory
diff --git a/nlsr_lsdb.c b/nlsr_lsdb.c
index 36f2dbd..c1d484f 100644
--- a/nlsr_lsdb.c
+++ b/nlsr_lsdb.c
@@ -929,7 +929,7 @@
char *key=(char *)calloc(adj_lsa->header->orig_router->length+4,sizeof(char));
make_adj_lsa_key(key,adj_lsa);
- struct alsa *new_adj_lsa;//=(struct alsa*)malloc(sizeof(struct alsa ));
+ struct alsa *new_adj_lsa;
struct hashtb_enumerator ee;
struct hashtb_enumerator *e = ⅇ
@@ -961,11 +961,8 @@
new_adj_lsa->header->orig_router->length=adj_lsa->header->orig_router->length;
new_adj_lsa->no_link=adj_lsa->no_link;
-
- //if(new_adj_lsa->body )
- //free(new_adj_lsa->body);
+
new_adj_lsa->body=(char *)calloc(strlen(adj_lsa->body)+1,sizeof(char));
- //memset(new_adj_lsa->body,0,strlen(adj_lsa->body)+1);
memcpy(new_adj_lsa->body,adj_lsa->body,strlen(adj_lsa->body)+1);
add_next_hop_router(new_adj_lsa->header->orig_router->name);
@@ -1019,11 +1016,8 @@
memcpy(new_adj_lsa->header->orig_time,adj_lsa->header->orig_time,strlen(adj_lsa->header->orig_time)+1);
new_adj_lsa->no_link=adj_lsa->no_link;
-
new_adj_lsa->body=(char *)calloc(strlen(adj_lsa->body)+1,sizeof(char));
- //memset(new_adj_lsa->body,0,strlen(adj_lsa->body)+1);
memcpy(new_adj_lsa->body,adj_lsa->body,strlen(adj_lsa->body)+1);
-
add_next_hop_from_lsa_adj_body(new_adj_lsa->body,new_adj_lsa->no_link);
writeLogg(__FILE__,__FUNCTION__,__LINE__," Adj-LSA\n");
diff --git a/nlsr_npt.c b/nlsr_npt.c
index 3f9f240..a986523 100644
--- a/nlsr_npt.c
+++ b/nlsr_npt.c
@@ -564,6 +564,7 @@
}
//hashtb_destroy(&ne->name_list);
//hashtb_destroy(&ne->face_list);
+ free(ne->orig_router);
destroy_name_list(ne->name_list);
destroy_face_list(ne->face_list);
hashtb_delete(e);