diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2004-02-18 16:14:14 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2004-02-18 16:14:14 +0000 |
commit | 0b09d5575123b6dbf1f0c36d564b09af9c6b43cf (patch) | |
tree | 9e1a0699d496cef6e01889bfa2073eee1d85b970 /usr.sbin/bgpd/rde_update.c | |
parent | bb69250687d3c74ddefd7e5e0c9329d06846949b (diff) |
Fix a nasty memory leak. OK henning@
Diffstat (limited to 'usr.sbin/bgpd/rde_update.c')
-rw-r--r-- | usr.sbin/bgpd/rde_update.c | 32 |
1 files changed, 15 insertions, 17 deletions
diff --git a/usr.sbin/bgpd/rde_update.c b/usr.sbin/bgpd/rde_update.c index dda9669ed8d..cbac934cbee 100644 --- a/usr.sbin/bgpd/rde_update.c +++ b/usr.sbin/bgpd/rde_update.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rde_update.c,v 1.3 2004/02/17 15:44:02 claudio Exp $ */ +/* $OpenBSD: rde_update.c,v 1.4 2004/02/18 16:14:13 claudio Exp $ */ /* * Copyright (c) 2004 Claudio Jeker <claudio@openbsd.org> @@ -74,23 +74,21 @@ up_init(struct rde_peer *peer) void up_down(struct rde_peer *peer) { - struct update_attr *ua, *xua; - struct update_prefix *up, *xup; - - for (ua = TAILQ_FIRST(&peer->updates); ua != TAILQ_END(&peer->updates); - ua = xua) { - xua = TAILQ_NEXT(ua, attr_l); - for (up = TAILQ_FIRST(&ua->prefix_h); - up != TAILQ_END(&ua->prefix_h); up = xup) { - xup = TAILQ_NEXT(up, prefix_l); + struct update_attr *ua; + struct update_prefix *up; + + while ((ua = TAILQ_FIRST(&peer->updates)) != NULL) { + TAILQ_REMOVE(&peer->updates, ua, attr_l); + while ((up = TAILQ_FIRST(&ua->prefix_h)) != NULL) { + TAILQ_REMOVE(&ua->prefix_h, up, prefix_l); free(up); } + free(ua->attr); free(ua); } - for (up = TAILQ_FIRST(&peer->withdraws); - up != TAILQ_END(&peer->withdraws); up = xup) { - xup = TAILQ_NEXT(up, prefix_l); + while ((up = TAILQ_FIRST(&peer->withdraws)) != NULL) { + TAILQ_REMOVE(&peer->withdraws, up, prefix_l); free(up); } @@ -157,6 +155,7 @@ up_add(struct rde_peer *peer, struct update_prefix *p, struct update_attr *a) } else { /* 1.2 if found -> use that, free a */ if (a != NULL) { + free(a->attr); free(a); a = na; /* move to end of update queue */ @@ -451,12 +450,10 @@ int up_dump_prefix(u_char *buf, int len, struct uplist_prefix *prefix_head, struct rde_peer *peer) { - struct update_prefix *upp, *xupp; + struct update_prefix *upp; int r, wpos = 0; - for (upp = TAILQ_FIRST(prefix_head); - upp != TAILQ_END(prefix_head); upp = xupp) { - xupp = TAILQ_NEXT(upp, prefix_l); + while ((upp = TAILQ_FIRST(prefix_head)) != NULL) { if ((r = up_set_prefix(buf + wpos, len - wpos, &upp->prefix, upp->prefixlen)) == -1) break; @@ -510,6 +507,7 @@ up_dump_attrnlri(u_char *buf, int len, struct rde_peer *peer) if (RB_REMOVE(uptree_attr, &peer->up_attrs, upa) == NULL) log_warnx("dequeuing update failed."); TAILQ_REMOVE(&peer->updates, upa, attr_l); + free(upa->attr); free(upa); peer->up_acnt--; } |