Commit f63ed3e6 authored by Phil Sutter's avatar Phil Sutter Committed by Stephen Hemminger

lib/ll_addr: improve ll_addr_n2a() a bit

Apart from making the code a bit more compact and efficient, this also
prevents a potential buffer overflow if the passed buffer is really too
small: Although correctly decrementing the size parameter passed to
snprintf, it could become negative which would then wrap since snprintf
uses (unsigned) size_t for the parameter.
Signed-off-by: default avatarPhil Sutter <phil@nwl.cc>
parent 7faf1588
...@@ -41,18 +41,9 @@ const char *ll_addr_n2a(const unsigned char *addr, int alen, int type, char *buf ...@@ -41,18 +41,9 @@ const char *ll_addr_n2a(const unsigned char *addr, int alen, int type, char *buf
if (alen == 16 && type == ARPHRD_TUNNEL6) { if (alen == 16 && type == ARPHRD_TUNNEL6) {
return inet_ntop(AF_INET6, addr, buf, blen); return inet_ntop(AF_INET6, addr, buf, blen);
} }
l = 0; snprintf(buf, blen, "%02x", addr[0]);
for (i=0; i<alen; i++) { for (i = 1, l = 2; i < alen && l < blen; i++, l += 3)
if (i==0) { snprintf(buf + l, blen - l, ":%02x", addr[i]);
snprintf(buf+l, blen, "%02x", addr[i]);
blen -= 2;
l += 2;
} else {
snprintf(buf+l, blen, ":%02x", addr[i]);
blen -= 3;
l += 3;
}
}
return buf; return buf;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment