#define rtnl_dump_filter_errhndlr(rth, filter, farg, errhndlr, earg) \
rtnl_dump_filter_errhndlr_nc(rth, filter, farg, errhndlr, earg, 0)
+int rtnl_echo_talk(struct rtnl_handle *rtnl, struct nlmsghdr *n, int json,
+ int (*print_info)(struct nlmsghdr *n, void *arg))
+ __attribute__((warn_unused_result));
int rtnl_talk(struct rtnl_handle *rtnl, struct nlmsghdr *n,
struct nlmsghdr **answer)
__attribute__((warn_unused_result));
__u32 preferred_lft = INFINITY_LIFE_TIME;
__u32 valid_lft = INFINITY_LIFE_TIME;
unsigned int ifa_flags = 0;
- struct nlmsghdr *answer;
- int ret;
-
- if (echo_request)
- req.n.nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
while (argc > 0) {
if (strcmp(*argv, "peer") == 0 ||
}
if (echo_request)
- ret = rtnl_talk(&rth, &req.n, &answer);
- else
- ret = rtnl_talk(&rth, &req.n, NULL);
-
- if (ret < 0)
- return -2;
+ return rtnl_echo_talk(&rth, &req.n, json, print_addrinfo);
- if (echo_request) {
- new_json_obj(json);
- open_json_object(NULL);
- print_addrinfo(answer, stdout);
- close_json_object();
- delete_json_obj();
- free(answer);
- }
-
- return 0;
+ return rtnl_talk(&rth, &req.n, NULL);
}
int do_ipaddr(int argc, char **argv)
.n.nlmsg_type = cmd,
.i.ifi_family = preferred_family,
};
- struct nlmsghdr *answer;
int ret;
ret = iplink_parse(argc, argv, &req, &type);
if (ret < 0)
return ret;
- if (echo_request)
- req.n.nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
-
if (type) {
struct link_util *lu;
struct rtattr *linkinfo;
}
if (echo_request)
- ret = rtnl_talk(&rth, &req.n, &answer);
+ ret = rtnl_echo_talk(&rth, &req.n, json, print_linkinfo);
else
ret = rtnl_talk(&rth, &req.n, NULL);
- if (ret < 0)
- return -2;
-
- if (echo_request) {
- new_json_obj(json);
- open_json_object(NULL);
- print_linkinfo(answer, stdout);
- close_json_object();
- delete_json_obj();
- free(answer);
- }
+ if (ret)
+ return ret;
/* remove device from cache; next use can refresh with new data */
ll_drop_by_index(req.i.ifi_index);
.n.nlmsg_type = cmd,
.nhm.nh_family = preferred_family,
};
- struct nlmsghdr *answer;
__u32 nh_flags = 0;
- int ret;
-
- if (echo_request)
- req.n.nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
while (argc > 0) {
if (!strcmp(*argv, "id")) {
req.nhm.nh_flags = nh_flags;
if (echo_request)
- ret = rtnl_talk(&rth, &req.n, &answer);
- else
- ret = rtnl_talk(&rth, &req.n, NULL);
-
- if (ret < 0)
- return -2;
+ return rtnl_echo_talk(&rth, &req.n, json, print_nexthop_nocache);
- if (echo_request) {
- new_json_obj(json);
- open_json_object(NULL);
- print_nexthop_nocache(answer, (void *)stdout);
- close_json_object();
- delete_json_obj();
- free(answer);
- }
-
- return 0;
+ return rtnl_talk(&rth, &req.n, NULL);
}
static int ipnh_get_id(__u32 id)
};
char mxbuf[256];
struct rtattr *mxrta = (void *)mxbuf;
- struct nlmsghdr *answer;
unsigned int mxlock = 0;
char *d = NULL;
int gw_ok = 0;
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)
- req.n.nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
-
mxrta->rta_type = RTA_METRICS;
mxrta->rta_len = RTA_LENGTH(0);
req.r.rtm_type = RTN_UNICAST;
if (echo_request)
- ret = rtnl_talk(&rth, &req.n, &answer);
- else
- ret = rtnl_talk(&rth, &req.n, NULL);
+ return rtnl_echo_talk(&rth, &req.n, json, print_route);
- if (ret < 0)
- return -2;
-
- if (echo_request) {
- new_json_obj(json);
- open_json_object(NULL);
- print_route(answer, (void *)stdout);
- close_json_object();
- delete_json_obj();
- free(answer);
- }
-
- return 0;
+ return rtnl_talk(&rth, &req.n, NULL);
}
static int iproute_flush_cache(void)
.frh.family = preferred_family,
.frh.action = FR_ACT_UNSPEC,
};
- struct nlmsghdr *answer;
- int ret;
-
- if (echo_request)
- req.n.nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
if (cmd == RTM_NEWRULE) {
if (argc == 0) {
req.frh.table = RT_TABLE_MAIN;
if (echo_request)
- ret = rtnl_talk(&rth, &req.n, &answer);
- else
- ret = rtnl_talk(&rth, &req.n, NULL);
-
- if (ret < 0)
- return -2;
-
- if (echo_request) {
- new_json_obj(json);
- open_json_object(NULL);
- print_rule(answer, stdout);
- close_json_object();
- delete_json_obj();
- free(answer);
- }
+ return rtnl_echo_talk(&rth, &req.n, json, print_rule);
- return 0;
+ return rtnl_talk(&rth, &req.n, NULL);
}
int do_iprule(int argc, char **argv)
return __rtnl_talk_iov(rtnl, &iov, 1, answer, show_rtnl_err, errfn);
}
+int rtnl_echo_talk(struct rtnl_handle *rtnl, struct nlmsghdr *n, int json,
+ int (*print_info)(struct nlmsghdr *n, void *arg))
+{
+ struct nlmsghdr *answer;
+ int ret;
+
+ n->nlmsg_flags |= NLM_F_ECHO | NLM_F_ACK;
+
+ ret = rtnl_talk(rtnl, n, &answer);
+ if (ret)
+ return ret;
+
+ new_json_obj(json);
+ open_json_object(NULL);
+ print_info(answer, stdout);
+ close_json_object();
+ delete_json_obj();
+ free(answer);
+
+ return 0;
+}
+
int rtnl_talk(struct rtnl_handle *rtnl, struct nlmsghdr *n,
struct nlmsghdr **answer)
{