blob: 1c26c14ffbb9bdfe8d442cb381e7c7d1fd242305 [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001// SPDX-License-Identifier: GPL-2.0-only
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * Generic show_mem() implementation
4 *
5 * Copyright (C) 2008 Johannes Weiner <hannes@saeurebad.de>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00006 */
7
8#include <linux/mm.h>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00009#include <linux/cma.h>
10
11void show_mem(unsigned int filter, nodemask_t *nodemask)
12{
13 pg_data_t *pgdat;
14 unsigned long total = 0, reserved = 0, highmem = 0;
15
16 printk("Mem-Info:\n");
17 show_free_areas(filter, nodemask);
18
19 for_each_online_pgdat(pgdat) {
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000020 int zoneid;
21
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000022 for (zoneid = 0; zoneid < MAX_NR_ZONES; zoneid++) {
23 struct zone *zone = &pgdat->node_zones[zoneid];
24 if (!populated_zone(zone))
25 continue;
26
27 total += zone->present_pages;
David Brazdil0f672f62019-12-10 10:32:29 +000028 reserved += zone->present_pages - zone_managed_pages(zone);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000029
30 if (is_highmem_idx(zoneid))
31 highmem += zone->present_pages;
32 }
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000033 }
34
35 printk("%lu pages RAM\n", total);
36 printk("%lu pages HighMem/MovableOnly\n", highmem);
37 printk("%lu pages reserved\n", reserved);
38#ifdef CONFIG_CMA
39 printk("%lu pages cma reserved\n", totalcma_pages);
40#endif
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000041#ifdef CONFIG_MEMORY_FAILURE
42 printk("%lu pages hwpoisoned\n", atomic_long_read(&num_poisoned_pages));
43#endif
44}