diff options
author | Eric Dumazet <dada1@cosmosbay.com> | 2007-11-16 02:29:24 -0800 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-11-18 18:47:38 -0800 |
commit | 483b23ffa3a5f44767038b0a676d757e0668437e (patch) | |
tree | 0d3e90fba6499af90077e01ba3c4da48a7c9b1d8 | |
parent | b242e891c218162cfbae064b1a9136cdbed5ee53 (diff) | |
download | kernel_samsung_smdk4412-483b23ffa3a5f44767038b0a676d757e0668437e.tar.gz kernel_samsung_smdk4412-483b23ffa3a5f44767038b0a676d757e0668437e.tar.bz2 kernel_samsung_smdk4412-483b23ffa3a5f44767038b0a676d757e0668437e.zip |
[NET]: Corrects a bug in ip_rt_acct_read()
It seems that stats of cpu 0 are counted twice, since
for_each_possible_cpu() is looping on all possible cpus, including 0
Before percpu conversion of ip_rt_acct, we should also remove the
assumption that CPU 0 is online (or even possible)
Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv4/route.c | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index 1bff9ed349f..c426dec6d57 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c @@ -2888,18 +2888,14 @@ static int ip_rt_acct_read(char *buffer, char **start, off_t offset, offset /= sizeof(u32); if (length > 0) { - u32 *src = ((u32 *) IP_RT_ACCT_CPU(0)) + offset; u32 *dst = (u32 *) buffer; - /* Copy first cpu. */ *start = buffer; - memcpy(dst, src, length); + memset(dst, 0, length); - /* Add the other cpus in, one int at a time */ for_each_possible_cpu(i) { unsigned int j; - - src = ((u32 *) IP_RT_ACCT_CPU(i)) + offset; + u32 *src = ((u32 *) IP_RT_ACCT_CPU(i)) + offset; for (j = 0; j < length/4; j++) dst[j] += src[j]; |