Index: linux-2.6.17-rc6-mm1/mm/page_alloc.c =================================================================== --- linux-2.6.17-rc6-mm1.orig/mm/page_alloc.c 2006-06-09 15:35:21.719837630 -0700 +++ linux-2.6.17-rc6-mm1/mm/page_alloc.c 2006-06-09 17:51:18.789713315 -0700 @@ -1612,7 +1612,7 @@ static void sum_vm_events(unsigned long * The result is unavoidably approximate - it can change * during and after execution of this function. */ -static void all_vm_events(unsigned long *ret) +void all_vm_events(unsigned long *ret) { sum_vm_events(ret, &cpu_online_map); } Index: linux-2.6.17-rc6-mm1/arch/s390/appldata/appldata_mem.c =================================================================== --- linux-2.6.17-rc6-mm1.orig/arch/s390/appldata/appldata_mem.c 2006-06-05 17:57:02.000000000 -0700 +++ linux-2.6.17-rc6-mm1/arch/s390/appldata/appldata_mem.c 2006-06-09 17:51:18.790689817 -0700 @@ -107,21 +107,21 @@ static void appldata_get_mem_data(void * * serialized through the appldata_ops_lock and can use static */ static struct sysinfo val; - static struct page_state ps; + unsigned long ev[NR_VM_EVENT_ITEMS]; struct appldata_mem_data *mem_data; mem_data = data; mem_data->sync_count_1++; - get_full_page_state(&ps); - mem_data->pgpgin = ps.pgpgin >> 1; - mem_data->pgpgout = ps.pgpgout >> 1; - mem_data->pswpin = ps.pswpin; - mem_data->pswpout = ps.pswpout; - mem_data->pgalloc = ps.pgalloc_high + ps.pgalloc_normal + - ps.pgalloc_dma; - mem_data->pgfault = ps.pgfault; - mem_data->pgmajfault = ps.pgmajfault; + all_vm_events(&ev); + mem_data->pgpgin = ev[PGPIN] >> 1; + mem_data->pgpgout = ev[PGPOUT] >> 1; + mem_data->pswpin = ev[PSWPIN]; + mem_data->pswpout = ev[PSWPOUT]; + mem_data->pgalloc = ev[PGALLOC_HIGH] + ev[PGALLOC_NORMAL] + + ev[PGALLOC_DMA]; + mem_data->pgfault = ev[PGFAULT]; + mem_data->pgmajfault = ev[PGMAJFAULT]; si_meminfo(&val); mem_data->sharedram = val.sharedram; @@ -130,7 +130,7 @@ static void appldata_get_mem_data(void * mem_data->totalhigh = P2K(val.totalhigh); mem_data->freehigh = P2K(val.freehigh); mem_data->bufferram = P2K(val.bufferram); - mem_data->cached = P2K(atomic_read(&nr_pagecache) - val.bufferram); + mem_data->cached = P2K(global_page_state(NR_PAGECACHE) - val.bufferram); si_swapinfo(&val); mem_data->totalswap = P2K(val.totalswap); Index: linux-2.6.17-rc6-mm1/include/linux/page-flags.h =================================================================== --- linux-2.6.17-rc6-mm1.orig/include/linux/page-flags.h 2006-06-09 17:51:27.469840701 -0700 +++ linux-2.6.17-rc6-mm1/include/linux/page-flags.h 2006-06-09 17:51:29.246098065 -0700 @@ -154,6 +154,7 @@ static inline void count_vm_events(enum __get_cpu_var(vm_event_states).event[item] += delta; } +extern void all_vm_events(unsigned long *); #else /* Disable counters */ #define get_cpu_vm_events(e) 0L