aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/bt8xx/bttv-driver.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/bt8xx/bttv-driver.c')
-rw-r--r--drivers/media/video/bt8xx/bttv-driver.c45
1 files changed, 16 insertions, 29 deletions
diff --git a/drivers/media/video/bt8xx/bttv-driver.c b/drivers/media/video/bt8xx/bttv-driver.c
index ccf6aa6a975..826ca60b42e 100644
--- a/drivers/media/video/bt8xx/bttv-driver.c
+++ b/drivers/media/video/bt8xx/bttv-driver.c
@@ -58,7 +58,7 @@
58 58
59 59
60unsigned int bttv_num; /* number of Bt848s in use */ 60unsigned int bttv_num; /* number of Bt848s in use */
61struct bttv bttvs[BTTV_MAX]; 61struct bttv *bttvs[BTTV_MAX];
62 62
63unsigned int bttv_debug; 63unsigned int bttv_debug;
64unsigned int bttv_verbose = 1; 64unsigned int bttv_verbose = 1;
@@ -3217,29 +3217,19 @@ err:
3217static int bttv_open(struct file *file) 3217static int bttv_open(struct file *file)
3218{ 3218{
3219 int minor = video_devdata(file)->minor; 3219 int minor = video_devdata(file)->minor;
3220 struct bttv *btv = NULL; 3220 struct bttv *btv = video_drvdata(file);
3221 struct bttv_fh *fh; 3221 struct bttv_fh *fh;
3222 enum v4l2_buf_type type = 0; 3222 enum v4l2_buf_type type = 0;
3223 unsigned int i;
3224 3223
3225 dprintk(KERN_DEBUG "bttv: open minor=%d\n",minor); 3224 dprintk(KERN_DEBUG "bttv: open minor=%d\n",minor);
3226 3225
3227 lock_kernel(); 3226 lock_kernel();
3228 for (i = 0; i < bttv_num; i++) { 3227 if (btv->video_dev->minor == minor) {
3229 if (bttvs[i].video_dev && 3228 type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
3230 bttvs[i].video_dev->minor == minor) { 3229 } else if (btv->vbi_dev->minor == minor) {
3231 btv = &bttvs[i]; 3230 type = V4L2_BUF_TYPE_VBI_CAPTURE;
3232 type = V4L2_BUF_TYPE_VIDEO_CAPTURE; 3231 } else {
3233 break; 3232 WARN_ON(1);
3234 }
3235 if (bttvs[i].vbi_dev &&
3236 bttvs[i].vbi_dev->minor == minor) {
3237 btv = &bttvs[i];
3238 type = V4L2_BUF_TYPE_VBI_CAPTURE;
3239 break;
3240 }
3241 }
3242 if (NULL == btv) {
3243 unlock_kernel(); 3233 unlock_kernel();
3244 return -ENODEV; 3234 return -ENODEV;
3245 } 3235 }
@@ -3429,20 +3419,14 @@ static struct video_device bttv_video_template = {
3429static int radio_open(struct file *file) 3419static int radio_open(struct file *file)
3430{ 3420{
3431 int minor = video_devdata(file)->minor; 3421 int minor = video_devdata(file)->minor;
3432 struct bttv *btv = NULL; 3422 struct bttv *btv = video_drvdata(file);
3433 struct bttv_fh *fh; 3423 struct bttv_fh *fh;
3434 unsigned int i;
3435 3424
3436 dprintk("bttv: open minor=%d\n",minor); 3425 dprintk("bttv: open minor=%d\n",minor);
3437 3426
3438 lock_kernel(); 3427 lock_kernel();
3439 for (i = 0; i < bttv_num; i++) { 3428 WARN_ON(btv->radio_dev && btv->radio_dev->minor != minor);
3440 if (bttvs[i].radio_dev && bttvs[i].radio_dev->minor == minor) { 3429 if (!btv->radio_dev || btv->radio_dev->minor != minor) {
3441 btv = &bttvs[i];
3442 break;
3443 }
3444 }
3445 if (NULL == btv) {
3446 unlock_kernel(); 3430 unlock_kernel();
3447 return -ENODEV; 3431 return -ENODEV;
3448 } 3432 }
@@ -4203,6 +4187,7 @@ static struct video_device *vdev_init(struct bttv *btv,
4203 vfd->parent = &btv->c.pci->dev; 4187 vfd->parent = &btv->c.pci->dev;
4204 vfd->release = video_device_release; 4188 vfd->release = video_device_release;
4205 vfd->debug = bttv_debug; 4189 vfd->debug = bttv_debug;
4190 video_set_drvdata(vfd, btv);
4206 snprintf(vfd->name, sizeof(vfd->name), "BT%d%s %s (%s)", 4191 snprintf(vfd->name, sizeof(vfd->name), "BT%d%s %s (%s)",
4207 btv->id, (btv->id==848 && btv->revision==0x12) ? "A" : "", 4192 btv->id, (btv->id==848 && btv->revision==0x12) ? "A" : "",
4208 type_name, bttv_tvcards[btv->c.type].name); 4193 type_name, bttv_tvcards[btv->c.type].name);
@@ -4312,8 +4297,7 @@ static int __devinit bttv_probe(struct pci_dev *dev,
4312 if (bttv_num == BTTV_MAX) 4297 if (bttv_num == BTTV_MAX)
4313 return -ENOMEM; 4298 return -ENOMEM;
4314 printk(KERN_INFO "bttv: Bt8xx card found (%d).\n", bttv_num); 4299 printk(KERN_INFO "bttv: Bt8xx card found (%d).\n", bttv_num);
4315 btv=&bttvs[bttv_num]; 4300 bttvs[bttv_num] = btv = kzalloc(sizeof(*btv), GFP_KERNEL);
4316 memset(btv,0,sizeof(*btv));
4317 btv->c.nr = bttv_num; 4301 btv->c.nr = bttv_num;
4318 sprintf(btv->c.name,"bttv%d",btv->c.nr); 4302 sprintf(btv->c.name,"bttv%d",btv->c.nr);
4319 4303
@@ -4517,6 +4501,9 @@ static void __devexit bttv_remove(struct pci_dev *pci_dev)
4517 pci_resource_len(btv->c.pci,0)); 4501 pci_resource_len(btv->c.pci,0));
4518 4502
4519 pci_set_drvdata(pci_dev, NULL); 4503 pci_set_drvdata(pci_dev, NULL);
4504 bttvs[btv->c.nr] = NULL;
4505 kfree(btv);
4506
4520 return; 4507 return;
4521} 4508}
4522 4509