|
@@ -327,6 +327,7 @@ struct mem_size_stats {
|
|
unsigned long private_clean;
|
|
unsigned long private_clean;
|
|
unsigned long private_dirty;
|
|
unsigned long private_dirty;
|
|
unsigned long referenced;
|
|
unsigned long referenced;
|
|
|
|
+ unsigned long anonymous;
|
|
unsigned long swap;
|
|
unsigned long swap;
|
|
u64 pss;
|
|
u64 pss;
|
|
};
|
|
};
|
|
@@ -357,6 +358,9 @@ static int smaps_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end,
|
|
if (!page)
|
|
if (!page)
|
|
continue;
|
|
continue;
|
|
|
|
|
|
|
|
+ if (PageAnon(page))
|
|
|
|
+ mss->anonymous += PAGE_SIZE;
|
|
|
|
+
|
|
mss->resident += PAGE_SIZE;
|
|
mss->resident += PAGE_SIZE;
|
|
/* Accumulate the size in pages that have been accessed. */
|
|
/* Accumulate the size in pages that have been accessed. */
|
|
if (pte_young(ptent) || PageReferenced(page))
|
|
if (pte_young(ptent) || PageReferenced(page))
|
|
@@ -410,6 +414,7 @@ static int show_smap(struct seq_file *m, void *v)
|
|
"Private_Clean: %8lu kB\n"
|
|
"Private_Clean: %8lu kB\n"
|
|
"Private_Dirty: %8lu kB\n"
|
|
"Private_Dirty: %8lu kB\n"
|
|
"Referenced: %8lu kB\n"
|
|
"Referenced: %8lu kB\n"
|
|
|
|
+ "Anonymous: %8lu kB\n"
|
|
"Swap: %8lu kB\n"
|
|
"Swap: %8lu kB\n"
|
|
"KernelPageSize: %8lu kB\n"
|
|
"KernelPageSize: %8lu kB\n"
|
|
"MMUPageSize: %8lu kB\n",
|
|
"MMUPageSize: %8lu kB\n",
|
|
@@ -421,6 +426,7 @@ static int show_smap(struct seq_file *m, void *v)
|
|
mss.private_clean >> 10,
|
|
mss.private_clean >> 10,
|
|
mss.private_dirty >> 10,
|
|
mss.private_dirty >> 10,
|
|
mss.referenced >> 10,
|
|
mss.referenced >> 10,
|
|
|
|
+ mss.anonymous >> 10,
|
|
mss.swap >> 10,
|
|
mss.swap >> 10,
|
|
vma_kernel_pagesize(vma) >> 10,
|
|
vma_kernel_pagesize(vma) >> 10,
|
|
vma_mmu_pagesize(vma) >> 10);
|
|
vma_mmu_pagesize(vma) >> 10);
|