summaryrefslogtreecommitdiff
path: root/filter
diff options
context:
space:
mode:
authorKazuki Yamaguchi <k@rhe.jp>2020-06-28 15:37:01 +0200
committerOndrej Zajicek (work) <santiago@crfreenet.org>2020-06-28 15:37:01 +0200
commita948cf9a5c338518773e6c98e895c829c469f56b (patch)
treeed2a551768da08e9f0e6603c7f815d4e6bf2331b /filter
parent4ef0a966392672d04a567c25758462fe3bbb0fb4 (diff)
Filter: Improve handling of sets in BGP path masks
Compare the content of PM_ASN_SET in path masks. A reconfiguration was not properly triggering a reload of affected protocols when the members of a set in a path mask change. Also, update the printing code to so that it can display sets in a path mask.
Diffstat (limited to 'filter')
-rw-r--r--filter/data.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/filter/data.c b/filter/data.c
index 9547a4c8..7c33d2cb 100644
--- a/filter/data.c
+++ b/filter/data.c
@@ -121,6 +121,11 @@ pm_format(const struct f_path_mask *p, buffer *buf)
buffer_print(buf, "%u..%u ", p->item[i].from, p->item[i].to);
break;
+ case PM_ASN_SET:
+ tree_format(p->item[i].set, buf);
+ buffer_puts(buf, " ");
+ break;
+
case PM_ASN_EXPR:
ASSERT(0);
}
@@ -221,6 +226,10 @@ pmi_same(const struct f_path_mask_item *mi1, const struct f_path_mask_item *mi2)
if (mi1->to != mi2->to)
return 0;
break;
+ case PM_ASN_SET:
+ if (!same_tree(mi1->set, mi2->set))
+ return 0;
+ break;
}
return 1;