tcp_metric: Use get_addr_rta()
While there remove & from inet_prefix.data when since it is array. Signed-off-by: Serhey Popovych <serhe.popovych@gmail.com> Signed-off-by: David Ahern <dsahern@gmail.com>
This commit is contained in:
parent
62f9f94acf
commit
228f2e97ba
|
|
@ -96,7 +96,7 @@ static int process_msg(const struct sockaddr_nl *who, struct nlmsghdr *n,
|
||||||
struct rtattr *attrs[TCP_METRICS_ATTR_MAX + 1], *a;
|
struct rtattr *attrs[TCP_METRICS_ATTR_MAX + 1], *a;
|
||||||
int len = n->nlmsg_len;
|
int len = n->nlmsg_len;
|
||||||
inet_prefix daddr, saddr;
|
inet_prefix daddr, saddr;
|
||||||
int family, i, atype, stype, dlen = 0, slen = 0;
|
int i, atype, stype;
|
||||||
|
|
||||||
if (n->nlmsg_type != genl_family)
|
if (n->nlmsg_type != genl_family)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
@ -116,61 +116,61 @@ static int process_msg(const struct sockaddr_nl *who, struct nlmsghdr *n,
|
||||||
if (f.daddr.family && f.daddr.family != AF_INET)
|
if (f.daddr.family && f.daddr.family != AF_INET)
|
||||||
return 0;
|
return 0;
|
||||||
a = attrs[TCP_METRICS_ATTR_ADDR_IPV4];
|
a = attrs[TCP_METRICS_ATTR_ADDR_IPV4];
|
||||||
memcpy(&daddr.data, RTA_DATA(a), 4);
|
daddr.family = AF_INET;
|
||||||
daddr.bytelen = 4;
|
|
||||||
family = AF_INET;
|
|
||||||
atype = TCP_METRICS_ATTR_ADDR_IPV4;
|
atype = TCP_METRICS_ATTR_ADDR_IPV4;
|
||||||
dlen = RTA_PAYLOAD(a);
|
|
||||||
} else if (attrs[TCP_METRICS_ATTR_ADDR_IPV6]) {
|
} else if (attrs[TCP_METRICS_ATTR_ADDR_IPV6]) {
|
||||||
if (f.daddr.family && f.daddr.family != AF_INET6)
|
if (f.daddr.family && f.daddr.family != AF_INET6)
|
||||||
return 0;
|
return 0;
|
||||||
a = attrs[TCP_METRICS_ATTR_ADDR_IPV6];
|
a = attrs[TCP_METRICS_ATTR_ADDR_IPV6];
|
||||||
memcpy(&daddr.data, RTA_DATA(a), 16);
|
daddr.family = AF_INET6;
|
||||||
daddr.bytelen = 16;
|
|
||||||
family = AF_INET6;
|
|
||||||
atype = TCP_METRICS_ATTR_ADDR_IPV6;
|
atype = TCP_METRICS_ATTR_ADDR_IPV6;
|
||||||
dlen = RTA_PAYLOAD(a);
|
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (get_addr_rta(&daddr, a, daddr.family))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (f.daddr.family && f.daddr.bitlen >= 0 &&
|
||||||
|
inet_addr_match(&daddr, &f.daddr, f.daddr.bitlen))
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (attrs[TCP_METRICS_ATTR_SADDR_IPV4]) {
|
if (attrs[TCP_METRICS_ATTR_SADDR_IPV4]) {
|
||||||
if (f.saddr.family && f.saddr.family != AF_INET)
|
if (f.saddr.family && f.saddr.family != AF_INET)
|
||||||
return 0;
|
return 0;
|
||||||
a = attrs[TCP_METRICS_ATTR_SADDR_IPV4];
|
a = attrs[TCP_METRICS_ATTR_SADDR_IPV4];
|
||||||
memcpy(&saddr.data, RTA_DATA(a), 4);
|
saddr.family = AF_INET;
|
||||||
saddr.bytelen = 4;
|
|
||||||
stype = TCP_METRICS_ATTR_SADDR_IPV4;
|
stype = TCP_METRICS_ATTR_SADDR_IPV4;
|
||||||
slen = RTA_PAYLOAD(a);
|
|
||||||
} else if (attrs[TCP_METRICS_ATTR_SADDR_IPV6]) {
|
} else if (attrs[TCP_METRICS_ATTR_SADDR_IPV6]) {
|
||||||
if (f.saddr.family && f.saddr.family != AF_INET6)
|
if (f.saddr.family && f.saddr.family != AF_INET6)
|
||||||
return 0;
|
return 0;
|
||||||
a = attrs[TCP_METRICS_ATTR_SADDR_IPV6];
|
a = attrs[TCP_METRICS_ATTR_SADDR_IPV6];
|
||||||
memcpy(&saddr.data, RTA_DATA(a), 16);
|
saddr.family = AF_INET6;
|
||||||
saddr.bytelen = 16;
|
|
||||||
stype = TCP_METRICS_ATTR_SADDR_IPV6;
|
stype = TCP_METRICS_ATTR_SADDR_IPV6;
|
||||||
slen = RTA_PAYLOAD(a);
|
} else {
|
||||||
|
saddr.family = AF_UNSPEC;
|
||||||
|
stype = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (f.daddr.family && f.daddr.bitlen >= 0 &&
|
/* Only get/check for the source-address if the kernel supports it. */
|
||||||
inet_addr_match(&daddr, &f.daddr, f.daddr.bitlen))
|
if (saddr.family) {
|
||||||
return 0;
|
if (get_addr_rta(&saddr, a, saddr.family))
|
||||||
/* Only check for the source-address if the kernel supports it,
|
return 0;
|
||||||
* meaning slen != 0.
|
|
||||||
*/
|
if (f.saddr.family && f.saddr.bitlen >= 0 &&
|
||||||
if (slen && f.saddr.family && f.saddr.bitlen >= 0 &&
|
inet_addr_match(&saddr, &f.saddr, f.saddr.bitlen))
|
||||||
inet_addr_match(&saddr, &f.saddr, f.saddr.bitlen))
|
return 0;
|
||||||
return 0;
|
}
|
||||||
|
|
||||||
if (f.flushb) {
|
if (f.flushb) {
|
||||||
struct nlmsghdr *fn;
|
struct nlmsghdr *fn;
|
||||||
|
|
||||||
TCPM_REQUEST(req2, 128, TCP_METRICS_CMD_DEL, NLM_F_REQUEST);
|
TCPM_REQUEST(req2, 128, TCP_METRICS_CMD_DEL, NLM_F_REQUEST);
|
||||||
|
|
||||||
addattr_l(&req2.n, sizeof(req2), atype, &daddr.data,
|
addattr_l(&req2.n, sizeof(req2), atype, daddr.data,
|
||||||
daddr.bytelen);
|
daddr.bytelen);
|
||||||
if (slen)
|
if (saddr.family)
|
||||||
addattr_l(&req2.n, sizeof(req2), stype, &saddr.data,
|
addattr_l(&req2.n, sizeof(req2), stype, saddr.data,
|
||||||
saddr.bytelen);
|
saddr.bytelen);
|
||||||
|
|
||||||
if (NLMSG_ALIGN(f.flushp) + req2.n.nlmsg_len > f.flushe) {
|
if (NLMSG_ALIGN(f.flushp) + req2.n.nlmsg_len > f.flushe) {
|
||||||
|
|
@ -190,7 +190,7 @@ static int process_msg(const struct sockaddr_nl *who, struct nlmsghdr *n,
|
||||||
fprintf(fp, "Deleted ");
|
fprintf(fp, "Deleted ");
|
||||||
|
|
||||||
fprintf(fp, "%s",
|
fprintf(fp, "%s",
|
||||||
format_host(family, dlen, &daddr.data));
|
format_host(daddr.family, daddr.bytelen, daddr.data));
|
||||||
|
|
||||||
a = attrs[TCP_METRICS_ATTR_AGE];
|
a = attrs[TCP_METRICS_ATTR_AGE];
|
||||||
if (a) {
|
if (a) {
|
||||||
|
|
@ -292,9 +292,9 @@ static int process_msg(const struct sockaddr_nl *who, struct nlmsghdr *n,
|
||||||
fprintf(fp, " fo_cookie %s", cookie);
|
fprintf(fp, " fo_cookie %s", cookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (slen) {
|
if (saddr.family) {
|
||||||
fprintf(fp, " source %s",
|
fprintf(fp, " source %s",
|
||||||
format_host(family, slen, &saddr.data));
|
format_host(saddr.family, saddr.bytelen, saddr.data));
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(fp, "\n");
|
fprintf(fp, "\n");
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue