This patch is add information of easy reclaim zone to /proc/meminfo.
This is new patch at take 4.
Signed-off-by: Yasunori Goto <[email protected]>
--
Index: zone_reclaim/fs/proc/proc_misc.c
===================================================================
--- zone_reclaim.orig/fs/proc/proc_misc.c 2005-12-15 19:48:29.000000000 +0900
+++ zone_reclaim/fs/proc/proc_misc.c 2005-12-15 20:43:27.000000000 +0900
@@ -126,6 +126,7 @@ static int meminfo_read_proc(char *page,
unsigned long free;
unsigned long committed;
unsigned long allowed;
+ unsigned long totalhigh, freehigh;
struct vmalloc_info vmi;
long cached;
@@ -147,7 +148,13 @@ static int meminfo_read_proc(char *page,
cached = 0;
get_vmalloc_info(&vmi);
-
+ if (i.totalhigh) {
+ totalhigh = i.totalhigh - i.total_easyreclaim;
+ freehigh = i.freehigh - i.free_easyreclaim;
+ } else {
+ totalhigh = 0;
+ freehigh = 0;
+ }
/*
* Tagged format, for easy grepping and expansion.
*/
@@ -161,6 +168,8 @@ static int meminfo_read_proc(char *page,
"Inactive: %8lu kB\n"
"HighTotal: %8lu kB\n"
"HighFree: %8lu kB\n"
+ "ReclaimTotal: %8lu kB\n"
+ "ReclaimFree: %8lu kB\n"
"LowTotal: %8lu kB\n"
"LowFree: %8lu kB\n"
"SwapTotal: %8lu kB\n"
@@ -182,8 +191,10 @@ static int meminfo_read_proc(char *page,
K(total_swapcache_pages),
K(active),
K(inactive),
- K(i.totalhigh),
- K(i.freehigh),
+ K(totalhigh),
+ K(freehigh),
+ K(i.total_easyreclaim),
+ K(i.free_easyreclaim),
K(i.totalram-i.totalhigh),
K(i.freeram-i.freehigh),
K(i.totalswap),
Index: zone_reclaim/include/linux/kernel.h
===================================================================
--- zone_reclaim.orig/include/linux/kernel.h 2005-12-15 19:48:30.000000000 +0900
+++ zone_reclaim/include/linux/kernel.h 2005-12-15 20:43:27.000000000 +0900
@@ -303,6 +303,8 @@ struct sysinfo {
unsigned short pad; /* explicit padding for m68k */
unsigned long totalhigh; /* Total high memory size */
unsigned long freehigh; /* Available high memory size */
+ unsigned long total_easyreclaim;/* Total easy reclaim size */
+ unsigned long free_easyreclaim; /* Available easy reclaim size */
unsigned int mem_unit; /* Memory unit size in bytes */
char _f[20-2*sizeof(long)-sizeof(int)]; /* Padding: libc5 uses this.. */
};
Index: zone_reclaim/mm/page_alloc.c
===================================================================
--- zone_reclaim.orig/mm/page_alloc.c 2005-12-15 20:11:43.000000000 +0900
+++ zone_reclaim/mm/page_alloc.c 2005-12-16 11:19:50.000000000 +0900
@@ -1275,17 +1275,45 @@ unsigned int nr_free_pagecache_pages(voi
}
#ifdef CONFIG_HIGHMEM
-unsigned int nr_free_highpages (void)
+unsigned int nr_total_highpages (void)
{
pg_data_t *pgdat;
unsigned int pages = 0;
+ for_each_pgdat(pgdat) {
+ pages += pgdat->node_zones[ZONE_HIGHMEM].present_pages;
+ }
+ return pages;
+}
- for_each_pgdat(pgdat)
+unsigned int nr_free_highpages (void)
+{
+ pg_data_t *pgdat;
+ unsigned int pages = 0;
+ for_each_pgdat(pgdat) {
pages += pgdat->node_zones[ZONE_HIGHMEM].free_pages;
-
+ }
return pages;
}
#endif
+unsigned int nr_total_easyreclaim (void)
+{
+ pg_data_t *pgdat;
+ unsigned int pages = 0;
+ for_each_pgdat(pgdat) {
+ pages += pgdat->node_zones[ZONE_EASY_RECLAIM].present_pages;
+ }
+ return pages;
+}
+
+unsigned int nr_free_easyreclaim (void)
+{
+ pg_data_t *pgdat;
+ unsigned int pages = 0;
+ for_each_pgdat(pgdat) {
+ pages += pgdat->node_zones[ZONE_EASY_RECLAIM].free_pages;
+ }
+ return pages;
+}
#ifdef CONFIG_NUMA
static void show_node(struct zone *zone)
@@ -1436,12 +1464,15 @@ void si_meminfo(struct sysinfo *val)
val->freeram = nr_free_pages();
val->bufferram = nr_blockdev_pages();
#ifdef CONFIG_HIGHMEM
- val->totalhigh = totalhigh_pages;
- val->freehigh = nr_free_highpages();
+ /* if highmem!=0, totalhigh includes easy reclaim pages. */
+ val->totalhigh = nr_total_highpages() + nr_total_easyreclaim();
+ val->freehigh = nr_free_highpages() + nr_free_easyreclaim();
#else
val->totalhigh = 0;
val->freehigh = 0;
#endif
+ val->total_easyreclaim = nr_total_easyreclaim();
+ val->free_easyreclaim = nr_free_easyreclaim();
val->mem_unit = PAGE_SIZE;
}
--
Yasunori Goto
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]