diff options
author | Eric Dumazet <edumazet@google.com> | 2019-11-08 03:27:22 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-11-08 07:03:08 +0300 |
commit | fd2f4737870eb866537fbbffa2b59414b9b0c0a2 (patch) | |
tree | 1a717aaeccccc9d8ff8f923dc9ac4f0d840655cd /include/linux/netdevice.h | |
parent | 5260dd3ed1ff7eba39251b28977e4d8950e2f099 (diff) | |
download | linux-fd2f4737870eb866537fbbffa2b59414b9b0c0a2.tar.xz |
net: use u64_stats_t in struct pcpu_lstats
In order to fix the data-race found by KCSAN, we
can use the new u64_stats_t type and its accessors instead
of plain u64 fields. This will still generate optimal code
for both 32 and 64 bit platforms.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/netdevice.h')
-rw-r--r-- | include/linux/netdevice.h | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index 461a36220cf4..f857f01234f7 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h @@ -2396,8 +2396,8 @@ struct pcpu_sw_netstats { } __aligned(4 * sizeof(u64)); struct pcpu_lstats { - u64 packets; - u64 bytes; + u64_stats_t packets; + u64_stats_t bytes; struct u64_stats_sync syncp; } __aligned(2 * sizeof(u64)); @@ -2408,8 +2408,8 @@ static inline void dev_lstats_add(struct net_device *dev, unsigned int len) struct pcpu_lstats *lstats = this_cpu_ptr(dev->lstats); u64_stats_update_begin(&lstats->syncp); - lstats->bytes += len; - lstats->packets++; + u64_stats_add(&lstats->bytes, len); + u64_stats_inc(&lstats->packets); u64_stats_update_end(&lstats->syncp); } |