Since it's no longer relevant whether an IP address is primary or
secondary when flushing, ipaddr_flush() can be simplified a bit.

Signed-off-by: Phil Sutter <p...@nwl.cc>
---
 ip/ipaddress.c | 38 +-------------------------------------
 1 file changed, 1 insertion(+), 37 deletions(-)

diff --git a/ip/ipaddress.c b/ip/ipaddress.c
index 75b3e27..b5b444b 100644
--- a/ip/ipaddress.c
+++ b/ip/ipaddress.c
@@ -1143,28 +1143,6 @@ brief_exit:
        return 0;
 }
 
-static int print_addrinfo_primary(const struct sockaddr_nl *who,
-                                 struct nlmsghdr *n, void *arg)
-{
-       struct ifaddrmsg *ifa = NLMSG_DATA(n);
-
-       if (ifa->ifa_flags & IFA_F_SECONDARY)
-               return 0;
-
-       return print_addrinfo(who, n, arg);
-}
-
-static int print_addrinfo_secondary(const struct sockaddr_nl *who,
-                                   struct nlmsghdr *n, void *arg)
-{
-       struct ifaddrmsg *ifa = NLMSG_DATA(n);
-
-       if (!(ifa->ifa_flags & IFA_F_SECONDARY))
-               return 0;
-
-       return print_addrinfo(who, n, arg);
-}
-
 struct nlmsg_list
 {
        struct nlmsg_list *next;
@@ -1415,26 +1393,12 @@ static int ipaddr_flush(void)
        filter.flushe = sizeof(flushb);
 
        while ((max_flush_loops == 0) || (round < max_flush_loops)) {
-               const struct rtnl_dump_filter_arg a[3] = {
-                       {
-                               .filter = print_addrinfo_secondary,
-                               .arg1 = stdout,
-                       },
-                       {
-                               .filter = print_addrinfo_primary,
-                               .arg1 = stdout,
-                       },
-                       {
-                               .filter = NULL,
-                               .arg1 = NULL,
-                       },
-               };
                if (rtnl_wilddump_request(&rth, filter.family, RTM_GETADDR) < 
0) {
                        perror("Cannot send dump request");
                        exit(1);
                }
                filter.flushed = 0;
-               if (rtnl_dump_filter_l(&rth, a) < 0) {
+               if (rtnl_dump_filter(&rth, print_addrinfo, stdout) < 0) {
                        fprintf(stderr, "Flush terminated\n");
                        exit(1);
                }
-- 
2.1.2

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to