aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/bt8xx/bttv-driver.c
diff options
context:
space:
mode:
authorTrent Piepho <xyzzy@speakeasy.org>2009-01-28 19:32:59 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2009-03-30 11:42:47 -0400
commit4b10d3b626922ffa2387905a230b12450281a12d (patch)
treed65429e98adf29ba08b6ddbf09e6ac78fcaaeac3 /drivers/media/video/bt8xx/bttv-driver.c
parent6f98700a5bb8d218162b04db1b8a3921a0dcc7ce (diff)
V4L/DVB (10568): bttv: dynamically allocate device data
The bttv driver had static array of structures for up to 16 possible bttv devices, even though few users have more than one or two. The structures were quite large and this resulted in a huge BSS segment. Change the driver to allocate the bttv device data dynamically, which changes "struct bttv bttvs[BTTV_MAX]" to "struct bttv *bttvs[BTTV_MAX]". It would be nice to get ride of "bttvs" entirely but there are some complications with gpio access from the audio & mpeg drivers. To help bttvs removal along anyway, I changed the open() methods use the video device's drvdata to get the driver data instead of looking it up in the bttvs array. This is also more efficient. Some WARN_ON()s are added in cases the device node exists by the bttv device doesn't, which I don't think should be possible. The gpio access functions need to check if bttvs[card] is NULL now. Though calling them on a non-existent card in the first place is wrong, but hard to solve given the fundamental problems in how the gpio access code works. This patch reduces the bss size by 66560 bytes on ia32. Overall change is a reduction of 66398 bytes, as the WARN_ON()s add some 198 bytes. Signed-off-by: Trent Piepho <xyzzy@speakeasy.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
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