summaryrefslogtreecommitdiff
path: root/linux/drivers/media/dvb/dvb-core/dvbdev.c
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers/media/dvb/dvb-core/dvbdev.c')
-rw-r--r--linux/drivers/media/dvb/dvb-core/dvbdev.c47
1 files changed, 19 insertions, 28 deletions
diff --git a/linux/drivers/media/dvb/dvb-core/dvbdev.c b/linux/drivers/media/dvb/dvb-core/dvbdev.c
index 3848c873f..1963ac731 100644
--- a/linux/drivers/media/dvb/dvb-core/dvbdev.c
+++ b/linux/drivers/media/dvb/dvb-core/dvbdev.c
@@ -38,9 +38,6 @@
static int dvbdev_debug = 0;
#define dprintk if (dvbdev_debug) printk
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0))
-static devfs_handle_t dvb_devfs_handle;
-#endif
static LIST_HEAD(dvb_adapter_list);
static DECLARE_MUTEX(dvbdev_register_lock);
@@ -194,7 +191,6 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
const struct dvb_device *template, void *priv, int type)
{
struct dvb_device *dvbdev;
- char name[64];
int id;
if (down_interruptible (&dvbdev_register_lock))
@@ -225,6 +221,8 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
list_add_tail (&dvbdev->list_head, &adap->device_list);
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0))
+ {
+ char name[64];
snprintf(name, sizeof(name), "%s%d", dnames[type], id);
dvbdev->devfs_handle = devfs_register(adap->devfs_handle, name,
DEVFS_FL_DEFAULT,
@@ -232,18 +230,19 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
nums2minor(adap->num, type, id),
S_IFCHR | S_IRUSR | S_IWUSR,
dvbdev->fops, dvbdev);
-#else
- snprintf(name, sizeof(name), "dvb/adapter%d/%s%d", adap->num, dnames[type], id);
- dvbdev->devfs_handle = devfs_register(NULL, name,
- DEVFS_FL_DEFAULT,
- DVB_MAJOR,
- nums2minor(adap->num, type, id),
- S_IFCHR | S_IRUSR | S_IWUSR,
- dvbdev->fops, dvbdev);
-#endif
dprintk("DVB: register adapter%d/%s @ minor: %i (0x%02x)\n",
adap->num, name, nums2minor(adap->num, type, id),
nums2minor(adap->num, type, id));
+ }
+#else
+ devfs_mk_cdev(MKDEV(DVB_MAJOR, nums2minor(adap->num, type, id)),
+ S_IFCHR | S_IRUSR | S_IWUSR,
+ "dvb/adapter%d/%s%d", adap->num, dnames[type], id);
+
+ dprintk("DVB: register adapter%d/%s%d @ minor: %i (0x%02x)\n",
+ adap->num, dnames[type], id, nums2minor(adap->num, type, id),
+ nums2minor(adap->num, type, id));
+#endif
return 0;
}
@@ -251,21 +250,14 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
void dvb_unregister_device(struct dvb_device *dvbdev)
{
-#if (LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0))
- char name[64];
- struct dvb_adapter *adap = dvbdev->adapter;
-#endif
-
if (!dvbdev)
return;
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0))
devfs_unregister(dvbdev->devfs_handle);
#else
- snprintf(name, sizeof(name), "dvb/adapter%d/%s%d", adap->num, dnames[dvbdev->type], dvbdev->id);
- /* fixme */
- printk("dvb_unregister_device: %s\n",name);
- devfs_remove(name);
+ devfs_remove("dvb/adapter%d/%s%d", dvbdev->adapter->num,
+ dnames[dvbdev->type], dvbdev->id);
#endif
list_del (&dvbdev->list_head);
kfree (dvbdev);
@@ -296,7 +288,6 @@ skip:
int dvb_register_adapter(struct dvb_adapter **padap, const char *name)
{
- char dirname[64];
struct dvb_adapter *adap;
int num;
@@ -319,11 +310,13 @@ int dvb_register_adapter(struct dvb_adapter **padap, const char *name)
printk ("DVB: registering new adapter (%s).\n", name);
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0))
+ {
+ char dirname[64];
snprintf(dirname, sizeof(dirname), "adapter%d", num);
adap->devfs_handle = devfs_mk_dir(dvb_devfs_handle, dirname, NULL);
+ }
#else
- snprintf(dirname, sizeof(dirname), "dvb/adapter%d", num);
- devfs_mk_dir(dirname);
+ devfs_mk_dir("dvb/adapter%d", num);
#endif
adap->num = num;
adap->name = name;
@@ -341,9 +334,7 @@ int dvb_unregister_adapter(struct dvb_adapter *adap)
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0))
devfs_unregister(adap->devfs_handle);
#else
- char dirname[64]; /* fixme */
- snprintf(dirname, sizeof(dirname), "dvb/adapter%d", adap->num);
- devfs_remove(dirname);
+ devfs_remove("dvb/adapter%d", adap->num);
#endif
if (down_interruptible (&dvbdev_register_lock))
return -ERESTARTSYS;