summaryrefslogtreecommitdiffstats
path: root/bgpd
diff options
context:
space:
mode:
authorIgor Ryzhov <iryzhov@nfware.com>2021-07-29 14:31:34 +0200
committerIgor Ryzhov <iryzhov@nfware.com>2021-07-29 23:59:19 +0200
commitdb0e636dc45f9bd2c76528a8368332c56f2c8f1e (patch)
tree4912acfd026b9b5ba7be08a30b9d2a00ebf3f91b /bgpd
parentbgpd: fix missing damp info free when cleaning bgp path (diff)
downloadfrr-db0e636dc45f9bd2c76528a8368332c56f2c8f1e.tar.xz
frr-db0e636dc45f9bd2c76528a8368332c56f2c8f1e.zip
bgpd: use double-linked list instead of single-linked list in dampening
This code always used double-linked list before this rework in 8.0 that introduced all these crashes and memory leaks. Using single-linked list is actually a performance regression, because there are frequent removes here and single-linked list obviously handles removes much worse. Signed-off-by: Igor Ryzhov <iryzhov@nfware.com>
Diffstat (limited to 'bgpd')
-rw-r--r--bgpd/bgp_damp.c18
-rw-r--r--bgpd/bgp_damp.h4
2 files changed, 11 insertions, 11 deletions
diff --git a/bgpd/bgp_damp.c b/bgpd/bgp_damp.c
index 513cfffda..fca5089da 100644
--- a/bgpd/bgp_damp.c
+++ b/bgpd/bgp_damp.c
@@ -41,14 +41,14 @@ static void bgp_reuselist_add(struct reuselist *list,
struct bgp_damp_info *info)
{
assert(info);
- SLIST_INSERT_HEAD(list, info, entry);
+ LIST_INSERT_HEAD(list, info, entry);
}
static void bgp_reuselist_del(struct reuselist *list,
struct bgp_damp_info *info)
{
assert(info);
- SLIST_REMOVE(list, info, bgp_damp_info, entry);
+ LIST_REMOVE(info, entry);
}
static void bgp_reuselist_switch(struct reuselist *source,
@@ -56,8 +56,8 @@ static void bgp_reuselist_switch(struct reuselist *source,
struct reuselist *target)
{
assert(source && target && info);
- SLIST_REMOVE(source, info, bgp_damp_info, entry);
- SLIST_INSERT_HEAD(target, info, entry);
+ LIST_REMOVE(info, entry);
+ LIST_INSERT_HEAD(target, info, entry);
}
static void bgp_damp_info_unclaim(struct bgp_damp_info *bdi)
@@ -188,7 +188,7 @@ static int bgp_reuse_timer(struct thread *t)
* list head entry. */
assert(bdc->reuse_offset < bdc->reuse_list_size);
plist = bdc->reuse_list[bdc->reuse_offset];
- SLIST_INIT(&bdc->reuse_list[bdc->reuse_offset]);
+ LIST_INIT(&bdc->reuse_list[bdc->reuse_offset]);
/* 2. set offset = modulo reuse-list-size ( offset + 1 ), thereby
rotating the circular queue of list-heads. */
@@ -196,7 +196,7 @@ static int bgp_reuse_timer(struct thread *t)
assert(bdc->reuse_offset < bdc->reuse_list_size);
/* 3. if ( the saved list head pointer is non-empty ) */
- while ((bdi = SLIST_FIRST(&plist)) != NULL) {
+ while ((bdi = LIST_FIRST(&plist)) != NULL) {
bgp = bdi->path->peer->bgp;
/* Set t-diff = t-now - t-updated. */
@@ -242,7 +242,7 @@ static int bgp_reuse_timer(struct thread *t)
}
}
- assert(SLIST_EMPTY(&plist));
+ assert(LIST_EMPTY(&plist));
return 0;
}
@@ -496,7 +496,7 @@ void bgp_damp_info_clean(struct bgp *bgp, struct bgp_damp_config *bdc,
bdc->reuse_offset = 0;
for (i = 0; i < bdc->reuse_list_size; ++i) {
list = &bdc->reuse_list[i];
- while ((bdi = SLIST_FIRST(list)) != NULL) {
+ while ((bdi = LIST_FIRST(list)) != NULL) {
if (bdi->lastrecord == BGP_RECORD_UPDATE) {
bgp_aggregate_increment(bgp, &bdi->dest->p,
bdi->path, bdi->afi,
@@ -508,7 +508,7 @@ void bgp_damp_info_clean(struct bgp *bgp, struct bgp_damp_config *bdc,
}
}
- while ((bdi = SLIST_FIRST(&bdc->no_reuse_list)) != NULL)
+ while ((bdi = LIST_FIRST(&bdc->no_reuse_list)) != NULL)
bgp_damp_info_free(bdi, 1);
/* Free decay array */
diff --git a/bgpd/bgp_damp.h b/bgpd/bgp_damp.h
index fc03b97c1..d238a7a34 100644
--- a/bgpd/bgp_damp.h
+++ b/bgpd/bgp_damp.h
@@ -62,10 +62,10 @@ struct bgp_damp_info {
afi_t afi;
safi_t safi;
- SLIST_ENTRY(bgp_damp_info) entry;
+ LIST_ENTRY(bgp_damp_info) entry;
};
-SLIST_HEAD(reuselist, bgp_damp_info);
+LIST_HEAD(reuselist, bgp_damp_info);
/* Specified parameter set configuration. */
struct bgp_damp_config {