diff options
Diffstat (limited to 'arch/sh')
| -rw-r--r-- | arch/sh/Kconfig.debug | 4 | ||||
| -rw-r--r-- | arch/sh/kernel/process_64.c | 39 | ||||
| -rw-r--r-- | arch/sh/mm/Makefile_32 | 1 | ||||
| -rw-r--r-- | arch/sh/mm/Makefile_64 | 1 | ||||
| -rw-r--r-- | arch/sh/mm/asids-debugfs.c | 79 |
5 files changed, 81 insertions, 43 deletions
diff --git a/arch/sh/Kconfig.debug b/arch/sh/Kconfig.debug index e6d2c8b11abd..8f0c1fbd51a6 100644 --- a/arch/sh/Kconfig.debug +++ b/arch/sh/Kconfig.debug | |||
| @@ -180,10 +180,6 @@ endmenu | |||
| 180 | 180 | ||
| 181 | if SUPERH64 | 181 | if SUPERH64 |
| 182 | 182 | ||
| 183 | config SH64_PROC_ASIDS | ||
| 184 | bool "Debug: report ASIDs through /proc/asids" | ||
| 185 | depends on PROC_FS && MMU | ||
| 186 | |||
| 187 | config SH64_SR_WATCH | 183 | config SH64_SR_WATCH |
| 188 | bool "Debug: set SR.WATCH to enable hardware watchpoints and trace" | 184 | bool "Debug: set SR.WATCH to enable hardware watchpoints and trace" |
| 189 | 185 | ||
diff --git a/arch/sh/kernel/process_64.c b/arch/sh/kernel/process_64.c index e9bf2548d6d4..a7e5f2e74bac 100644 --- a/arch/sh/kernel/process_64.c +++ b/arch/sh/kernel/process_64.c | |||
| @@ -23,7 +23,6 @@ | |||
| 23 | #include <linux/reboot.h> | 23 | #include <linux/reboot.h> |
| 24 | #include <linux/init.h> | 24 | #include <linux/init.h> |
| 25 | #include <linux/module.h> | 25 | #include <linux/module.h> |
| 26 | #include <linux/proc_fs.h> | ||
| 27 | #include <linux/io.h> | 26 | #include <linux/io.h> |
| 28 | #include <asm/syscalls.h> | 27 | #include <asm/syscalls.h> |
| 29 | #include <asm/uaccess.h> | 28 | #include <asm/uaccess.h> |
| @@ -590,41 +589,3 @@ unsigned long get_wchan(struct task_struct *p) | |||
| 590 | #endif | 589 | #endif |
| 591 | return pc; | 590 | return pc; |
| 592 | } | 591 | } |
| 593 | |||
| 594 | /* Provide a /proc/asids file that lists out the | ||
| 595 | ASIDs currently associated with the processes. (If the DM.PC register is | ||
| 596 | examined through the debug link, this shows ASID + PC. To make use of this, | ||
| 597 | the PID->ASID relationship needs to be known. This is primarily for | ||
| 598 | debugging.) | ||
| 599 | */ | ||
| 600 | |||
| 601 | #if defined(CONFIG_SH64_PROC_ASIDS) | ||
| 602 | static int | ||
| 603 | asids_proc_info(char *buf, char **start, off_t fpos, int length, int *eof, void *data) | ||
| 604 | { | ||
| 605 | int len=0; | ||
| 606 | struct task_struct *p; | ||
| 607 | read_lock(&tasklist_lock); | ||
| 608 | for_each_process(p) { | ||
| 609 | int pid = p->pid; | ||
| 610 | |||
| 611 | if (!pid) | ||
| 612 | continue; | ||
| 613 | if (p->mm) | ||
| 614 | len += sprintf(buf+len, "%5d : %02lx\n", pid, | ||
| 615 | asid_cache(smp_processor_id())); | ||
| 616 | else | ||
| 617 | len += sprintf(buf+len, "%5d : (none)\n", pid); | ||
| 618 | } | ||
| 619 | read_unlock(&tasklist_lock); | ||
| 620 | *eof = 1; | ||
| 621 | return len; | ||
| 622 | } | ||
| 623 | |||
| 624 | static int __init register_proc_asids(void) | ||
| 625 | { | ||
| 626 | create_proc_read_entry("asids", 0, NULL, asids_proc_info, NULL); | ||
| 627 | return 0; | ||
| 628 | } | ||
| 629 | __initcall(register_proc_asids); | ||
| 630 | #endif | ||
diff --git a/arch/sh/mm/Makefile_32 b/arch/sh/mm/Makefile_32 index f066e76da204..cb2f3f299591 100644 --- a/arch/sh/mm/Makefile_32 +++ b/arch/sh/mm/Makefile_32 | |||
| @@ -18,6 +18,7 @@ mmu-y := tlb-nommu.o pg-nommu.o | |||
| 18 | mmu-$(CONFIG_MMU) := fault_32.o tlbflush_32.o ioremap_32.o | 18 | mmu-$(CONFIG_MMU) := fault_32.o tlbflush_32.o ioremap_32.o |
| 19 | 19 | ||
| 20 | obj-y += $(mmu-y) | 20 | obj-y += $(mmu-y) |
| 21 | obj-$(CONFIG_DEBUG_FS) += asids-debugfs.o | ||
| 21 | 22 | ||
| 22 | ifdef CONFIG_DEBUG_FS | 23 | ifdef CONFIG_DEBUG_FS |
| 23 | obj-$(CONFIG_CPU_SH4) += cache-debugfs.o | 24 | obj-$(CONFIG_CPU_SH4) += cache-debugfs.o |
diff --git a/arch/sh/mm/Makefile_64 b/arch/sh/mm/Makefile_64 index 9481d0f54efd..2863ffb7006d 100644 --- a/arch/sh/mm/Makefile_64 +++ b/arch/sh/mm/Makefile_64 | |||
| @@ -13,6 +13,7 @@ obj-y += cache-sh5.o | |||
| 13 | endif | 13 | endif |
| 14 | 14 | ||
| 15 | obj-y += $(mmu-y) | 15 | obj-y += $(mmu-y) |
| 16 | obj-$(CONFIG_DEBUG_FS) += asids-debugfs.o | ||
| 16 | 17 | ||
| 17 | obj-$(CONFIG_HUGETLB_PAGE) += hugetlbpage.o | 18 | obj-$(CONFIG_HUGETLB_PAGE) += hugetlbpage.o |
| 18 | obj-$(CONFIG_NUMA) += numa.o | 19 | obj-$(CONFIG_NUMA) += numa.o |
diff --git a/arch/sh/mm/asids-debugfs.c b/arch/sh/mm/asids-debugfs.c new file mode 100644 index 000000000000..0678a1044a9a --- /dev/null +++ b/arch/sh/mm/asids-debugfs.c | |||
| @@ -0,0 +1,79 @@ | |||
| 1 | /* | ||
| 2 | * debugfs ops for process ASIDs | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000, 2001 Paolo Alberelli | ||
| 5 | * Copyright (C) 2003 - 2008 Paul Mundt | ||
| 6 | * Copyright (C) 2003, 2004 Richard Curnow | ||
| 7 | * | ||
| 8 | * Provides a debugfs file that lists out the ASIDs currently associated | ||
| 9 | * with the processes. | ||
| 10 | * | ||
| 11 | * In the SH-5 case, if the DM.PC register is examined through the debug | ||
| 12 | * link, this shows ASID + PC. To make use of this, the PID->ASID | ||
| 13 | * relationship needs to be known. This is primarily for debugging. | ||
| 14 | * | ||
| 15 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 16 | * License. See the file "COPYING" in the main directory of this archive | ||
| 17 | * for more details. | ||
| 18 | */ | ||
| 19 | #include <linux/init.h> | ||
| 20 | #include <linux/module.h> | ||
| 21 | #include <linux/debugfs.h> | ||
| 22 | #include <linux/seq_file.h> | ||
| 23 | #include <linux/spinlock.h> | ||
| 24 | #include <asm/processor.h> | ||
| 25 | #include <asm/mmu_context.h> | ||
| 26 | |||
| 27 | static int asids_seq_show(struct seq_file *file, void *iter) | ||
| 28 | { | ||
| 29 | struct task_struct *p; | ||
| 30 | |||
| 31 | read_lock(&tasklist_lock); | ||
| 32 | |||
| 33 | for_each_process(p) { | ||
| 34 | int pid = p->pid; | ||
| 35 | |||
| 36 | if (unlikely(!pid)) | ||
| 37 | continue; | ||
| 38 | |||
| 39 | if (p->mm) | ||
| 40 | seq_printf(file, "%5d : %02x\n", pid, | ||
| 41 | cpu_asid(smp_processor_id(), p->mm)); | ||
| 42 | else | ||
| 43 | seq_printf(file, "%5d : (none)\n", pid); | ||
| 44 | } | ||
| 45 | |||
| 46 | read_unlock(&tasklist_lock); | ||
| 47 | |||
| 48 | return 0; | ||
| 49 | } | ||
| 50 | |||
| 51 | static int asids_debugfs_open(struct inode *inode, struct file *file) | ||
| 52 | { | ||
| 53 | return single_open(file, asids_seq_show, inode->i_private); | ||
| 54 | } | ||
| 55 | |||
| 56 | static const struct file_operations asids_debugfs_fops = { | ||
| 57 | .owner = THIS_MODULE, | ||
| 58 | .open = asids_debugfs_open, | ||
| 59 | .read = seq_read, | ||
| 60 | .llseek = seq_lseek, | ||
| 61 | .release = single_release, | ||
| 62 | }; | ||
| 63 | |||
| 64 | static int __init asids_debugfs_init(void) | ||
| 65 | { | ||
| 66 | struct dentry *asids_dentry; | ||
| 67 | |||
| 68 | asids_dentry = debugfs_create_file("asids", S_IRUSR, sh_debugfs_root, | ||
| 69 | NULL, &asids_debugfs_fops); | ||
| 70 | if (!asids_dentry) | ||
| 71 | return -ENOMEM; | ||
| 72 | if (IS_ERR(asids_dentry)) | ||
| 73 | return PTR_ERR(asids_dentry); | ||
| 74 | |||
| 75 | return 0; | ||
| 76 | } | ||
| 77 | module_init(asids_debugfs_init); | ||
| 78 | |||
| 79 | MODULE_LICENSE("GPL v2"); | ||
