From: Duan Jiong Date: Wed, 17 Dec 2014 07:28:45 +0000 (+0800) Subject: ip link: use addattr_nest()/addattr_nest_end() X-Git-Tag: v3.19.0~43 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a1e2e5fcee9d56f350e14b826bf928b3b52cdbf8;p=thirdparty%2Fiproute2.git ip link: use addattr_nest()/addattr_nest_end() Use addattr_nest() and addattr_nest_end() to simplify the code. Signed-off-by: Duan Jiong --- diff --git a/ip/iplink.c b/ip/iplink.c index f847fe7b0..2709173a1 100644 --- a/ip/iplink.c +++ b/ip/iplink.c @@ -706,11 +706,11 @@ static int iplink_modify(int cmd, unsigned int flags, int argc, char **argv) } if (type) { - struct rtattr *linkinfo = NLMSG_TAIL(&req.n); + struct rtattr *linkinfo; char slavebuf[128], *ulinep = strchr(type, '_'); int iflatype; - addattr_l(&req.n, sizeof(req), IFLA_LINKINFO, NULL, 0); + linkinfo = addattr_nest(&req.n, sizeof(req), IFLA_LINKINFO); addattr_l(&req.n, sizeof(req), IFLA_INFO_KIND, type, strlen(type)); @@ -728,14 +728,13 @@ static int iplink_modify(int cmd, unsigned int flags, int argc, char **argv) iflatype = IFLA_INFO_DATA; } if (lu && argc) { - struct rtattr * data = NLMSG_TAIL(&req.n); - addattr_l(&req.n, sizeof(req), iflatype, NULL, 0); + struct rtattr *data = addattr_nest(&req.n, sizeof(req), iflatype); if (lu->parse_opt && lu->parse_opt(lu, argc, argv, &req.n)) return -1; - data->rta_len = (void *)NLMSG_TAIL(&req.n) - (void *)data; + addattr_nest_end(&req.n, data); } else if (argc) { if (matches(*argv, "help") == 0) usage(); @@ -743,7 +742,7 @@ static int iplink_modify(int cmd, unsigned int flags, int argc, char **argv) "Try \"ip link help\".\n", *argv); return -1; } - linkinfo->rta_len = (void *)NLMSG_TAIL(&req.n) - (void *)linkinfo; + addattr_nest_end(&req.n, linkinfo); } else if (flags & NLM_F_CREATE) { fprintf(stderr, "Not enough information: \"type\" argument " "is required\n");