From 956b46a1f2fdbe4ac8ae1510999055ee887209d8 Mon Sep 17 00:00:00 2001 From: Benjamin Herrenschmidt Date: Tue, 6 Jul 2010 15:39:19 -0700 Subject: [PATCH] --- yaml --- r: 212711 b: refs/heads/master c: 6d03b885f0926ab5b66e21307d505afcafa6dced h: refs/heads/master i: 212709: 906c4fa1aad950bc7e4df0f2023d3b3dc19f41eb 212707: ca9eddbfda58610134744fd57804a6887d9a98b4 212703: eb1338612d292c1151bf0be5021172ac711b5f2a v: v3 --- [refs] | 2 +- trunk/mm/memblock.c | 51 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 52 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index d61e913b826c..bfaa95a0ba0d 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 918fe8d60331f679519ab8239a7232272126da9e +refs/heads/master: 6d03b885f0926ab5b66e21307d505afcafa6dced diff --git a/trunk/mm/memblock.c b/trunk/mm/memblock.c index 9de5fcdf8e28..cc15be29fd0a 100644 --- a/trunk/mm/memblock.c +++ b/trunk/mm/memblock.c @@ -16,6 +16,8 @@ #include #include #include +#include +#include #include struct memblock memblock; @@ -740,3 +742,52 @@ static int __init early_memblock(char *p) } early_param("memblock", early_memblock); +#ifdef CONFIG_DEBUG_FS + +static int memblock_debug_show(struct seq_file *m, void *private) +{ + struct memblock_type *type = m->private; + struct memblock_region *reg; + int i; + + for (i = 0; i < type->cnt; i++) { + reg = &type->regions[i]; + seq_printf(m, "%4d: ", i); + if (sizeof(phys_addr_t) == 4) + seq_printf(m, "0x%08lx..0x%08lx\n", + (unsigned long)reg->base, + (unsigned long)(reg->base + reg->size - 1)); + else + seq_printf(m, "0x%016llx..0x%016llx\n", + (unsigned long long)reg->base, + (unsigned long long)(reg->base + reg->size - 1)); + + } + return 0; +} + +static int memblock_debug_open(struct inode *inode, struct file *file) +{ + return single_open(file, memblock_debug_show, inode->i_private); +} + +static const struct file_operations memblock_debug_fops = { + .open = memblock_debug_open, + .read = seq_read, + .llseek = seq_lseek, + .release = single_release, +}; + +static int __init memblock_init_debugfs(void) +{ + struct dentry *root = debugfs_create_dir("memblock", NULL); + if (!root) + return -ENXIO; + debugfs_create_file("memory", S_IRUGO, root, &memblock.memory, &memblock_debug_fops); + debugfs_create_file("reserved", S_IRUGO, root, &memblock.reserved, &memblock_debug_fops); + + return 0; +} +__initcall(memblock_init_debugfs); + +#endif /* CONFIG_DEBUG_FS */