diff options
author | Archit Taneja <archit@ti.com> | 2011-09-28 09:49:24 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2011-11-07 07:46:18 -0500 |
commit | d06db7ec908869cbf79829b8cbd9a04a7c802905 (patch) | |
tree | e3ced6ea27849ba6be19579274ed2f948b9e5ca5 /drivers/media/video/omap | |
parent | 3f8770454b82c166662201a8966476f4538cbfeb (diff) |
[media] OMAP_VOUT: Fix check in reqbuf for buf_size allocation
The commit 383e4f69879d11c86ebdd38b3356f6d0690fb4cc makes reqbuf prevent
requesting a larger size buffer than what is allocated at kernel boot during
omap_vout_probe.
In omap_vout_buffer_setup callback API, the requested size is compared with
vout->buffer_size, this isn't correct as vout->buffer_size is later set to the
size requested in reqbuf. When the video device is opened the next time, this
check will prevent us to allocate a buffer which is larger than what we requested
the last time.
Don't use vout->buffer_size, always check with the parameters video1_bufsize
or video2_bufsize.
Signed-off-by: Archit Taneja <archit@ti.com>
Acked-by: Vaibhav Hiremath <hvaibhav@ti.com>
Signed-off-by: Vaibhav Hiremath <hvaibhav@ti.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/omap')
-rw-r--r-- | drivers/media/video/omap/omap_vout.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/media/video/omap/omap_vout.c b/drivers/media/video/omap/omap_vout.c index 9c5c19f142de..11f5638dad78 100644 --- a/drivers/media/video/omap/omap_vout.c +++ b/drivers/media/video/omap/omap_vout.c | |||
@@ -663,10 +663,14 @@ static int omap_vout_buffer_setup(struct videobuf_queue *q, unsigned int *count, | |||
663 | u32 phy_addr = 0, virt_addr = 0; | 663 | u32 phy_addr = 0, virt_addr = 0; |
664 | struct omap_vout_device *vout = q->priv_data; | 664 | struct omap_vout_device *vout = q->priv_data; |
665 | struct omapvideo_info *ovid = &vout->vid_info; | 665 | struct omapvideo_info *ovid = &vout->vid_info; |
666 | int vid_max_buf_size; | ||
666 | 667 | ||
667 | if (!vout) | 668 | if (!vout) |
668 | return -EINVAL; | 669 | return -EINVAL; |
669 | 670 | ||
671 | vid_max_buf_size = vout->vid == OMAP_VIDEO1 ? video1_bufsize : | ||
672 | video2_bufsize; | ||
673 | |||
670 | if (V4L2_BUF_TYPE_VIDEO_OUTPUT != q->type) | 674 | if (V4L2_BUF_TYPE_VIDEO_OUTPUT != q->type) |
671 | return -EINVAL; | 675 | return -EINVAL; |
672 | 676 | ||
@@ -689,7 +693,7 @@ static int omap_vout_buffer_setup(struct videobuf_queue *q, unsigned int *count, | |||
689 | video1_numbuffers : video2_numbuffers; | 693 | video1_numbuffers : video2_numbuffers; |
690 | 694 | ||
691 | /* Check the size of the buffer */ | 695 | /* Check the size of the buffer */ |
692 | if (*size > vout->buffer_size) { | 696 | if (*size > vid_max_buf_size) { |
693 | v4l2_err(&vout->vid_dev->v4l2_dev, | 697 | v4l2_err(&vout->vid_dev->v4l2_dev, |
694 | "buffer allocation mismatch [%u] [%u]\n", | 698 | "buffer allocation mismatch [%u] [%u]\n", |
695 | *size, vout->buffer_size); | 699 | *size, vout->buffer_size); |