diff options
author | Mingming Cao <cmm@us.ibm.com> | 2006-06-23 02:05:41 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-23 07:43:06 -0700 |
commit | 0216bfcffe424a5473daa4da47440881b36c1f41 (patch) | |
tree | 80eaa49bfc644b070e57c251285048992ac6fafc /lib/percpu_counter.c | |
parent | 3cbc564024d8f174202f023e8a2991782f6a9431 (diff) | |
download | kernel-common-0216bfcffe424a5473daa4da47440881b36c1f41.tar.gz kernel-common-0216bfcffe424a5473daa4da47440881b36c1f41.tar.bz2 kernel-common-0216bfcffe424a5473daa4da47440881b36c1f41.zip |
[PATCH] percpu counter data type changes to suppport more than 2**31 ext3 free blocks counter
The percpu counter data type are changed in this set of patches to support
more users like ext3 who need more than 32 bit to store the free blocks
total in the filesystem.
- Generic perpcu counters data type changes. The size of the global counter
and local counter were explictly specified using s64 and s32. The global
counter is changed from long to s64, while the local counter is changed from
long to s32, so we could avoid doing 64 bit update in most cases.
- Users of the percpu counters are updated to make use of the new
percpu_counter_init() routine now taking an additional parameter to allow
users to pass the initial value of the global counter.
Signed-off-by: Mingming Cao <cmm@us.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'lib/percpu_counter.c')
-rw-r--r-- | lib/percpu_counter.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/percpu_counter.c b/lib/percpu_counter.c index 7a87003f8e8f..850449080e1c 100644 --- a/lib/percpu_counter.c +++ b/lib/percpu_counter.c @@ -5,10 +5,10 @@ #include <linux/percpu_counter.h> #include <linux/module.h> -void percpu_counter_mod(struct percpu_counter *fbc, long amount) +void percpu_counter_mod(struct percpu_counter *fbc, s32 amount) { long count; - long *pcount; + s32 *pcount; int cpu = get_cpu(); pcount = per_cpu_ptr(fbc->counters, cpu); @@ -29,15 +29,15 @@ EXPORT_SYMBOL(percpu_counter_mod); * Add up all the per-cpu counts, return the result. This is a more accurate * but much slower version of percpu_counter_read_positive() */ -long percpu_counter_sum(struct percpu_counter *fbc) +s64 percpu_counter_sum(struct percpu_counter *fbc) { - long ret; + s64 ret; int cpu; spin_lock(&fbc->lock); ret = fbc->count; for_each_possible_cpu(cpu) { - long *pcount = per_cpu_ptr(fbc->counters, cpu); + s32 *pcount = per_cpu_ptr(fbc->counters, cpu); ret += *pcount; } spin_unlock(&fbc->lock); |