aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video
diff options
context:
space:
mode:
authorJanne Grunau <janne-dvb@grunau.be>2008-04-09 18:13:13 -0400
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-04-24 13:08:00 -0400
commit78e92006f410a4044f8c1760c25ac9d11d259aa2 (patch)
tree293de8abe261420df2db5e12936ec2721ea52c7c /drivers/media/video
parent9950c1b5b4b86d4aae12853c2f0a0ef11d976764 (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.c4
-rw-r--r--drivers/media/video/cx88/cx88-dvb.c5
-rw-r--r--drivers/media/video/saa7134/saa7134-dvb.c5
-rw-r--r--drivers/media/video/videobuf-dvb.c6
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;
54module_param(alt_tuner, int, 0644); 54module_param(alt_tuner, int, 0644);
55MODULE_PARM_DESC(alt_tuner, "Enable alternate tuner configuration"); 55MODULE_PARM_DESC(alt_tuner, "Enable alternate tuner configuration");
56 56
57DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
58
57/* ------------------------------------------------------------------ */ 59/* ------------------------------------------------------------------ */
58 60
59static int dvb_buf_setup(struct videobuf_queue *q, 61static 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
339int cx23885_dvb_register(struct cx23885_tsport *port) 341int 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;
58module_param(debug, int, 0644); 58module_param(debug, int, 0644);
59MODULE_PARM_DESC(debug,"enable debug messages [dvb]"); 59MODULE_PARM_DESC(debug,"enable debug messages [dvb]");
60 60
61DVB_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;
65module_param(debug, int, 0644); 65module_param(debug, int, 0644);
66MODULE_PARM_DESC(debug, "Turn on/off module debugging (default:off)."); 66MODULE_PARM_DESC(debug, "Turn on/off module debugging (default:off).");
67 67
68DVB_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)
138int videobuf_dvb_register(struct videobuf_dvb *dvb, 138int 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);