Commit 0078bff5 authored by Jan Kara's avatar Jan Kara Committed by Greg Kroah-Hartman

Allow setting of number of raw devices as a module parameter

Allow setting of maximal number of raw devices as a module parameter. This
requires changing of static array into a vmalloced one (the array is going to
be too large for kmalloc).
Signed-off-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent a1d9a09a
...@@ -523,7 +523,7 @@ config RAW_DRIVER ...@@ -523,7 +523,7 @@ config RAW_DRIVER
with the O_DIRECT flag. with the O_DIRECT flag.
config MAX_RAW_DEVS config MAX_RAW_DEVS
int "Maximum number of RAW devices to support (1-8192)" int "Maximum number of RAW devices to support (1-65536)"
depends on RAW_DRIVER depends on RAW_DRIVER
default "256" default "256"
help help
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/gfp.h> #include <linux/gfp.h>
#include <linux/compat.h> #include <linux/compat.h>
#include <linux/vmalloc.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
...@@ -30,10 +31,15 @@ struct raw_device_data { ...@@ -30,10 +31,15 @@ struct raw_device_data {
}; };
static struct class *raw_class; static struct class *raw_class;
static struct raw_device_data raw_devices[MAX_RAW_MINORS]; static struct raw_device_data *raw_devices;
static DEFINE_MUTEX(raw_mutex); static DEFINE_MUTEX(raw_mutex);
static const struct file_operations raw_ctl_fops; /* forward declaration */ static const struct file_operations raw_ctl_fops; /* forward declaration */
static int max_raw_minors = MAX_RAW_MINORS;
module_param(max_raw_minors, int, 0);
MODULE_PARM_DESC(max_raw_minors, "Maximum number of raw devices (1-65536)");
/* /*
* Open/close code for raw IO. * Open/close code for raw IO.
* *
...@@ -125,7 +131,7 @@ static int bind_set(int number, u64 major, u64 minor) ...@@ -125,7 +131,7 @@ static int bind_set(int number, u64 major, u64 minor)
struct raw_device_data *rawdev; struct raw_device_data *rawdev;
int err = 0; int err = 0;
if (number <= 0 || number >= MAX_RAW_MINORS) if (number <= 0 || number >= max_raw_minors)
return -EINVAL; return -EINVAL;
if (MAJOR(dev) != major || MINOR(dev) != minor) if (MAJOR(dev) != major || MINOR(dev) != minor)
...@@ -312,12 +318,26 @@ static int __init raw_init(void) ...@@ -312,12 +318,26 @@ static int __init raw_init(void)
dev_t dev = MKDEV(RAW_MAJOR, 0); dev_t dev = MKDEV(RAW_MAJOR, 0);
int ret; int ret;
ret = register_chrdev_region(dev, MAX_RAW_MINORS, "raw"); if (max_raw_minors < 1 || max_raw_minors > 65536) {
printk(KERN_WARNING "raw: invalid max_raw_minors (must be"
" between 1 and 65536), using %d\n", MAX_RAW_MINORS);
max_raw_minors = MAX_RAW_MINORS;
}
raw_devices = vmalloc(sizeof(struct raw_device_data) * max_raw_minors);
if (!raw_devices) {
printk(KERN_ERR "Not enough memory for raw device structures\n");
ret = -ENOMEM;
goto error;
}
memset(raw_devices, 0, sizeof(struct raw_device_data) * max_raw_minors);
ret = register_chrdev_region(dev, max_raw_minors, "raw");
if (ret) if (ret)
goto error; goto error;
cdev_init(&raw_cdev, &raw_fops); cdev_init(&raw_cdev, &raw_fops);
ret = cdev_add(&raw_cdev, dev, MAX_RAW_MINORS); ret = cdev_add(&raw_cdev, dev, max_raw_minors);
if (ret) { if (ret) {
kobject_put(&raw_cdev.kobj); kobject_put(&raw_cdev.kobj);
goto error_region; goto error_region;
...@@ -336,8 +356,9 @@ static int __init raw_init(void) ...@@ -336,8 +356,9 @@ static int __init raw_init(void)
return 0; return 0;
error_region: error_region:
unregister_chrdev_region(dev, MAX_RAW_MINORS); unregister_chrdev_region(dev, max_raw_minors);
error: error:
vfree(raw_devices);
return ret; return ret;
} }
...@@ -346,7 +367,7 @@ static void __exit raw_exit(void) ...@@ -346,7 +367,7 @@ static void __exit raw_exit(void)
device_destroy(raw_class, MKDEV(RAW_MAJOR, 0)); device_destroy(raw_class, MKDEV(RAW_MAJOR, 0));
class_destroy(raw_class); class_destroy(raw_class);
cdev_del(&raw_cdev); cdev_del(&raw_cdev);
unregister_chrdev_region(MKDEV(RAW_MAJOR, 0), MAX_RAW_MINORS); unregister_chrdev_region(MKDEV(RAW_MAJOR, 0), max_raw_minors);
} }
module_init(raw_init); module_init(raw_init);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment