From 5702d4c1b97616f5212da31db01a2f3c79c15b7c Mon Sep 17 00:00:00 2001 From: Wolfgang Steudel Date: Tue, 7 Oct 2008 06:43:59 +0200 Subject: [PATCH] Only include local addr as peer addr if provided we're using libnl-1.1 for a project. When trying to delete all addresses of an interface by only setting interface index and address family of an rtnl_addr and executing rtnl_addr_delete() we received some error (I don't remember what it was). The bug(?) is in build_addr_msg() in lib/route/addr.c: IFA_ADDRESS is set to a_local when a_peer is not set, without checking if a_local was set. We just added if (tmpl->ce_mask & ADDR_ATTR_LOCAL) after the "else" (line 496 in the current git). --- lib/route/addr.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/route/addr.c b/lib/route/addr.c index b30c96d..33bdace 100644 --- a/lib/route/addr.c +++ b/lib/route/addr.c @@ -493,7 +493,7 @@ static int build_addr_msg(struct rtnl_addr *tmpl, int cmd, int flags, if (tmpl->ce_mask & ADDR_ATTR_PEER) NLA_PUT_ADDR(msg, IFA_ADDRESS, tmpl->a_peer); - else + else if (tmpl->ce_mask & ADDR_ATTR_LOCAL) NLA_PUT_ADDR(msg, IFA_ADDRESS, tmpl->a_local); if (tmpl->ce_mask & ADDR_ATTR_LABEL) -- 2.40.0