summaryrefslogtreecommitdiffstats
path: root/sys/netinet6
diff options
context:
space:
mode:
authorjoe <joe@FreeBSD.org>2000-10-19 23:15:54 +0000
committerjoe <joe@FreeBSD.org>2000-10-19 23:15:54 +0000
commitc6d8349444659c4a281b31a709377e8c71a90ad9 (patch)
tree5b45af51429da655c27059a03f05adb01ed28593 /sys/netinet6
parent8de06f19919021195552d59746e811f20efc29ba (diff)
downloadFreeBSD-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.c5
-rw-r--r--sys/netinet6/ip6_output.c8
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) {
OpenPOWER on IntegriCloud