net: update netdev_rx_csum_fault() print dump only once
authorTanner Love <tannerlove@google.com>
Mon, 28 Jun 2021 13:50:07 +0000 (09:50 -0400)
committerDavid S. Miller <davem@davemloft.net>
Mon, 28 Jun 2021 22:54:57 +0000 (15:54 -0700)
Printing this stack dump multiple times does not provide additional
useful information, and consumes time in the data path. Printing once
is sufficient.

Changes
  v2: Format indentation properly

Signed-off-by: Tanner Love <tannerlove@google.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Acked-by: Mahesh Bandewar <maheshb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/dev.c

index 991d09b..d609366 100644 (file)
 #include <net/devlink.h>
 #include <linux/pm_runtime.h>
 #include <linux/prandom.h>
+#include <linux/once_lite.h>
 
 #include "net-sysfs.h"
 
@@ -3487,13 +3488,16 @@ EXPORT_SYMBOL(__skb_gso_segment);
 
 /* Take action when hardware reception checksum errors are detected. */
 #ifdef CONFIG_BUG
+static void do_netdev_rx_csum_fault(struct net_device *dev, struct sk_buff *skb)
+{
+       pr_err("%s: hw csum failure\n", dev ? dev->name : "<unknown>");
+       skb_dump(KERN_ERR, skb, true);
+       dump_stack();
+}
+
 void netdev_rx_csum_fault(struct net_device *dev, struct sk_buff *skb)
 {
-       if (net_ratelimit()) {
-               pr_err("%s: hw csum failure\n", dev ? dev->name : "<unknown>");
-               skb_dump(KERN_ERR, skb, true);
-               dump_stack();
-       }
+       DO_ONCE_LITE(do_netdev_rx_csum_fault, dev, skb);
 }
 EXPORT_SYMBOL(netdev_rx_csum_fault);
 #endif