aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
authorKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>2011-09-23 16:32:47 -0400
committerKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>2011-09-23 22:22:32 -0400
commita867db10e89e12a3d97dedafdd411aa1527a6540 (patch)
tree0db5e4335a92447d47b0924c936993e187323de0 /arch/x86
parent10fe570fc16721d78afdba9689720094527c1ba3 (diff)
xen/p2m: Make debug/xen/mmu/p2m visible again.
We dropped a lot of the MMU debugfs in favour of using tracing API - but there is one which just provides mostly static information that was made invisible by this change. Bring it back. Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/include/asm/xen/page.h3
-rw-r--r--arch/x86/xen/mmu.c14
-rw-r--r--arch/x86/xen/p2m.c35
3 files changed, 32 insertions, 20 deletions
diff --git a/arch/x86/include/asm/xen/page.h b/arch/x86/include/asm/xen/page.h
index 64a619d47d34..bc12c12299c3 100644
--- a/arch/x86/include/asm/xen/page.h
+++ b/arch/x86/include/asm/xen/page.h
@@ -53,9 +53,6 @@ extern int m2p_remove_override(struct page *page, bool clear_pte);
53extern struct page *m2p_find_override(unsigned long mfn); 53extern struct page *m2p_find_override(unsigned long mfn);
54extern unsigned long m2p_find_override_pfn(unsigned long mfn, unsigned long pfn); 54extern unsigned long m2p_find_override_pfn(unsigned long mfn, unsigned long pfn);
55 55
56#ifdef CONFIG_XEN_DEBUG_FS
57extern int p2m_dump_show(struct seq_file *m, void *v);
58#endif
59static inline unsigned long pfn_to_mfn(unsigned long pfn) 56static inline unsigned long pfn_to_mfn(unsigned long pfn)
60{ 57{
61 unsigned long mfn; 58 unsigned long mfn;
diff --git a/arch/x86/xen/mmu.c b/arch/x86/xen/mmu.c
index 3c9aecd09ed1..4df0444b2cee 100644
--- a/arch/x86/xen/mmu.c
+++ b/arch/x86/xen/mmu.c
@@ -2362,17 +2362,3 @@ out:
2362 return err; 2362 return err;
2363} 2363}
2364EXPORT_SYMBOL_GPL(xen_remap_domain_mfn_range); 2364EXPORT_SYMBOL_GPL(xen_remap_domain_mfn_range);
2365
2366#ifdef CONFIG_XEN_DEBUG_FS
2367static int p2m_dump_open(struct inode *inode, struct file *filp)
2368{
2369 return single_open(filp, p2m_dump_show, NULL);
2370}
2371
2372static const struct file_operations p2m_dump_fops = {
2373 .open = p2m_dump_open,
2374 .read = seq_read,
2375 .llseek = seq_lseek,
2376 .release = single_release,
2377};
2378#endif /* CONFIG_XEN_DEBUG_FS */
diff --git a/arch/x86/xen/p2m.c b/arch/x86/xen/p2m.c
index 58efeb9d5440..cc2f8dcf8dda 100644
--- a/arch/x86/xen/p2m.c
+++ b/arch/x86/xen/p2m.c
@@ -782,8 +782,9 @@ unsigned long m2p_find_override_pfn(unsigned long mfn, unsigned long pfn)
782EXPORT_SYMBOL_GPL(m2p_find_override_pfn); 782EXPORT_SYMBOL_GPL(m2p_find_override_pfn);
783 783
784#ifdef CONFIG_XEN_DEBUG_FS 784#ifdef CONFIG_XEN_DEBUG_FS
785 785#include <linux/debugfs.h>
786int p2m_dump_show(struct seq_file *m, void *v) 786#include "debugfs.h"
787static int p2m_dump_show(struct seq_file *m, void *v)
787{ 788{
788 static const char * const level_name[] = { "top", "middle", 789 static const char * const level_name[] = { "top", "middle",
789 "entry", "abnormal" }; 790 "entry", "abnormal" };
@@ -856,4 +857,32 @@ int p2m_dump_show(struct seq_file *m, void *v)
856#undef TYPE_PFN 857#undef TYPE_PFN
857#undef TYPE_UNKNOWN 858#undef TYPE_UNKNOWN
858} 859}
859#endif 860
861static int p2m_dump_open(struct inode *inode, struct file *filp)
862{
863 return single_open(filp, p2m_dump_show, NULL);
864}
865
866static const struct file_operations p2m_dump_fops = {
867 .open = p2m_dump_open,
868 .read = seq_read,
869 .llseek = seq_lseek,
870 .release = single_release,
871};
872
873static struct dentry *d_mmu_debug;
874
875static int __init xen_p2m_debugfs(void)
876{
877 struct dentry *d_xen = xen_init_debugfs();
878
879 if (d_xen == NULL)
880 return -ENOMEM;
881
882 d_mmu_debug = debugfs_create_dir("mmu", d_xen);
883
884 debugfs_create_file("p2m", 0600, d_mmu_debug, NULL, &p2m_dump_fops);
885 return 0;
886}
887fs_initcall(xen_p2m_debugfs);
888#endif /* CONFIG_XEN_DEBUG_FS */