]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
ip: fix return value for rtnl_talk failures
authorHangbin Liu <liuhangbin@gmail.com>
Tue, 8 Nov 2022 12:43:44 +0000 (20:43 +0800)
committerStephen Hemminger <stephen@networkplumber.org>
Mon, 28 Nov 2022 16:42:31 +0000 (08:42 -0800)
Since my last commit "rtnetlink: add new function rtnl_echo_talk()" we
return the kernel rtnl exit code directly, which breaks some kernel
selftest checking. As there are still a lot of tests checking -2 as the
error return value, to keep backward compatibility, let's keep using
-2 for all the rtnl return values.

Reported-by: Ido Schimmel <idosch@idosch.org>
Fixes: 6c09257f1bf6 ("rtnetlink: add new function rtnl_echo_talk()")
Signed-off-by: Hangbin Liu <liuhangbin@gmail.com>
Tested-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
ip/ipaddress.c
ip/iplink.c
ip/ipnexthop.c
ip/iproute.c
ip/iprule.c

index 456545bb64504b322f626b82882e7ae08932d98b..5e833482304462a663d1db8de92cd8be7b6078aa 100644 (file)
@@ -2422,6 +2422,7 @@ static int ipaddr_modify(int cmd, int flags, int argc, char **argv)
        __u32 preferred_lft = INFINITY_LIFE_TIME;
        __u32 valid_lft = INFINITY_LIFE_TIME;
        unsigned int ifa_flags = 0;
+       int ret;
 
        while (argc > 0) {
                if (strcmp(*argv, "peer") == 0 ||
@@ -2604,9 +2605,14 @@ static int ipaddr_modify(int cmd, int flags, int argc, char **argv)
        }
 
        if (echo_request)
-               return rtnl_echo_talk(&rth, &req.n, json, print_addrinfo);
+               ret = rtnl_echo_talk(&rth, &req.n, json, print_addrinfo);
+       else
+               ret = rtnl_talk(&rth, &req.n, NULL);
 
-       return rtnl_talk(&rth, &req.n, NULL);
+       if (ret)
+               return -2;
+
+       return 0;
 }
 
 int do_ipaddr(int argc, char **argv)
index 92ce6c47b486cb1b2f65f5f8de5028cfd3cbd5dd..301a535e66d957ee3b81fb6d301de5ad634c76f4 100644 (file)
@@ -1129,7 +1129,7 @@ static int iplink_modify(int cmd, unsigned int flags, int argc, char **argv)
                ret = rtnl_talk(&rth, &req.n, NULL);
 
        if (ret)
-               return ret;
+               return -2;
 
        /* remove device from cache; next use can refresh with new data */
        ll_drop_by_index(req.i.ifi_index);
index c87e847f345d38a09cf5363fc96ec9fec202ba51..9f16b8097b40c4f5b991ea64a4341d4e384ecd27 100644 (file)
@@ -920,6 +920,7 @@ static int ipnh_modify(int cmd, unsigned int flags, int argc, char **argv)
                .nhm.nh_family = preferred_family,
        };
        __u32 nh_flags = 0;
+       int ret;
 
        while (argc > 0) {
                if (!strcmp(*argv, "id")) {
@@ -1000,9 +1001,14 @@ static int ipnh_modify(int cmd, unsigned int flags, int argc, char **argv)
        req.nhm.nh_flags = nh_flags;
 
        if (echo_request)
-               return rtnl_echo_talk(&rth, &req.n, json, print_nexthop_nocache);
+               ret = rtnl_echo_talk(&rth, &req.n, json, print_nexthop_nocache);
+       else
+               ret = rtnl_talk(&rth, &req.n, NULL);
+
+       if (ret)
+               return -2;
 
-       return rtnl_talk(&rth, &req.n, NULL);
+       return 0;
 }
 
 static int ipnh_get_id(__u32 id)
index b4b9d1b203d426e026d54a91182c6c292b51ffd2..f34289e836ec3f093b24163e90063250bac49b5a 100644 (file)
@@ -1134,6 +1134,7 @@ static int iproute_modify(int cmd, unsigned int flags, int argc, char **argv)
        int raw = 0;
        int type_ok = 0;
        __u32 nhid = 0;
+       int ret;
 
        if (cmd != RTM_DELROUTE) {
                req.r.rtm_protocol = RTPROT_BOOT;
@@ -1588,9 +1589,14 @@ static int iproute_modify(int cmd, unsigned int flags, int argc, char **argv)
                req.r.rtm_type = RTN_UNICAST;
 
        if (echo_request)
-               return rtnl_echo_talk(&rth, &req.n, json, print_route);
+               ret = rtnl_echo_talk(&rth, &req.n, json, print_route);
+       else
+               ret = rtnl_talk(&rth, &req.n, NULL);
+
+       if (ret)
+               return -2;
 
-       return rtnl_talk(&rth, &req.n, NULL);
+       return 0;
 }
 
 static int iproute_flush_cache(void)
index 8f7504253a8872205820021128d345bde3de1982..8e5a2287ca6f08c62112ac9a8477a749206a1c8a 100644 (file)
@@ -787,6 +787,7 @@ static int iprule_modify(int cmd, int argc, char **argv)
                .frh.family = preferred_family,
                .frh.action = FR_ACT_UNSPEC,
        };
+       int ret;
 
        if (cmd == RTM_NEWRULE) {
                if (argc == 0) {
@@ -1017,9 +1018,14 @@ static int iprule_modify(int cmd, int argc, char **argv)
                req.frh.table = RT_TABLE_MAIN;
 
        if (echo_request)
-               return rtnl_echo_talk(&rth, &req.n, json, print_rule);
+               ret = rtnl_echo_talk(&rth, &req.n, json, print_rule);
+       else
+               ret = rtnl_talk(&rth, &req.n, NULL);
+
+       if (ret)
+               return -2;
 
-       return rtnl_talk(&rth, &req.n, NULL);
+       return 0;
 }
 
 int do_iprule(int argc, char **argv)