summaryrefslogtreecommitdiff
path: root/drivers/media
diff options
context:
space:
mode:
authorWayne Zou <b36644@freescale.com>2013-03-01 16:05:47 +0800
committerWayne Zou <b36644@freescale.com>2013-04-17 08:06:49 +0800
commit18059b6f37c7b19cf82bab2d99df62f0779bb300 (patch)
treee07080c58410b6cd94f8878ee5c5ce4ca8b9e803 /drivers/media
parent1864c456809a8f67b56078c7312e6cab60cbbc36 (diff)
ENGR00239959 V4L2 output: Fix video playback bug if pulling window out of screen
Add strict input parameters check for v4l2 output drivers. The part of window inside the display boundary is shown if pulling window out of screen. About this issue: video playback error if pulling window out of screen Using totem to play a video and using the mouse to pull the video window out of the screen, it will print the follow errors: imx-ipuv3 imx-ipuv3.0: ERR:[0xbad85200]-no:0x15c0 "wait_for_comp_timeo ut" ret:0,line:2768 imx-ipuv3 imx-ipuv3.0: ERR: [0xbad85200] no-0x15c0, timeout:1000ms! imx-ipuv3 imx-ipuv3.0: ERR: no-0x15c0,ipu_queue_task err:-110 mxc_v4l2_output mxc_v4l2_output.0: display work fail ret = -110 imx-ipuv3 imx-ipuv3.0: warning: disable ipu dma channel 21 during its busy state Signed-off-by: Wayne Zou <b36644@freescale.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/mxc/output/mxc_vout.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/media/video/mxc/output/mxc_vout.c b/drivers/media/video/mxc/output/mxc_vout.c
index 626bad59e151..727c07abaab9 100644
--- a/drivers/media/video/mxc/output/mxc_vout.c
+++ b/drivers/media/video/mxc/output/mxc_vout.c
@@ -1379,6 +1379,14 @@ static int mxc_vidioc_s_crop(struct file *file, void *fh,
/* stride line limitation */
crop->c.height -= crop->c.height % 8;
crop->c.width -= crop->c.width % 8;
+ if ((crop->c.width <= 0) || (crop->c.height <= 0) ||
+ ((crop->c.left + crop->c.width) > (b->left + b->width)) ||
+ ((crop->c.top + crop->c.height) > (b->top + b->height))) {
+ v4l2_err(vout->vfd->v4l2_dev, "s_crop err: %d, %d, %d, %d",
+ crop->c.left, crop->c.top,
+ crop->c.width, crop->c.height);
+ return -EINVAL;
+ }
/* the same setting, return */
if (vout->disp_support_windows) {