mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-20 16:01:53 +00:00
Merge branch 'int-new' into bash-completion
This commit is contained in:
commit
adf80eccc5
@ -244,6 +244,7 @@ lp_restore(linpool *m, lp_state *p)
|
|||||||
while ((c = m->first_large) && (c != p->large))
|
while ((c = m->first_large) && (c != p->large))
|
||||||
{
|
{
|
||||||
m->first_large = c->next;
|
m->first_large = c->next;
|
||||||
|
m->total_large -= c->size;
|
||||||
xfree(c);
|
xfree(c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -536,6 +536,13 @@ ec_set_sort(struct linpool *pool, struct adata *src)
|
|||||||
return dst;
|
return dst;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ec_set_sort_x(struct adata *set)
|
||||||
|
{
|
||||||
|
/* Sort in place */
|
||||||
|
qsort(set->data, set->length / 8, 8, ec_set_cmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
lc_set_cmp(const void *X, const void *Y)
|
lc_set_cmp(const void *X, const void *Y)
|
||||||
|
@ -197,4 +197,6 @@ struct adata *int_set_sort(struct linpool *pool, struct adata *src);
|
|||||||
struct adata *ec_set_sort(struct linpool *pool, struct adata *src);
|
struct adata *ec_set_sort(struct linpool *pool, struct adata *src);
|
||||||
struct adata *lc_set_sort(struct linpool *pool, struct adata *src);
|
struct adata *lc_set_sort(struct linpool *pool, struct adata *src);
|
||||||
|
|
||||||
|
void ec_set_sort_x(struct adata *set); /* Sort in place */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -550,10 +550,12 @@ bgp_decode_mp_unreach_nlri(struct bgp_parse_state *s, uint code UNUSED, uint fla
|
|||||||
static void
|
static void
|
||||||
bgp_export_ext_community(struct bgp_export_state *s, eattr *a)
|
bgp_export_ext_community(struct bgp_export_state *s, eattr *a)
|
||||||
{
|
{
|
||||||
|
a->u.ptr = ec_set_del_nontrans(s->pool, a->u.ptr);
|
||||||
|
|
||||||
if (a->u.ptr->length == 0)
|
if (a->u.ptr->length == 0)
|
||||||
UNSET(a);
|
UNSET(a);
|
||||||
|
|
||||||
a->u.ptr = ec_set_sort(s->pool, a->u.ptr);
|
ec_set_sort_x(a->u.ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -645,13 +645,8 @@ nl_add_multipath(struct nlmsghdr *h, uint bufsize, struct nexthop *nh, int af)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct nexthop *
|
static struct nexthop *
|
||||||
nl_parse_multipath(struct krt_proto *p, struct rtattr *ra, int af)
|
nl_parse_multipath(struct nl_parse_state *s, struct krt_proto *p, struct rtattr *ra, int af)
|
||||||
{
|
{
|
||||||
/* Temporary buffer for multicast nexthops */
|
|
||||||
static struct nexthop *nh_buffer;
|
|
||||||
static int nh_buf_size; /* in number of structures */
|
|
||||||
static int nh_buf_used;
|
|
||||||
|
|
||||||
struct rtattr *a[BIRD_RTA_MAX];
|
struct rtattr *a[BIRD_RTA_MAX];
|
||||||
struct rtnexthop *nh = RTA_DATA(ra);
|
struct rtnexthop *nh = RTA_DATA(ra);
|
||||||
struct nexthop *rv, *first, **last;
|
struct nexthop *rv, *first, **last;
|
||||||
@ -659,7 +654,6 @@ nl_parse_multipath(struct krt_proto *p, struct rtattr *ra, int af)
|
|||||||
|
|
||||||
first = NULL;
|
first = NULL;
|
||||||
last = &first;
|
last = &first;
|
||||||
nh_buf_used = 0;
|
|
||||||
|
|
||||||
while (len)
|
while (len)
|
||||||
{
|
{
|
||||||
@ -667,18 +661,9 @@ nl_parse_multipath(struct krt_proto *p, struct rtattr *ra, int af)
|
|||||||
if ((len < sizeof(*nh)) || (len < nh->rtnh_len))
|
if ((len < sizeof(*nh)) || (len < nh->rtnh_len))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (nh_buf_used == nh_buf_size)
|
*last = rv = lp_allocz(s->pool, NEXTHOP_MAX_SIZE);
|
||||||
{
|
|
||||||
nh_buf_size = nh_buf_size ? (nh_buf_size * 2) : 4;
|
|
||||||
nh_buffer = xrealloc(nh_buffer, nh_buf_size * NEXTHOP_MAX_SIZE);
|
|
||||||
}
|
|
||||||
/* FIXME: This is really ugly */
|
|
||||||
*last = rv = (void *) (((byte *) nh_buffer) + (nh_buf_used++ * NEXTHOP_MAX_SIZE));
|
|
||||||
memset(rv, 0, NEXTHOP_MAX_SIZE);
|
|
||||||
// rv->next = NULL;
|
|
||||||
last = &(rv->next);
|
last = &(rv->next);
|
||||||
|
|
||||||
rv->flags = 0;
|
|
||||||
rv->weight = nh->rtnh_hops;
|
rv->weight = nh->rtnh_hops;
|
||||||
rv->iface = if_find_by_index(nh->rtnh_ifindex);
|
rv->iface = if_find_by_index(nh->rtnh_ifindex);
|
||||||
if (!rv->iface)
|
if (!rv->iface)
|
||||||
@ -1395,20 +1380,6 @@ krt_replace_rte(struct krt_proto *p, net *n, rte *new, rte *old, struct ea_list
|
|||||||
n->n.flags &= ~KRF_SYNC_ERROR;
|
n->n.flags &= ~KRF_SYNC_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static inline struct nexthop *
|
|
||||||
nl_alloc_nexthop(struct nl_parse_state *s, ip_addr gw, struct iface *iface, byte weight)
|
|
||||||
{
|
|
||||||
struct nexthop *nh = lp_alloc(s->pool, sizeof(struct nexthop));
|
|
||||||
|
|
||||||
nh->gw = gw;
|
|
||||||
nh->iface = iface;
|
|
||||||
nh->next = NULL;
|
|
||||||
nh->weight = weight;
|
|
||||||
|
|
||||||
return nh;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
nl_mergable_route(struct nl_parse_state *s, net *net, struct krt_proto *p, uint priority, uint krt_type)
|
nl_mergable_route(struct nl_parse_state *s, net *net, struct krt_proto *p, uint priority, uint krt_type)
|
||||||
{
|
{
|
||||||
@ -1597,7 +1568,7 @@ nl_parse_route(struct nl_parse_state *s, struct nlmsghdr *h)
|
|||||||
|
|
||||||
if (a[RTA_MULTIPATH])
|
if (a[RTA_MULTIPATH])
|
||||||
{
|
{
|
||||||
struct nexthop *nh = nl_parse_multipath(p, a[RTA_MULTIPATH], i->rtm_family);
|
struct nexthop *nh = nl_parse_multipath(s, p, a[RTA_MULTIPATH], i->rtm_family);
|
||||||
if (!nh)
|
if (!nh)
|
||||||
{
|
{
|
||||||
log(L_ERR "KRT: Received strange multipath route %N", net->n.addr);
|
log(L_ERR "KRT: Received strange multipath route %N", net->n.addr);
|
||||||
@ -1784,8 +1755,8 @@ nl_parse_route(struct nl_parse_state *s, struct nlmsghdr *h)
|
|||||||
* Ideally, now we would send the received route to the rest of kernel code.
|
* Ideally, now we would send the received route to the rest of kernel code.
|
||||||
* But IPv6 ECMP routes before 4.11 are sent as a sequence of routes, so we
|
* But IPv6 ECMP routes before 4.11 are sent as a sequence of routes, so we
|
||||||
* postpone it and merge next hops until the end of the sequence. Note that
|
* postpone it and merge next hops until the end of the sequence. Note that
|
||||||
* proper multipath updates are rejected by nl_mergable_route(), so it is
|
* when doing merging of next hops, we expect the new route to be unipath.
|
||||||
* always the first case for them.
|
* Otherwise, we ignore additional next hops in nexthop_insert().
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!s->net)
|
if (!s->net)
|
||||||
|
Loading…
Reference in New Issue
Block a user