2019-06-04 15:11:33 +07:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2013-05-21 20:50:31 +07:00
|
|
|
/*
|
|
|
|
*
|
2016-05-05 14:57:56 +07:00
|
|
|
* Copyright (C) 2013 John Crispin <john@phrozen.org>
|
2013-05-21 20:50:31 +07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/debugfs.h>
|
|
|
|
#include <linux/seq_file.h>
|
|
|
|
|
|
|
|
#define BOOTROM_OFFSET 0x10118000
|
|
|
|
#define BOOTROM_SIZE 0x8000
|
|
|
|
|
|
|
|
static void __iomem *membase = (void __iomem *) KSEG1ADDR(BOOTROM_OFFSET);
|
|
|
|
|
|
|
|
static int bootrom_show(struct seq_file *s, void *unused)
|
|
|
|
{
|
|
|
|
seq_write(s, membase, BOOTROM_SIZE);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int bootrom_open(struct inode *inode, struct file *file)
|
|
|
|
{
|
|
|
|
return single_open(file, bootrom_show, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
static const struct file_operations bootrom_file_ops = {
|
|
|
|
.open = bootrom_open,
|
|
|
|
.read = seq_read,
|
|
|
|
.llseek = seq_lseek,
|
|
|
|
.release = single_release,
|
|
|
|
};
|
|
|
|
|
|
|
|
static int bootrom_setup(void)
|
|
|
|
{
|
2019-01-22 21:57:39 +07:00
|
|
|
debugfs_create_file("bootrom", 0444, NULL, NULL, &bootrom_file_ops);
|
2013-05-21 20:50:31 +07:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
postcore_initcall(bootrom_setup);
|