sh: provide generic arch_debugfs_dir.

While sh previously had its own debugfs root, there now exists a
common arch_debugfs_dir prototype, so we switch everything over to
that.  Presumably once more architectures start making use of this
we'll be able to just kill off the stub kdebugfs wrapper.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
Paul Mundt 2010-09-24 04:04:26 +09:00
parent a234ca0faa
commit 3f224f4e05
8 changed files with 24 additions and 40 deletions

View File

@ -140,8 +140,6 @@ extern unsigned int instruction_size(unsigned int insn);
extern unsigned long cached_to_uncached; extern unsigned long cached_to_uncached;
extern unsigned long uncached_size; extern unsigned long uncached_size;
extern struct dentry *sh_debugfs_root;
void per_cpu_trap_init(void); void per_cpu_trap_init(void);
void default_idle(void); void default_idle(void);
void cpu_idle_wait(void); void cpu_idle_wait(void);

View File

@ -12,8 +12,8 @@ endif
CFLAGS_REMOVE_return_address.o = -pg CFLAGS_REMOVE_return_address.o = -pg
obj-y := clkdev.o debugtraps.o dma-nommu.o dumpstack.o \ obj-y := clkdev.o debugtraps.o dma-nommu.o dumpstack.o \
idle.o io.o irq.o \ idle.o io.o irq.o irq_$(BITS).o kdebugfs.o \
irq_$(BITS).o machvec.o nmi_debug.o process.o \ machvec.o nmi_debug.o process.o \
process_$(BITS).o ptrace.o ptrace_$(BITS).o \ process_$(BITS).o ptrace.o ptrace_$(BITS).o \
reboot.o return_address.o \ reboot.o return_address.o \
setup.o signal_$(BITS).o sys_sh.o sys_sh$(BITS).o \ setup.o signal_$(BITS).o sys_sh.o sys_sh$(BITS).o \

16
arch/sh/kernel/kdebugfs.c Normal file
View File

@ -0,0 +1,16 @@
#include <linux/module.h>
#include <linux/init.h>
#include <linux/debugfs.h>
struct dentry *arch_debugfs_dir;
EXPORT_SYMBOL(arch_debugfs_dir);
static int __init arch_kdebugfs_init(void)
{
arch_debugfs_dir = debugfs_create_dir("sh", NULL);
if (!arch_debugfs_dir)
return -ENOMEM;
return 0;
}
arch_initcall(arch_kdebugfs_init);

View File

@ -24,7 +24,6 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/smp.h> #include <linux/smp.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/debugfs.h>
#include <linux/crash_dump.h> #include <linux/crash_dump.h>
#include <linux/mmzone.h> #include <linux/mmzone.h>
#include <linux/clk.h> #include <linux/clk.h>
@ -458,17 +457,3 @@ const struct seq_operations cpuinfo_op = {
.show = show_cpuinfo, .show = show_cpuinfo,
}; };
#endif /* CONFIG_PROC_FS */ #endif /* CONFIG_PROC_FS */
struct dentry *sh_debugfs_root;
static int __init sh_debugfs_init(void)
{
sh_debugfs_root = debugfs_create_dir("sh", NULL);
if (!sh_debugfs_root)
return -ENOMEM;
if (IS_ERR(sh_debugfs_root))
return PTR_ERR(sh_debugfs_root);
return 0;
}
arch_initcall(sh_debugfs_init);

View File

@ -63,7 +63,7 @@ static int __init asids_debugfs_init(void)
{ {
struct dentry *asids_dentry; struct dentry *asids_dentry;
asids_dentry = debugfs_create_file("asids", S_IRUSR, sh_debugfs_root, asids_dentry = debugfs_create_file("asids", S_IRUSR, arch_debugfs_dir,
NULL, &asids_debugfs_fops); NULL, &asids_debugfs_fops);
if (!asids_dentry) if (!asids_dentry)
return -ENOMEM; return -ENOMEM;

View File

@ -126,25 +126,19 @@ static int __init cache_debugfs_init(void)
{ {
struct dentry *dcache_dentry, *icache_dentry; struct dentry *dcache_dentry, *icache_dentry;
dcache_dentry = debugfs_create_file("dcache", S_IRUSR, sh_debugfs_root, dcache_dentry = debugfs_create_file("dcache", S_IRUSR, arch_debugfs_dir,
(unsigned int *)CACHE_TYPE_DCACHE, (unsigned int *)CACHE_TYPE_DCACHE,
&cache_debugfs_fops); &cache_debugfs_fops);
if (!dcache_dentry) if (!dcache_dentry)
return -ENOMEM; return -ENOMEM;
if (IS_ERR(dcache_dentry))
return PTR_ERR(dcache_dentry);
icache_dentry = debugfs_create_file("icache", S_IRUSR, sh_debugfs_root, icache_dentry = debugfs_create_file("icache", S_IRUSR, arch_debugfs_dir,
(unsigned int *)CACHE_TYPE_ICACHE, (unsigned int *)CACHE_TYPE_ICACHE,
&cache_debugfs_fops); &cache_debugfs_fops);
if (!icache_dentry) { if (!icache_dentry) {
debugfs_remove(dcache_dentry); debugfs_remove(dcache_dentry);
return -ENOMEM; return -ENOMEM;
} }
if (IS_ERR(icache_dentry)) {
debugfs_remove(dcache_dentry);
return PTR_ERR(icache_dentry);
}
return 0; return 0;
} }

View File

@ -866,11 +866,9 @@ static int __init pmb_debugfs_init(void)
struct dentry *dentry; struct dentry *dentry;
dentry = debugfs_create_file("pmb", S_IFREG | S_IRUGO, dentry = debugfs_create_file("pmb", S_IFREG | S_IRUGO,
sh_debugfs_root, NULL, &pmb_debugfs_fops); arch_debugfs_dir, NULL, &pmb_debugfs_fops);
if (!dentry) if (!dentry)
return -ENOMEM; return -ENOMEM;
if (IS_ERR(dentry))
return PTR_ERR(dentry);
return 0; return 0;
} }

View File

@ -151,15 +151,13 @@ static int __init tlb_debugfs_init(void)
{ {
struct dentry *itlb, *utlb; struct dentry *itlb, *utlb;
itlb = debugfs_create_file("itlb", S_IRUSR, sh_debugfs_root, itlb = debugfs_create_file("itlb", S_IRUSR, arch_debugfs_dir,
(unsigned int *)TLB_TYPE_ITLB, (unsigned int *)TLB_TYPE_ITLB,
&tlb_debugfs_fops); &tlb_debugfs_fops);
if (unlikely(!itlb)) if (unlikely(!itlb))
return -ENOMEM; return -ENOMEM;
if (IS_ERR(itlb))
return PTR_ERR(itlb);
utlb = debugfs_create_file("utlb", S_IRUSR, sh_debugfs_root, utlb = debugfs_create_file("utlb", S_IRUSR, arch_debugfs_dir,
(unsigned int *)TLB_TYPE_UTLB, (unsigned int *)TLB_TYPE_UTLB,
&tlb_debugfs_fops); &tlb_debugfs_fops);
if (unlikely(!utlb)) { if (unlikely(!utlb)) {
@ -167,11 +165,6 @@ static int __init tlb_debugfs_init(void)
return -ENOMEM; return -ENOMEM;
} }
if (IS_ERR(utlb)) {
debugfs_remove(itlb);
return PTR_ERR(utlb);
}
return 0; return 0;
} }
module_init(tlb_debugfs_init); module_init(tlb_debugfs_init);