diff options
-rw-r--r-- | drivers/mtd/mtdcore.c | 50 |
1 files changed, 19 insertions, 31 deletions
diff --git a/drivers/mtd/mtdcore.c b/drivers/mtd/mtdcore.c index a50348b60d79..d162426416de 100644 --- a/drivers/mtd/mtdcore.c +++ b/drivers/mtd/mtdcore.c | |||
@@ -24,6 +24,7 @@ | |||
24 | #include <linux/module.h> | 24 | #include <linux/module.h> |
25 | #include <linux/kernel.h> | 25 | #include <linux/kernel.h> |
26 | #include <linux/ptrace.h> | 26 | #include <linux/ptrace.h> |
27 | #include <linux/seq_file.h> | ||
27 | #include <linux/string.h> | 28 | #include <linux/string.h> |
28 | #include <linux/timer.h> | 29 | #include <linux/timer.h> |
29 | #include <linux/major.h> | 30 | #include <linux/major.h> |
@@ -705,44 +706,32 @@ EXPORT_SYMBOL_GPL(mtd_kmalloc_up_to); | |||
705 | 706 | ||
706 | static struct proc_dir_entry *proc_mtd; | 707 | static struct proc_dir_entry *proc_mtd; |
707 | 708 | ||
708 | static inline int mtd_proc_info(char *buf, struct mtd_info *this) | 709 | static int mtd_proc_show(struct seq_file *m, void *v) |
709 | { | ||
710 | return sprintf(buf, "mtd%d: %8.8llx %8.8x \"%s\"\n", this->index, | ||
711 | (unsigned long long)this->size, | ||
712 | this->erasesize, this->name); | ||
713 | } | ||
714 | |||
715 | static int mtd_read_proc (char *page, char **start, off_t off, int count, | ||
716 | int *eof, void *data_unused) | ||
717 | { | 710 | { |
718 | struct mtd_info *mtd; | 711 | struct mtd_info *mtd; |
719 | int len, l; | ||
720 | off_t begin = 0; | ||
721 | 712 | ||
713 | seq_puts(m, "dev: size erasesize name\n"); | ||
722 | mutex_lock(&mtd_table_mutex); | 714 | mutex_lock(&mtd_table_mutex); |
723 | |||
724 | len = sprintf(page, "dev: size erasesize name\n"); | ||
725 | mtd_for_each_device(mtd) { | 715 | mtd_for_each_device(mtd) { |
726 | l = mtd_proc_info(page + len, mtd); | 716 | seq_printf(m, "mtd%d: %8.8llx %8.8x \"%s\"\n", |
727 | len += l; | 717 | mtd->index, (unsigned long long)mtd->size, |
728 | if (len+begin > off+count) | 718 | mtd->erasesize, mtd->name); |
729 | goto done; | ||
730 | if (len+begin < off) { | ||
731 | begin += len; | ||
732 | len = 0; | ||
733 | } | ||
734 | } | 719 | } |
735 | |||
736 | *eof = 1; | ||
737 | |||
738 | done: | ||
739 | mutex_unlock(&mtd_table_mutex); | 720 | mutex_unlock(&mtd_table_mutex); |
740 | if (off >= len+begin) | 721 | return 0; |
741 | return 0; | ||
742 | *start = page + (off-begin); | ||
743 | return ((count < begin+len-off) ? count : begin+len-off); | ||
744 | } | 722 | } |
745 | 723 | ||
724 | static int mtd_proc_open(struct inode *inode, struct file *file) | ||
725 | { | ||
726 | return single_open(file, mtd_proc_show, NULL); | ||
727 | } | ||
728 | |||
729 | static const struct file_operations mtd_proc_ops = { | ||
730 | .open = mtd_proc_open, | ||
731 | .read = seq_read, | ||
732 | .llseek = seq_lseek, | ||
733 | .release = single_release, | ||
734 | }; | ||
746 | #endif /* CONFIG_PROC_FS */ | 735 | #endif /* CONFIG_PROC_FS */ |
747 | 736 | ||
748 | /*====================================================================*/ | 737 | /*====================================================================*/ |
@@ -783,8 +772,7 @@ static int __init init_mtd(void) | |||
783 | goto err_bdi3; | 772 | goto err_bdi3; |
784 | 773 | ||
785 | #ifdef CONFIG_PROC_FS | 774 | #ifdef CONFIG_PROC_FS |
786 | if ((proc_mtd = create_proc_entry( "mtd", 0, NULL ))) | 775 | proc_mtd = proc_create("mtd", 0, NULL, &mtd_proc_ops); |
787 | proc_mtd->read_proc = mtd_read_proc; | ||
788 | #endif /* CONFIG_PROC_FS */ | 776 | #endif /* CONFIG_PROC_FS */ |
789 | return 0; | 777 | return 0; |
790 | 778 | ||