diff options
| author | Donald Sharp <sharpd@cumulusnetworks.com> | 2018-02-17 19:02:55 -0500 | 
|---|---|---|
| committer | Donald Sharp <sharpd@cumulusnetworks.com> | 2018-02-23 07:08:36 -0500 | 
| commit | 55cd0f612a046137f0be936e7856921ada4546ca (patch) | |
| tree | 33ebc2df612fe462d3f422834fe6c99c409320f1 /ldpd/neighbor.c | |
| parent | a031a7e4c9232fc9433e51af6b67f22d9b0cd663 (diff) | |
*: Make assignment from RB_ROOT in while loop work better
Fix up the assignment of the variable = RB_ROOT inside of
while loop patter we were using.
Signed-off-by: Donald Sharp <sharpd@cumulusnetworks.com>
Diffstat (limited to 'ldpd/neighbor.c')
| -rw-r--r-- | ldpd/neighbor.c | 4 | 
1 files changed, 3 insertions, 1 deletions
diff --git a/ldpd/neighbor.c b/ldpd/neighbor.c index 39860a1859..1c3f650dff 100644 --- a/ldpd/neighbor.c +++ b/ldpd/neighbor.c @@ -316,7 +316,9 @@ nbr_del(struct nbr *nbr)  	mapping_list_clr(&nbr->release_list);  	mapping_list_clr(&nbr->abortreq_list); -	while ((adj = RB_ROOT(nbr_adj_head, &nbr->adj_tree)) != NULL) { +	while (!RB_EMPTY(nbr_adj_head, &nbr->adj_tree)) { +		adj = RB_ROOT(nbr_adj_head, &nbr->adj_tree); +  		adj->nbr = NULL;  		RB_REMOVE(nbr_adj_head, &nbr->adj_tree, adj);  	}  | 
