summaryrefslogtreecommitdiff
path: root/net
diff options
context:
space:
mode:
authorAlex Elder <elder@linaro.org>2021-06-11 21:26:00 +0300
committerDavid S. Miller <davem@davemloft.net>2021-06-14 22:13:38 +0300
commit994c393bb6886d6d94d628475b274a8cb3fc67a4 (patch)
tree36f896c2133b667725d3726a8abe619e4a3c0a3c /net
parent4f667b8e049e716a0533fc927f50310fe6e40d22 (diff)
downloadlinux-994c393bb6886d6d94d628475b274a8cb3fc67a4.tar.xz
net: qualcomm: rmnet: don't over-count statistics
The purpose of the loop using u64_stats_fetch_*_irq() is to ensure statistics on a given CPU are collected atomically. If one of the statistics values gets updated within the begin/retry window, the loop will run again. Currently the statistics totals are updated inside that window. This means that if the loop ever retries, the statistics for the CPU will be counted more than once. Fix this by taking a snapshot of a CPU's statistics inside the protected window, and then updating the counters with the snapshot values after exiting the loop. (Also add a newline at the end of this file...) Fixes: 192c4b5d48f2a ("net: qualcomm: rmnet: Add support for 64 bit stats") Signed-off-by: Alex Elder <elder@linaro.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions