From: Thomas Graf Date: Wed, 19 Dec 2007 18:41:01 +0000 (+0100) Subject: Represent default route with destination address length zero X-Git-Tag: libnl2_0~170 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=464988628802b76d5b3e50af99158413ac28bd18;p=libnl Represent default route with destination address length zero So far the destination address for default routes was NULL which complicated the handling of routes in general. By assigning a address of length zero they can be compared to each other. This allows the cache manager to properly handle default routes. --- diff --git a/lib/route/route.c b/lib/route/route.c index 2fc25f7..0644bd7 100644 --- a/lib/route/route.c +++ b/lib/route/route.c @@ -91,15 +91,18 @@ static int route_msg_parser(struct nl_cache_ops *ops, struct sockaddr_nl *who, dst = nla_get_addr(tb[RTA_DST], rtm->rtm_family); if (dst == NULL) goto errout_errno; - } else if (rtm->rtm_dst_len) + } else { dst = nl_addr_alloc(0); - - if (dst) { - nl_addr_set_prefixlen(dst, rtm->rtm_dst_len); - rtnl_route_set_dst(route, dst); - nl_addr_put(dst); + nl_addr_set_family(dst, rtm->rtm_family); } + nl_addr_set_prefixlen(dst, rtm->rtm_dst_len); + err = rtnl_route_set_dst(route, dst); + if (err < 0) + goto errout; + + nl_addr_put(dst); + if (tb[RTA_SRC]) { src = nla_get_addr(tb[RTA_SRC], rtm->rtm_family); if (src == NULL) diff --git a/lib/route/route_obj.c b/lib/route/route_obj.c index 7d954fc..78e7712 100644 --- a/lib/route/route_obj.c +++ b/lib/route/route_obj.c @@ -136,10 +136,11 @@ static int route_dump_brief(struct nl_object *a, struct nl_dump_params *p) link_cache = nl_cache_mngt_require("route/link"); - if (r->ce_mask & ROUTE_ATTR_DST) - dp_dump(p, "%s ", nl_addr2str(r->rt_dst, buf, sizeof(buf))); - else + if (!(r->ce_mask & ROUTE_ATTR_DST) || + nl_addr_get_len(r->rt_dst) == 0) dp_dump(p, "default "); + else + dp_dump(p, "%s ", nl_addr2str(r->rt_dst, buf, sizeof(buf))); if (r->ce_mask & ROUTE_ATTR_OIF) { if (link_cache)