diff options
author | joe <joe@FreeBSD.org> | 2000-10-19 23:15:54 +0000 |
---|---|---|
committer | joe <joe@FreeBSD.org> | 2000-10-19 23:15:54 +0000 |
commit | c6d8349444659c4a281b31a709377e8c71a90ad9 (patch) | |
tree | 5b45af51429da655c27059a03f05adb01ed28593 /sys/netinet6 | |
parent | 8de06f19919021195552d59746e811f20efc29ba (diff) | |
download | FreeBSD-src-c6d8349444659c4a281b31a709377e8c71a90ad9.zip FreeBSD-src-c6d8349444659c4a281b31a709377e8c71a90ad9.tar.gz |
Augment the 'ifaddr' structure with a 'struct if_data' to keep
statistics on a per network address basis.
Teach the IPv4 and IPv6 input/output routines to log packets/bytes
against the network address connected to the flow.
Teach netstat to display the per-address stats for IP protocols
when 'netstat -i' is evoked, instead of displaying the per-interface
stats.
Diffstat (limited to 'sys/netinet6')
-rw-r--r-- | sys/netinet6/ip6_input.c | 5 | ||||
-rw-r--r-- | sys/netinet6/ip6_output.c | 8 |
2 files changed, 12 insertions, 1 deletions
diff --git a/sys/netinet6/ip6_input.c b/sys/netinet6/ip6_input.c index 46f0b9c..7e83bf5 100644 --- a/sys/netinet6/ip6_input.c +++ b/sys/netinet6/ip6_input.c @@ -493,6 +493,11 @@ ip6_input(m) /* this address is ready */ ours = 1; deliverifp = ia6->ia_ifp; /* correct? */ + + /* Count the packet in the ip address stats */ + ia6->ia_ifa.if_ipackets++; + ia6->ia_ifa.if_ibytes += m->m_pkthdr.len; + goto hbhcheck; } else { /* address is not ready, so discard the packet. */ diff --git a/sys/netinet6/ip6_output.c b/sys/netinet6/ip6_output.c index c17070c..4f1bd4c 100644 --- a/sys/netinet6/ip6_output.c +++ b/sys/netinet6/ip6_output.c @@ -156,7 +156,7 @@ ip6_output(m0, opt, ro, flags, im6o, ifpp) struct route_in6 ip6route; struct sockaddr_in6 *dst; int error = 0; - struct in6_ifaddr *ia; + struct in6_ifaddr *ia = NULL; u_long mtu; u_int32_t optlen = 0, plen = 0, unfragpartlen = 0; struct ip6_exthdrs exthdrs; @@ -890,6 +890,12 @@ skip_ipsec2:; #endif ) { + /* Record statistics for this interface address. */ + if (ia && !(flags & IPV6_FORWARDING)) { + ia->ia_ifa.if_opackets++; + ia->ia_ifa.if_obytes += m->m_pkthdr.len; + } + error = nd6_output(ifp, origifp, m, dst, ro->ro_rt); goto done; } else if (mtu < IPV6_MMTU) { |