diff options
author | Janne Grunau <janne-dvb@grunau.be> | 2008-04-09 18:13:13 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2008-04-24 13:08:00 -0400 |
commit | 78e92006f410a4044f8c1760c25ac9d11d259aa2 (patch) | |
tree | 293de8abe261420df2db5e12936ec2721ea52c7c /drivers/media/video | |
parent | 9950c1b5b4b86d4aae12853c2f0a0ef11d976764 (diff) |
V4L/DVB (7538): Adds selectable adapter numbers as per module option
The adapter_nr module options can be used to allocate static adapter
numbers on a driver level. It avoids problems with changing DVB apapter
numbers after warm/cold boot or device unplugging and repluging.
Each driver holds DVB_MAX_ADAPTER long array of the preferred order of
adapter numbers.
options dvb-usb-dib0700 adapter_nr=7,6,5,4,3,2,1,0 would result in a
reversed allocation of adapter numbers.
With adapter_nr=2,5 it tries first to get adapter number 2 and 5. If
both are already in use it will allocate the lowest free adapter number.
Signed-off-by: Janne Grunau <janne-dvb@grunau.be>
Acked-by: Hermann Pitton <hermann.pitton@arcor.de>
Signed-off-by: Michael Krufky <mkrufky@linuxtv.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/cx23885/cx23885-dvb.c | 4 | ||||
-rw-r--r-- | drivers/media/video/cx88/cx88-dvb.c | 5 | ||||
-rw-r--r-- | drivers/media/video/saa7134/saa7134-dvb.c | 5 | ||||
-rw-r--r-- | drivers/media/video/videobuf-dvb.c | 6 |
4 files changed, 15 insertions, 5 deletions
diff --git a/drivers/media/video/cx23885/cx23885-dvb.c b/drivers/media/video/cx23885/cx23885-dvb.c index 74baa28d16ab..1a720abbd066 100644 --- a/drivers/media/video/cx23885/cx23885-dvb.c +++ b/drivers/media/video/cx23885/cx23885-dvb.c | |||
@@ -54,6 +54,8 @@ static unsigned int alt_tuner; | |||
54 | module_param(alt_tuner, int, 0644); | 54 | module_param(alt_tuner, int, 0644); |
55 | MODULE_PARM_DESC(alt_tuner, "Enable alternate tuner configuration"); | 55 | MODULE_PARM_DESC(alt_tuner, "Enable alternate tuner configuration"); |
56 | 56 | ||
57 | DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr); | ||
58 | |||
57 | /* ------------------------------------------------------------------ */ | 59 | /* ------------------------------------------------------------------ */ |
58 | 60 | ||
59 | static int dvb_buf_setup(struct videobuf_queue *q, | 61 | static int dvb_buf_setup(struct videobuf_queue *q, |
@@ -333,7 +335,7 @@ static int dvb_register(struct cx23885_tsport *port) | |||
333 | 335 | ||
334 | /* register everything */ | 336 | /* register everything */ |
335 | return videobuf_dvb_register(&port->dvb, THIS_MODULE, port, | 337 | return videobuf_dvb_register(&port->dvb, THIS_MODULE, port, |
336 | &dev->pci->dev); | 338 | &dev->pci->dev, adapter_nr); |
337 | } | 339 | } |
338 | 340 | ||
339 | int cx23885_dvb_register(struct cx23885_tsport *port) | 341 | int cx23885_dvb_register(struct cx23885_tsport *port) |
diff --git a/drivers/media/video/cx88/cx88-dvb.c b/drivers/media/video/cx88/cx88-dvb.c index e83d9869e68b..fda7334d934b 100644 --- a/drivers/media/video/cx88/cx88-dvb.c +++ b/drivers/media/video/cx88/cx88-dvb.c | |||
@@ -58,6 +58,8 @@ static unsigned int debug; | |||
58 | module_param(debug, int, 0644); | 58 | module_param(debug, int, 0644); |
59 | MODULE_PARM_DESC(debug,"enable debug messages [dvb]"); | 59 | MODULE_PARM_DESC(debug,"enable debug messages [dvb]"); |
60 | 60 | ||
61 | DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr); | ||
62 | |||
61 | #define dprintk(level,fmt, arg...) if (debug >= level) \ | 63 | #define dprintk(level,fmt, arg...) if (debug >= level) \ |
62 | printk(KERN_DEBUG "%s/2-dvb: " fmt, core->name, ## arg) | 64 | printk(KERN_DEBUG "%s/2-dvb: " fmt, core->name, ## arg) |
63 | 65 | ||
@@ -862,7 +864,8 @@ static int dvb_register(struct cx8802_dev *dev) | |||
862 | cx88_call_i2c_clients (dev->core, TUNER_SET_STANDBY, NULL); | 864 | cx88_call_i2c_clients (dev->core, TUNER_SET_STANDBY, NULL); |
863 | 865 | ||
864 | /* register everything */ | 866 | /* register everything */ |
865 | return videobuf_dvb_register(&dev->dvb, THIS_MODULE, dev, &dev->pci->dev); | 867 | return videobuf_dvb_register(&dev->dvb, THIS_MODULE, dev, |
868 | &dev->pci->dev, adapter_nr); | ||
866 | } | 869 | } |
867 | 870 | ||
868 | /* ----------------------------------------------------------- */ | 871 | /* ----------------------------------------------------------- */ |
diff --git a/drivers/media/video/saa7134/saa7134-dvb.c b/drivers/media/video/saa7134/saa7134-dvb.c index e5c3569dd2c8..73154c1a0239 100644 --- a/drivers/media/video/saa7134/saa7134-dvb.c +++ b/drivers/media/video/saa7134/saa7134-dvb.c | |||
@@ -65,6 +65,8 @@ static int debug; | |||
65 | module_param(debug, int, 0644); | 65 | module_param(debug, int, 0644); |
66 | MODULE_PARM_DESC(debug, "Turn on/off module debugging (default:off)."); | 66 | MODULE_PARM_DESC(debug, "Turn on/off module debugging (default:off)."); |
67 | 67 | ||
68 | DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr); | ||
69 | |||
68 | #define dprintk(fmt, arg...) do { if (debug) \ | 70 | #define dprintk(fmt, arg...) do { if (debug) \ |
69 | printk(KERN_DEBUG "%s/dvb: " fmt, dev->name , ## arg); } while(0) | 71 | printk(KERN_DEBUG "%s/dvb: " fmt, dev->name , ## arg); } while(0) |
70 | 72 | ||
@@ -1257,7 +1259,8 @@ static int dvb_init(struct saa7134_dev *dev) | |||
1257 | } | 1259 | } |
1258 | 1260 | ||
1259 | /* register everything else */ | 1261 | /* register everything else */ |
1260 | ret = videobuf_dvb_register(&dev->dvb, THIS_MODULE, dev, &dev->pci->dev); | 1262 | ret = videobuf_dvb_register(&dev->dvb, THIS_MODULE, dev, &dev->pci->dev, |
1263 | adapter_nr); | ||
1261 | 1264 | ||
1262 | /* this sequence is necessary to make the tda1004x load its firmware | 1265 | /* this sequence is necessary to make the tda1004x load its firmware |
1263 | * and to enter analog mode of hybrid boards | 1266 | * and to enter analog mode of hybrid boards |
diff --git a/drivers/media/video/videobuf-dvb.c b/drivers/media/video/videobuf-dvb.c index 4ba8b7db7fda..0f8542a4c71a 100644 --- a/drivers/media/video/videobuf-dvb.c +++ b/drivers/media/video/videobuf-dvb.c | |||
@@ -138,14 +138,16 @@ static int videobuf_dvb_stop_feed(struct dvb_demux_feed *feed) | |||
138 | int videobuf_dvb_register(struct videobuf_dvb *dvb, | 138 | int videobuf_dvb_register(struct videobuf_dvb *dvb, |
139 | struct module *module, | 139 | struct module *module, |
140 | void *adapter_priv, | 140 | void *adapter_priv, |
141 | struct device *device) | 141 | struct device *device, |
142 | short *adapter_nr) | ||
142 | { | 143 | { |
143 | int result; | 144 | int result; |
144 | 145 | ||
145 | mutex_init(&dvb->lock); | 146 | mutex_init(&dvb->lock); |
146 | 147 | ||
147 | /* register adapter */ | 148 | /* register adapter */ |
148 | result = dvb_register_adapter(&dvb->adapter, dvb->name, module, device); | 149 | result = dvb_register_adapter(&dvb->adapter, dvb->name, module, device, |
150 | adapter_nr); | ||
149 | if (result < 0) { | 151 | if (result < 0) { |
150 | printk(KERN_WARNING "%s: dvb_register_adapter failed (errno = %d)\n", | 152 | printk(KERN_WARNING "%s: dvb_register_adapter failed (errno = %d)\n", |
151 | dvb->name, result); | 153 | dvb->name, result); |