0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-05 08:31:53 +00:00

Merge branch 'mq-aggregator-for-v3' into HEAD

This commit is contained in:
Maria Matejka 2023-11-01 10:58:44 +01:00
commit 11faa7d36b
3 changed files with 28 additions and 3 deletions

View File

@ -1678,7 +1678,7 @@ rte_same(const rte *x, const rte *y)
{ {
/* rte.flags / rte.pflags are not checked, as they are internal to rtable */ /* rte.flags / rte.pflags are not checked, as they are internal to rtable */
return return
( (x == y) || (
(x->attrs == y->attrs) || (x->attrs == y->attrs) ||
((!(x->attrs->flags & EALF_CACHED) || !(y->attrs->flags & EALF_CACHED)) && ea_same(x->attrs, y->attrs)) ((!(x->attrs->flags & EALF_CACHED) || !(y->attrs->flags & EALF_CACHED)) && ea_same(x->attrs, y->attrs))
) && ) &&

View File

@ -54,8 +54,17 @@ aggregator_proto_item:
if (!AGGREGATOR_CFG->aggr_on_net) if (!AGGREGATOR_CFG->aggr_on_net)
cf_error("aggregate on must be always include 'net'."); cf_error("aggregate on must be always include 'net'.");
struct f_inst *rot = NULL;
while ($4.begin)
{
struct f_inst *tmp = $4.begin->next;
$4.begin->next = rot;
rot = $4.begin;
$4.begin = tmp;
}
AGGREGATOR_CFG->aggr_on_count = count; AGGREGATOR_CFG->aggr_on_count = count;
AGGREGATOR_CFG->aggr_on = f_linearize($4.begin, count); AGGREGATOR_CFG->aggr_on = f_linearize(rot, count);
struct f_line *premerge = f_linearize($4.end, 0); struct f_line *premerge = f_linearize($4.end, 0);
premerge->args = count; premerge->args = count;

View File

@ -1,9 +1,17 @@
log "bird.log" all; log "bird.log" all;
attribute int foo;
protocol device {} protocol device {}
protocol static { protocol static {
ipv6; ipv6 {
import filter {
preference = 111;
foo = 666;
accept;
};
};
route 2001:db8:0::/48 unreachable { bgp_path.prepend(65432); bgp_path.prepend(4200000000); }; route 2001:db8:0::/48 unreachable { bgp_path.prepend(65432); bgp_path.prepend(4200000000); };
route 2001:db8:1::/48 unreachable; route 2001:db8:1::/48 unreachable;
route 2001:db8:2::/48 unreachable; route 2001:db8:2::/48 unreachable;
@ -25,6 +33,8 @@ protocol static {
protocol static { protocol static {
ipv6 { ipv6 {
import filter { import filter {
preference = 222;
foo = 666;
bgp_med = 1; bgp_med = 1;
bgp_community = -empty-.add((65533,1)).add((65500,0xe)); bgp_community = -empty-.add((65533,1)).add((65500,0xe));
accept; accept;
@ -43,6 +53,8 @@ protocol static {
protocol static { protocol static {
ipv6 { ipv6 {
import filter { import filter {
preference = 222;
foo = 666;
bgp_med = 2; bgp_med = 2;
bgp_community = -empty-.add((65533,2)).add((65500,0xd)); bgp_community = -empty-.add((65533,2)).add((65500,0xd));
accept; accept;
@ -61,6 +73,8 @@ protocol static {
protocol static { protocol static {
ipv6 { ipv6 {
import filter { import filter {
preference = 222;
foo = 666;
bgp_med = 4; bgp_med = 4;
bgp_community = -empty-.add((65533,4)).add((65500,0xb)); bgp_community = -empty-.add((65533,4)).add((65500,0xb));
accept; accept;
@ -79,6 +93,8 @@ protocol static {
protocol static { protocol static {
ipv6 { ipv6 {
import filter { import filter {
preference = 222;
foo = 666;
bgp_med = 8; bgp_med = 8;
bgp_community = -empty-.add((65533,8)).add((65500,0x7)); bgp_community = -empty-.add((65533,8)).add((65500,0x7));
accept; accept;