summaryrefslogtreecommitdiffstats
path: root/net/packet
diff options
context:
space:
mode:
authorWillem de Bruijn <willemb@google.com>2013-08-19 16:40:22 -0400
committerDavid S. Miller <davem@davemloft.net>2013-08-20 17:23:58 -0700
commit8bcdeaff5ed544704a9a691d4aef0adb3f9c5b8f (patch)
treea100df027287cf5e047dd8f9c651673afc8b6434 /net/packet
parent8b64fd61474797acde426742e80028f5b1c4adf6 (diff)
downloadlinux-8bcdeaff5ed544704a9a691d4aef0adb3f9c5b8f.tar.gz
linux-8bcdeaff5ed544704a9a691d4aef0adb3f9c5b8f.tar.bz2
linux-8bcdeaff5ed544704a9a691d4aef0adb3f9c5b8f.zip
packet: restore packet statistics tp_packets to include drops
getsockopt PACKET_STATISTICS returns tp_packets + tp_drops. Commit ee80fbf301 ("packet: account statistics only in tpacket_stats_u") cleaned up the getsockopt PACKET_STATISTICS code. This also changed semantics. Historically, tp_packets included tp_drops on return. The commit removed the line that adds tp_drops into tp_packets. This patch reinstates the old semantics. Signed-off-by: Willem de Bruijn <willemb@google.com> Acked-by: Daniel Borkmann <dborkman@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/packet')
-rw-r--r--net/packet/af_packet.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c
index 4b66c752eae5..75c8bbf598c8 100644
--- a/net/packet/af_packet.c
+++ b/net/packet/af_packet.c
@@ -3259,9 +3259,11 @@ static int packet_getsockopt(struct socket *sock, int level, int optname,
if (po->tp_version == TPACKET_V3) {
lv = sizeof(struct tpacket_stats_v3);
+ st.stats3.tp_packets += st.stats3.tp_drops;
data = &st.stats3;
} else {
lv = sizeof(struct tpacket_stats);
+ st.stats1.tp_packets += st.stats1.tp_drops;
data = &st.stats1;
}