__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 ||
}
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)
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);
.nhm.nh_family = preferred_family,
};
__u32 nh_flags = 0;
+ int ret;
while (argc > 0) {
if (!strcmp(*argv, "id")) {
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)
int raw = 0;
int type_ok = 0;
__u32 nhid = 0;
+ int ret;
if (cmd != RTM_DELROUTE) {
req.r.rtm_protocol = RTPROT_BOOT;
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)
.frh.family = preferred_family,
.frh.action = FR_ACT_UNSPEC,
};
+ int ret;
if (cmd == RTM_NEWRULE) {
if (argc == 0) {
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)