在mm/memblock.c 中会为memblock 在/sys/kernel/debug 下为memblock新建一个入口,通过这个入口可以看到bios 传给kernel的memory和在kernel中已经reserve 好的memory.
static int __init memblock_init_debugfs(void)
{
//在调用debugfs_create_dir 是如果第二个参数为null的话,表示是放在/sys/kernel/debug 下面
struct dentry *root = debugfs_create_dir("memblock", NULL);
if (!root)
return -ENXIO;
//从下面的三句话可以看出会在memblock下面新建两个文件,一个memory,一个是reserved,如果定义了CONFIG_HAVE_MEMBLOCK_PHYS_MAP的话,还会新建physmem。
debugfs_create_file("memory", S_IRUGO, root, &memblock.memory, &memblock_debug_fops);
debugfs_create_file("reserved", S_IRUGO, root, &memblock.reserved, &memblock_debug_fops);
#ifdef CONFIG_HAVE_MEMBLOCK_PHYS_MAP
debugfs_create_file("physmem", S_IRUGO, root, &memblock.physmem, &memblock_debug_fops);
#endif
return 0;
}
__initcall(memblock_init_debugfs);
可见在kernel早期会通过__initcall来调用
这里以memory为例,当处理的fops为memblock_debug_fops
static const struct file_operations memblock_debug_fops = {
.open = memblock_debug_open,
.read = seq_read,
.llseek = seq_lseek,
.release = single_release,
};
可以看到memory只能read没有write
static int memblock_debug_show(struct seq_file *m, void *private)
{
struct memblock_type *type = m->private;
struct memblock_region *reg;
int i;
phys_addr_t end;
//针对memory这个文件,这里的type是memblock.memory,可见会打印每个memblock的起始地址和结束地址
for (i = 0; i < type->cnt; i++) {
reg = &type->regions[i];
end = reg->base + reg->size - 1;
seq_printf(m, "%4d: ", i);
seq_printf(m, "%pa..%pa\n", ®->base, &end);
}
return 0;
}
static int memblock_debug_open(struct inode *inode, struct file *file)
{
return single_open(file, memblock_debug_show, inode->i_private);
}
static int __init memblock_init_debugfs(void)
{
//在调用debugfs_create_dir 是如果第二个参数为null的话,表示是放在/sys/kernel/debug 下面
struct dentry *root = debugfs_create_dir("memblock", NULL);
if (!root)
return -ENXIO;
//从下面的三句话可以看出会在memblock下面新建两个文件,一个memory,一个是reserved,如果定义了CONFIG_HAVE_MEMBLOCK_PHYS_MAP的话,还会新建physmem。
debugfs_create_file("memory", S_IRUGO, root, &memblock.memory, &memblock_debug_fops);
debugfs_create_file("reserved", S_IRUGO, root, &memblock.reserved, &memblock_debug_fops);
#ifdef CONFIG_HAVE_MEMBLOCK_PHYS_MAP
debugfs_create_file("physmem", S_IRUGO, root, &memblock.physmem, &memblock_debug_fops);
#endif
return 0;
}
__initcall(memblock_init_debugfs);
可见在kernel早期会通过__initcall来调用
这里以memory为例,当处理的fops为memblock_debug_fops
static const struct file_operations memblock_debug_fops = {
.open = memblock_debug_open,
.read = seq_read,
.llseek = seq_lseek,
.release = single_release,
};
可以看到memory只能read没有write
static int memblock_debug_show(struct seq_file *m, void *private)
{
struct memblock_type *type = m->private;
struct memblock_region *reg;
int i;
phys_addr_t end;
//针对memory这个文件,这里的type是memblock.memory,可见会打印每个memblock的起始地址和结束地址
for (i = 0; i < type->cnt; i++) {
reg = &type->regions[i];
end = reg->base + reg->size - 1;
seq_printf(m, "%4d: ", i);
seq_printf(m, "%pa..%pa\n", ®->base, &end);
}
return 0;
}
static int memblock_debug_open(struct inode *inode, struct file *file)
{
return single_open(file, memblock_debug_show, inode->i_private);
}
实际运行截图