proc: move /proc/diskstats boilerplate to block/genhd.c
Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com> Acked-by: Jens Axboe <jens.axboe@oracle.com>
This commit is contained in:
parent
5c9fe6281b
commit
31d85ab28e
|
@ -1005,15 +1005,28 @@ static int diskstats_show(struct seq_file *seqf, void *v)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct seq_operations diskstats_op = {
|
static const struct seq_operations diskstats_op = {
|
||||||
.start = disk_seqf_start,
|
.start = disk_seqf_start,
|
||||||
.next = disk_seqf_next,
|
.next = disk_seqf_next,
|
||||||
.stop = disk_seqf_stop,
|
.stop = disk_seqf_stop,
|
||||||
.show = diskstats_show
|
.show = diskstats_show
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int diskstats_open(struct inode *inode, struct file *file)
|
||||||
|
{
|
||||||
|
return seq_open(file, &diskstats_op);
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct file_operations proc_diskstats_operations = {
|
||||||
|
.open = diskstats_open,
|
||||||
|
.read = seq_read,
|
||||||
|
.llseek = seq_lseek,
|
||||||
|
.release = seq_release,
|
||||||
|
};
|
||||||
|
|
||||||
static int __init proc_genhd_init(void)
|
static int __init proc_genhd_init(void)
|
||||||
{
|
{
|
||||||
|
proc_create("diskstats", 0, NULL, &proc_diskstats_operations);
|
||||||
proc_create("partitions", 0, NULL, &proc_partitions_operations);
|
proc_create("partitions", 0, NULL, &proc_partitions_operations);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,19 +57,6 @@
|
||||||
#include <asm/div64.h>
|
#include <asm/div64.h>
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
||||||
#ifdef CONFIG_BLOCK
|
|
||||||
static int diskstats_open(struct inode *inode, struct file *file)
|
|
||||||
{
|
|
||||||
return seq_open(file, &diskstats_op);
|
|
||||||
}
|
|
||||||
static const struct file_operations proc_diskstats_operations = {
|
|
||||||
.open = diskstats_open,
|
|
||||||
.read = seq_read,
|
|
||||||
.llseek = seq_lseek,
|
|
||||||
.release = seq_release,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_MODULES
|
#ifdef CONFIG_MODULES
|
||||||
extern const struct seq_operations modules_op;
|
extern const struct seq_operations modules_op;
|
||||||
static int modules_open(struct inode *inode, struct file *file)
|
static int modules_open(struct inode *inode, struct file *file)
|
||||||
|
@ -222,9 +209,6 @@ void __init proc_misc_init(void)
|
||||||
proc_symlink("mounts", NULL, "self/mounts");
|
proc_symlink("mounts", NULL, "self/mounts");
|
||||||
|
|
||||||
/* And now for trickier ones */
|
/* And now for trickier ones */
|
||||||
#ifdef CONFIG_BLOCK
|
|
||||||
proc_create("diskstats", 0, NULL, &proc_diskstats_operations);
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_MODULES
|
#ifdef CONFIG_MODULES
|
||||||
proc_create("modules", 0, NULL, &proc_modules_operations);
|
proc_create("modules", 0, NULL, &proc_modules_operations);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -25,8 +25,6 @@ extern struct device_type part_type;
|
||||||
extern struct kobject *block_depr;
|
extern struct kobject *block_depr;
|
||||||
extern struct class block_class;
|
extern struct class block_class;
|
||||||
|
|
||||||
extern const struct seq_operations diskstats_op;
|
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
/* These three have identical behaviour; use the second one if DOS FDISK gets
|
/* These three have identical behaviour; use the second one if DOS FDISK gets
|
||||||
confused about extended/logical partitions starting past cylinder 1023. */
|
confused about extended/logical partitions starting past cylinder 1023. */
|
||||||
|
|
Loading…
Reference in New Issue