diff options
| author | Mark Brown <broonie@kernel.org> | 2020-12-11 17:48:50 +0000 | 
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2020-12-11 17:48:50 +0000 | 
| commit | 58f7553fa424fd0fd74e8b796d50c66014cebebe (patch) | |
| tree | 8aecb1d047b1df2abbfa1ef323d2a724a6a61c77 /net/xfrm/xfrm_interface.c | |
| parent | dd91c555461261fed220ae29a508f508a0afeb43 (diff) | |
| parent | 9326e4f1e5dd1a4410c429638d3c412b6fc17040 (diff) | |
Merge remote-tracking branch 'spi/for-5.10' into spi-linus
Diffstat (limited to 'net/xfrm/xfrm_interface.c')
| -rw-r--r-- | net/xfrm/xfrm_interface.c | 31 | 
1 files changed, 2 insertions, 29 deletions
| diff --git a/net/xfrm/xfrm_interface.c b/net/xfrm/xfrm_interface.c index a8f66112c52b..aa4cdcf69d47 100644 --- a/net/xfrm/xfrm_interface.c +++ b/net/xfrm/xfrm_interface.c @@ -210,7 +210,6 @@ static void xfrmi_scrub_packet(struct sk_buff *skb, bool xnet)  static int xfrmi_rcv_cb(struct sk_buff *skb, int err)  {  	const struct xfrm_mode *inner_mode; -	struct pcpu_sw_netstats *tstats;  	struct net_device *dev;  	struct xfrm_state *x;  	struct xfrm_if *xi; @@ -255,13 +254,7 @@ static int xfrmi_rcv_cb(struct sk_buff *skb, int err)  	}  	xfrmi_scrub_packet(skb, xnet); - -	tstats = this_cpu_ptr(dev->tstats); - -	u64_stats_update_begin(&tstats->syncp); -	tstats->rx_packets++; -	tstats->rx_bytes += skb->len; -	u64_stats_update_end(&tstats->syncp); +	dev_sw_netstats_rx_add(dev, skb->len);  	return 0;  } @@ -548,27 +541,7 @@ static int xfrmi_update(struct xfrm_if *xi, struct xfrm_if_parms *p)  static void xfrmi_get_stats64(struct net_device *dev,  			       struct rtnl_link_stats64 *s)  { -	int cpu; - -	for_each_possible_cpu(cpu) { -		struct pcpu_sw_netstats *stats; -		struct pcpu_sw_netstats tmp; -		int start; - -		stats = per_cpu_ptr(dev->tstats, cpu); -		do { -			start = u64_stats_fetch_begin_irq(&stats->syncp); -			tmp.rx_packets = stats->rx_packets; -			tmp.rx_bytes   = stats->rx_bytes; -			tmp.tx_packets = stats->tx_packets; -			tmp.tx_bytes   = stats->tx_bytes; -		} while (u64_stats_fetch_retry_irq(&stats->syncp, start)); - -		s->rx_packets += tmp.rx_packets; -		s->rx_bytes   += tmp.rx_bytes; -		s->tx_packets += tmp.tx_packets; -		s->tx_bytes   += tmp.tx_bytes; -	} +	dev_fetch_sw_netstats(s, dev->tstats);  	s->rx_dropped = dev->stats.rx_dropped;  	s->tx_dropped = dev->stats.tx_dropped; | 
