mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 21:35:07 +00:00
mm: per-node vmstat: show proper vmstats
commit 2ac390370a ("writeback: add /sys/devices/system/node/<node>/vmstat") added vmstat entry. But strangely it only show nr_written and nr_dirtied. # cat /sys/devices/system/node/node20/vmstat nr_written 0 nr_dirtied 0 Of course, It's not adequate. With this patch, the vmstat show all vm stastics as /proc/vmstat. # cat /sys/devices/system/node/node0/vmstat nr_free_pages 899224 nr_inactive_anon 201 nr_active_anon 17380 nr_inactive_file 31572 nr_active_file 28277 nr_unevictable 0 nr_mlock 0 nr_anon_pages 17321 nr_mapped 8640 nr_file_pages 60107 nr_dirty 33 nr_writeback 0 nr_slab_reclaimable 6850 nr_slab_unreclaimable 7604 nr_page_table_pages 3105 nr_kernel_stack 175 nr_unstable 0 nr_bounce 0 nr_vmscan_write 0 nr_writeback_temp 0 nr_isolated_anon 0 nr_isolated_file 0 nr_shmem 260 nr_dirtied 1050 nr_written 938 numa_hit 962872 numa_miss 0 numa_foreign 0 numa_interleave 8617 numa_local 962872 numa_other 0 nr_anon_transparent_hugepages 0 [akpm@linux-foundation.org: no externs in .c files] Signed-off-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Cc: Michael Rubin <mrubin@google.com> Cc: Wu Fengguang <fengguang.wu@intel.com> Acked-by: David Rientjes <rientjes@google.com> Cc: Randy Dunlap <rdunlap@xenotime.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
bb005a59e0
commit
fa25c503df
@ -7,6 +7,7 @@
|
|||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/memory.h>
|
#include <linux/memory.h>
|
||||||
|
#include <linux/vmstat.h>
|
||||||
#include <linux/node.h>
|
#include <linux/node.h>
|
||||||
#include <linux/hugetlb.h>
|
#include <linux/hugetlb.h>
|
||||||
#include <linux/compaction.h>
|
#include <linux/compaction.h>
|
||||||
@ -179,11 +180,14 @@ static ssize_t node_read_vmstat(struct sys_device *dev,
|
|||||||
struct sysdev_attribute *attr, char *buf)
|
struct sysdev_attribute *attr, char *buf)
|
||||||
{
|
{
|
||||||
int nid = dev->id;
|
int nid = dev->id;
|
||||||
return sprintf(buf,
|
int i;
|
||||||
"nr_written %lu\n"
|
int n = 0;
|
||||||
"nr_dirtied %lu\n",
|
|
||||||
node_page_state(nid, NR_WRITTEN),
|
for (i = 0; i < NR_VM_ZONE_STAT_ITEMS; i++)
|
||||||
node_page_state(nid, NR_DIRTIED));
|
n += sprintf(buf+n, "%s %lu\n", vmstat_text[i],
|
||||||
|
node_page_state(nid, i));
|
||||||
|
|
||||||
|
return n;
|
||||||
}
|
}
|
||||||
static SYSDEV_ATTR(vmstat, S_IRUGO, node_read_vmstat, NULL);
|
static SYSDEV_ATTR(vmstat, S_IRUGO, node_read_vmstat, NULL);
|
||||||
|
|
||||||
|
@ -313,6 +313,8 @@ static inline void __dec_zone_page_state(struct page *page,
|
|||||||
#define set_pgdat_percpu_threshold(pgdat, callback) { }
|
#define set_pgdat_percpu_threshold(pgdat, callback) { }
|
||||||
|
|
||||||
static inline void refresh_cpu_vm_stats(int cpu) { }
|
static inline void refresh_cpu_vm_stats(int cpu) { }
|
||||||
#endif
|
#endif /* CONFIG_SMP */
|
||||||
|
|
||||||
|
extern const char * const vmstat_text[];
|
||||||
|
|
||||||
#endif /* _LINUX_VMSTAT_H */
|
#endif /* _LINUX_VMSTAT_H */
|
||||||
|
261
mm/vmstat.c
261
mm/vmstat.c
@ -659,6 +659,138 @@ static void walk_zones_in_node(struct seq_file *m, pg_data_t *pgdat,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PROC_FS) || defined(CONFIG_SYSFS)
|
||||||
|
#ifdef CONFIG_ZONE_DMA
|
||||||
|
#define TEXT_FOR_DMA(xx) xx "_dma",
|
||||||
|
#else
|
||||||
|
#define TEXT_FOR_DMA(xx)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_ZONE_DMA32
|
||||||
|
#define TEXT_FOR_DMA32(xx) xx "_dma32",
|
||||||
|
#else
|
||||||
|
#define TEXT_FOR_DMA32(xx)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_HIGHMEM
|
||||||
|
#define TEXT_FOR_HIGHMEM(xx) xx "_high",
|
||||||
|
#else
|
||||||
|
#define TEXT_FOR_HIGHMEM(xx)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define TEXTS_FOR_ZONES(xx) TEXT_FOR_DMA(xx) TEXT_FOR_DMA32(xx) xx "_normal", \
|
||||||
|
TEXT_FOR_HIGHMEM(xx) xx "_movable",
|
||||||
|
|
||||||
|
const char * const vmstat_text[] = {
|
||||||
|
/* Zoned VM counters */
|
||||||
|
"nr_free_pages",
|
||||||
|
"nr_inactive_anon",
|
||||||
|
"nr_active_anon",
|
||||||
|
"nr_inactive_file",
|
||||||
|
"nr_active_file",
|
||||||
|
"nr_unevictable",
|
||||||
|
"nr_mlock",
|
||||||
|
"nr_anon_pages",
|
||||||
|
"nr_mapped",
|
||||||
|
"nr_file_pages",
|
||||||
|
"nr_dirty",
|
||||||
|
"nr_writeback",
|
||||||
|
"nr_slab_reclaimable",
|
||||||
|
"nr_slab_unreclaimable",
|
||||||
|
"nr_page_table_pages",
|
||||||
|
"nr_kernel_stack",
|
||||||
|
"nr_unstable",
|
||||||
|
"nr_bounce",
|
||||||
|
"nr_vmscan_write",
|
||||||
|
"nr_writeback_temp",
|
||||||
|
"nr_isolated_anon",
|
||||||
|
"nr_isolated_file",
|
||||||
|
"nr_shmem",
|
||||||
|
"nr_dirtied",
|
||||||
|
"nr_written",
|
||||||
|
|
||||||
|
#ifdef CONFIG_NUMA
|
||||||
|
"numa_hit",
|
||||||
|
"numa_miss",
|
||||||
|
"numa_foreign",
|
||||||
|
"numa_interleave",
|
||||||
|
"numa_local",
|
||||||
|
"numa_other",
|
||||||
|
#endif
|
||||||
|
"nr_anon_transparent_hugepages",
|
||||||
|
"nr_dirty_threshold",
|
||||||
|
"nr_dirty_background_threshold",
|
||||||
|
|
||||||
|
#ifdef CONFIG_VM_EVENT_COUNTERS
|
||||||
|
"pgpgin",
|
||||||
|
"pgpgout",
|
||||||
|
"pswpin",
|
||||||
|
"pswpout",
|
||||||
|
|
||||||
|
TEXTS_FOR_ZONES("pgalloc")
|
||||||
|
|
||||||
|
"pgfree",
|
||||||
|
"pgactivate",
|
||||||
|
"pgdeactivate",
|
||||||
|
|
||||||
|
"pgfault",
|
||||||
|
"pgmajfault",
|
||||||
|
|
||||||
|
TEXTS_FOR_ZONES("pgrefill")
|
||||||
|
TEXTS_FOR_ZONES("pgsteal")
|
||||||
|
TEXTS_FOR_ZONES("pgscan_kswapd")
|
||||||
|
TEXTS_FOR_ZONES("pgscan_direct")
|
||||||
|
|
||||||
|
#ifdef CONFIG_NUMA
|
||||||
|
"zone_reclaim_failed",
|
||||||
|
#endif
|
||||||
|
"pginodesteal",
|
||||||
|
"slabs_scanned",
|
||||||
|
"kswapd_steal",
|
||||||
|
"kswapd_inodesteal",
|
||||||
|
"kswapd_low_wmark_hit_quickly",
|
||||||
|
"kswapd_high_wmark_hit_quickly",
|
||||||
|
"kswapd_skip_congestion_wait",
|
||||||
|
"pageoutrun",
|
||||||
|
"allocstall",
|
||||||
|
|
||||||
|
"pgrotated",
|
||||||
|
|
||||||
|
#ifdef CONFIG_COMPACTION
|
||||||
|
"compact_blocks_moved",
|
||||||
|
"compact_pages_moved",
|
||||||
|
"compact_pagemigrate_failed",
|
||||||
|
"compact_stall",
|
||||||
|
"compact_fail",
|
||||||
|
"compact_success",
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_HUGETLB_PAGE
|
||||||
|
"htlb_buddy_alloc_success",
|
||||||
|
"htlb_buddy_alloc_fail",
|
||||||
|
#endif
|
||||||
|
"unevictable_pgs_culled",
|
||||||
|
"unevictable_pgs_scanned",
|
||||||
|
"unevictable_pgs_rescued",
|
||||||
|
"unevictable_pgs_mlocked",
|
||||||
|
"unevictable_pgs_munlocked",
|
||||||
|
"unevictable_pgs_cleared",
|
||||||
|
"unevictable_pgs_stranded",
|
||||||
|
"unevictable_pgs_mlockfreed",
|
||||||
|
|
||||||
|
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
||||||
|
"thp_fault_alloc",
|
||||||
|
"thp_fault_fallback",
|
||||||
|
"thp_collapse_alloc",
|
||||||
|
"thp_collapse_alloc_failed",
|
||||||
|
"thp_split",
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* CONFIG_VM_EVENTS_COUNTERS */
|
||||||
|
};
|
||||||
|
#endif /* CONFIG_PROC_FS || CONFIG_SYSFS */
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_PROC_FS
|
#ifdef CONFIG_PROC_FS
|
||||||
static void frag_show_print(struct seq_file *m, pg_data_t *pgdat,
|
static void frag_show_print(struct seq_file *m, pg_data_t *pgdat,
|
||||||
struct zone *zone)
|
struct zone *zone)
|
||||||
@ -831,135 +963,6 @@ static const struct file_operations pagetypeinfo_file_ops = {
|
|||||||
.release = seq_release,
|
.release = seq_release,
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_ZONE_DMA
|
|
||||||
#define TEXT_FOR_DMA(xx) xx "_dma",
|
|
||||||
#else
|
|
||||||
#define TEXT_FOR_DMA(xx)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_ZONE_DMA32
|
|
||||||
#define TEXT_FOR_DMA32(xx) xx "_dma32",
|
|
||||||
#else
|
|
||||||
#define TEXT_FOR_DMA32(xx)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_HIGHMEM
|
|
||||||
#define TEXT_FOR_HIGHMEM(xx) xx "_high",
|
|
||||||
#else
|
|
||||||
#define TEXT_FOR_HIGHMEM(xx)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define TEXTS_FOR_ZONES(xx) TEXT_FOR_DMA(xx) TEXT_FOR_DMA32(xx) xx "_normal", \
|
|
||||||
TEXT_FOR_HIGHMEM(xx) xx "_movable",
|
|
||||||
|
|
||||||
static const char * const vmstat_text[] = {
|
|
||||||
/* Zoned VM counters */
|
|
||||||
"nr_free_pages",
|
|
||||||
"nr_inactive_anon",
|
|
||||||
"nr_active_anon",
|
|
||||||
"nr_inactive_file",
|
|
||||||
"nr_active_file",
|
|
||||||
"nr_unevictable",
|
|
||||||
"nr_mlock",
|
|
||||||
"nr_anon_pages",
|
|
||||||
"nr_mapped",
|
|
||||||
"nr_file_pages",
|
|
||||||
"nr_dirty",
|
|
||||||
"nr_writeback",
|
|
||||||
"nr_slab_reclaimable",
|
|
||||||
"nr_slab_unreclaimable",
|
|
||||||
"nr_page_table_pages",
|
|
||||||
"nr_kernel_stack",
|
|
||||||
"nr_unstable",
|
|
||||||
"nr_bounce",
|
|
||||||
"nr_vmscan_write",
|
|
||||||
"nr_writeback_temp",
|
|
||||||
"nr_isolated_anon",
|
|
||||||
"nr_isolated_file",
|
|
||||||
"nr_shmem",
|
|
||||||
"nr_dirtied",
|
|
||||||
"nr_written",
|
|
||||||
|
|
||||||
#ifdef CONFIG_NUMA
|
|
||||||
"numa_hit",
|
|
||||||
"numa_miss",
|
|
||||||
"numa_foreign",
|
|
||||||
"numa_interleave",
|
|
||||||
"numa_local",
|
|
||||||
"numa_other",
|
|
||||||
#endif
|
|
||||||
"nr_anon_transparent_hugepages",
|
|
||||||
"nr_dirty_threshold",
|
|
||||||
"nr_dirty_background_threshold",
|
|
||||||
|
|
||||||
#ifdef CONFIG_VM_EVENT_COUNTERS
|
|
||||||
"pgpgin",
|
|
||||||
"pgpgout",
|
|
||||||
"pswpin",
|
|
||||||
"pswpout",
|
|
||||||
|
|
||||||
TEXTS_FOR_ZONES("pgalloc")
|
|
||||||
|
|
||||||
"pgfree",
|
|
||||||
"pgactivate",
|
|
||||||
"pgdeactivate",
|
|
||||||
|
|
||||||
"pgfault",
|
|
||||||
"pgmajfault",
|
|
||||||
|
|
||||||
TEXTS_FOR_ZONES("pgrefill")
|
|
||||||
TEXTS_FOR_ZONES("pgsteal")
|
|
||||||
TEXTS_FOR_ZONES("pgscan_kswapd")
|
|
||||||
TEXTS_FOR_ZONES("pgscan_direct")
|
|
||||||
|
|
||||||
#ifdef CONFIG_NUMA
|
|
||||||
"zone_reclaim_failed",
|
|
||||||
#endif
|
|
||||||
"pginodesteal",
|
|
||||||
"slabs_scanned",
|
|
||||||
"kswapd_steal",
|
|
||||||
"kswapd_inodesteal",
|
|
||||||
"kswapd_low_wmark_hit_quickly",
|
|
||||||
"kswapd_high_wmark_hit_quickly",
|
|
||||||
"kswapd_skip_congestion_wait",
|
|
||||||
"pageoutrun",
|
|
||||||
"allocstall",
|
|
||||||
|
|
||||||
"pgrotated",
|
|
||||||
|
|
||||||
#ifdef CONFIG_COMPACTION
|
|
||||||
"compact_blocks_moved",
|
|
||||||
"compact_pages_moved",
|
|
||||||
"compact_pagemigrate_failed",
|
|
||||||
"compact_stall",
|
|
||||||
"compact_fail",
|
|
||||||
"compact_success",
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_HUGETLB_PAGE
|
|
||||||
"htlb_buddy_alloc_success",
|
|
||||||
"htlb_buddy_alloc_fail",
|
|
||||||
#endif
|
|
||||||
"unevictable_pgs_culled",
|
|
||||||
"unevictable_pgs_scanned",
|
|
||||||
"unevictable_pgs_rescued",
|
|
||||||
"unevictable_pgs_mlocked",
|
|
||||||
"unevictable_pgs_munlocked",
|
|
||||||
"unevictable_pgs_cleared",
|
|
||||||
"unevictable_pgs_stranded",
|
|
||||||
"unevictable_pgs_mlockfreed",
|
|
||||||
|
|
||||||
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
|
||||||
"thp_fault_alloc",
|
|
||||||
"thp_fault_fallback",
|
|
||||||
"thp_collapse_alloc",
|
|
||||||
"thp_collapse_alloc_failed",
|
|
||||||
"thp_split",
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* CONFIG_VM_EVENTS_COUNTERS */
|
|
||||||
};
|
|
||||||
|
|
||||||
static void zoneinfo_show_print(struct seq_file *m, pg_data_t *pgdat,
|
static void zoneinfo_show_print(struct seq_file *m, pg_data_t *pgdat,
|
||||||
struct zone *zone)
|
struct zone *zone)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user