From 82958bdbf4a09f557e17ea2d01e3c43e10cfc73f Mon Sep 17 00:00:00 2001 From: Herbert Xu Date: Thu, 20 Dec 2007 04:13:21 -0800 Subject: [PATCH] --- yaml --- r: 78563 b: refs/heads/master c: d647b36a69bf0a630ebf981bde3c0651e2779e5e h: refs/heads/master i: 78561: 36075be4258690c6cb07c4a6c647ddd7bc4fefdd 78559: 98585fe948a8d7268a80ccf3ed7d62c46524b732 v: v3 --- [refs] | 2 +- trunk/include/net/snmp.h | 21 +++++++++++++++++---- 2 files changed, 18 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index c55e96e0996e..16d9603604de 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 2caf62f6cae46e36b1c4a1b0f2d9ef82af89cad2 +refs/heads/master: d647b36a69bf0a630ebf981bde3c0651e2779e5e diff --git a/trunk/include/net/snmp.h b/trunk/include/net/snmp.h index 9c5793db637f..fbb66663a42c 100644 --- a/trunk/include/net/snmp.h +++ b/trunk/include/net/snmp.h @@ -23,6 +23,7 @@ #include #include +#include /* * Mibs are stored in array of unsigned long. @@ -135,14 +136,26 @@ struct linux_mib { #define SNMP_INC_STATS_BH(mib, field) \ (per_cpu_ptr(mib[0], raw_smp_processor_id())->mibs[field]++) #define SNMP_INC_STATS_USER(mib, field) \ - (per_cpu_ptr(mib[1], raw_smp_processor_id())->mibs[field]++) + do { \ + per_cpu_ptr(mib[1], get_cpu())->mibs[field]++; \ + put_cpu(); \ + } while (0) #define SNMP_INC_STATS(mib, field) \ - (per_cpu_ptr(mib[!in_softirq()], raw_smp_processor_id())->mibs[field]++) + do { \ + per_cpu_ptr(mib[!in_softirq()], get_cpu())->mibs[field]++; \ + put_cpu(); \ + } while (0) #define SNMP_DEC_STATS(mib, field) \ - (per_cpu_ptr(mib[!in_softirq()], raw_smp_processor_id())->mibs[field]--) + do { \ + per_cpu_ptr(mib[!in_softirq()], get_cpu())->mibs[field]--; \ + put_cpu(); \ + } while (0) #define SNMP_ADD_STATS_BH(mib, field, addend) \ (per_cpu_ptr(mib[0], raw_smp_processor_id())->mibs[field] += addend) #define SNMP_ADD_STATS_USER(mib, field, addend) \ - (per_cpu_ptr(mib[1], raw_smp_processor_id())->mibs[field] += addend) + do { \ + per_cpu_ptr(mib[1], get_cpu())->mibs[field] += addend; \ + put_cpu(); \ + } while (0) #endif