If both ext2 and ext3 are built as modules there is nothing to pull percpu_counter_mod() into the kernel build and the ext2 and ext3 modules do not load. So move percpu_counter_mod() out of lib.a. /dev/null | 21 --------------------- lib/Makefile | 1 - mm/swap.c | 21 +++++++++++++++++++++ 3 files changed, 21 insertions(+), 22 deletions(-) diff -puN -L lib/percpu_counter.c lib/percpu_counter.c~percpu-counter-linkage-fix /dev/null --- 25/lib/percpu_counter.c +++ /dev/null 2002-08-30 16:31:37.000000000 -0700 @@ -1,21 +0,0 @@ -#include -#include -#include - -void percpu_counter_mod(struct percpu_counter *fbc, long amount) -{ - int cpu = get_cpu(); - long count = fbc->counters[cpu].count; - - count += amount; - if (count >= FBC_BATCH || count <= -FBC_BATCH) { - spin_lock(&fbc->lock); - fbc->count += count; - spin_unlock(&fbc->lock); - count = 0; - } - fbc->counters[cpu].count = count; - put_cpu(); -} - -EXPORT_SYMBOL(percpu_counter_mod); diff -puN lib/Makefile~percpu-counter-linkage-fix lib/Makefile --- 25/lib/Makefile~percpu-counter-linkage-fix 2003-11-07 20:36:48.000000000 -0800 +++ 25-akpm/lib/Makefile 2003-11-07 20:36:48.000000000 -0800 @@ -9,7 +9,6 @@ lib-y := errno.o ctype.o string.o vsprin lib-$(CONFIG_RWSEM_GENERIC_SPINLOCK) += rwsem-spinlock.o lib-$(CONFIG_RWSEM_XCHGADD_ALGORITHM) += rwsem.o -lib-$(CONFIG_SMP) += percpu_counter.o ifneq ($(CONFIG_HAVE_DEC_LOCK),y) lib-y += dec_and_lock.o diff -puN mm/swap.c~percpu-counter-linkage-fix mm/swap.c --- 25/mm/swap.c~percpu-counter-linkage-fix 2003-11-07 20:36:48.000000000 -0800 +++ 25-akpm/mm/swap.c 2003-11-07 20:36:48.000000000 -0800 @@ -14,6 +14,7 @@ */ #include +#include #include #include #include @@ -23,6 +24,8 @@ #include #include #include /* for try_to_release_page() */ +#include +#include #include /* How many pages do we try to swap or page in/out together? */ @@ -380,6 +383,24 @@ void vm_acct_memory(long pages) EXPORT_SYMBOL(vm_acct_memory); #endif +#ifdef CONFIG_SMP +void percpu_counter_mod(struct percpu_counter *fbc, long amount) +{ + int cpu = get_cpu(); + long count = fbc->counters[cpu].count; + + count += amount; + if (count >= FBC_BATCH || count <= -FBC_BATCH) { + spin_lock(&fbc->lock); + fbc->count += count; + spin_unlock(&fbc->lock); + count = 0; + } + fbc->counters[cpu].count = count; + put_cpu(); +} +EXPORT_SYMBOL(percpu_counter_mod); +#endif /* * Perform any setup for the swap system _