From c99050cce228b214c2856c6eebefbefffccade7f Mon Sep 17 00:00:00 2001 From: "Ondrej Zajicek (work)" Date: Mon, 11 Dec 2017 01:04:15 +0100 Subject: [PATCH] KRT: Fix bug in multipath handling --- sysdep/linux/netlink.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/sysdep/linux/netlink.c b/sysdep/linux/netlink.c index afb9dc8b..76ffe78b 100644 --- a/sysdep/linux/netlink.c +++ b/sysdep/linux/netlink.c @@ -677,8 +677,10 @@ nl_parse_multipath(struct krt_proto *p, struct rtattr *ra, int af) nh_buf_size = nh_buf_size ? (nh_buf_size * 2) : 4; nh_buffer = xrealloc(nh_buffer, nh_buf_size * NEXTHOP_MAX_SIZE); } - *last = rv = nh_buffer + nh_buf_used++; - rv->next = NULL; + /* 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); rv->flags = 0;