/* * Generic show_mem() implementation * * Copyright (C) 2008 Johannes Weiner * All code subject to the GPL version 2. */ #include #include #include void show_mem(unsigned int filter) { pg_data_t *pgdat; unsigned long total = 0, reserved = 0, shared = 0, nonshared = 0, highmem = 0; printk("Mem-Info:\n"); show_free_areas(filter); if (filter & SHOW_MEM_FILTER_PAGE_COUNT) return; for_each_online_pgdat(pgdat) { #if !defined(CONFIG_CMA) || !defined(CONFIG_MTK_SVP) // SVP 10 unsigned long i, flags; pgdat_resize_lock(pgdat, &flags); for (i = 0; i < pgdat->node_spanned_pages; i++) { struct page *page; unsigned long pfn = pgdat->node_start_pfn + i; if (unlikely(!(i % MAX_ORDER_NR_PAGES))) touch_nmi_watchdog(); if (!pfn_valid(pfn)) continue; page = pfn_to_page(pfn); if (PageHighMem(page)) highmem++; if (PageReserved(page)) reserved++; else if (page_count(page) == 1) nonshared++; else if (page_count(page) > 1) shared += page_count(page) - 1; total++; } pgdat_resize_unlock(pgdat, &flags); #else unsigned long flags; int zoneid; pgdat_resize_lock(pgdat, &flags); for (zoneid = 0; zoneid < MAX_NR_ZONES; zoneid++) { struct zone *zone = &pgdat->node_zones[zoneid]; if (!populated_zone(zone)) continue; total += zone->present_pages; reserved += zone->present_pages - zone->managed_pages; // if (is_highmem_idx(zoneid)) if (is_highmem(zone)) highmem += zone->present_pages; } pgdat_resize_unlock(pgdat, &flags); #endif } printk("%lu pages RAM\n", total); #ifdef CONFIG_HIGHMEM printk("%lu pages HighMem\n", highmem); #endif printk("%lu pages reserved\n", reserved); printk("%lu pages shared\n", shared); printk("%lu pages non-shared\n", nonshared); #ifdef CONFIG_QUICKLIST printk("%lu pages in pagetable cache\n", quicklist_total_size()); #endif }