ipv6: only update __use and lastusetime once per jiffy at most
authorWei Wang <weiwan@google.com>
Fri, 13 Oct 2017 22:08:07 +0000 (15:08 -0700)
committerDavid S. Miller <davem@davemloft.net>
Mon, 16 Oct 2017 20:08:30 +0000 (21:08 +0100)
commit0da4af00b2ed3dbe46788623a696c4169447eadc
treeb4a6120d1c252e7e1c8df5316db753ed36e8d682
parent0e80193bd8c1d97654f1a2f45934e7372e9a512e
ipv6: only update __use and lastusetime once per jiffy at most

In order to not dirty the cacheline too often, we try to only update
dst->__use and dst->lastusetime at most once per jiffy.
As dst->lastusetime is only used by ipv6 garbage collector, it should
be good enough time resolution.
And __use is only used in ipv6_route_seq_show() to show how many times a
dst has been used. And as __use is not atomic_t right now, it does not
show the precise number of usage times anyway. So we think it should be
OK to only update it at most once per jiffy.

According to my latest syn flood test on a machine with intel Xeon 6th
gen processor and 2 10G mlx nics bonded together, each with 8 rx queues
on 2 NUMA nodes:
With this patch, the packet process rate increases from ~3.49Mpps to
~3.75Mpps with a 7% increase rate.

Note: dst_use() is being renamed to dst_hold_and_use() to better specify
the purpose of the function.

Signed-off-by: Wei Wang <weiwan@google.com>
Acked-by: Eric Dumazet <edumazet@googl.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/dst.h
net/decnet/dn_route.c