diff options
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/pvrusb2/pvrusb2-v4l2.c | 35 |
1 files changed, 11 insertions, 24 deletions
diff --git a/drivers/media/video/pvrusb2/pvrusb2-v4l2.c b/drivers/media/video/pvrusb2/pvrusb2-v4l2.c index 74b681aeda2f..e93e2aa81f30 100644 --- a/drivers/media/video/pvrusb2/pvrusb2-v4l2.c +++ b/drivers/media/video/pvrusb2/pvrusb2-v4l2.c | |||
@@ -434,12 +434,6 @@ static int pvr2_v4l2_do_ioctl(struct inode *inode, struct file *file, | |||
434 | vf->fmt.pix.width = val; | 434 | vf->fmt.pix.width = val; |
435 | val = 0; | 435 | val = 0; |
436 | pvr2_ctrl_get_value( | 436 | pvr2_ctrl_get_value( |
437 | pvr2_hdw_get_ctrl_by_id(hdw, | ||
438 | PVR2_CID_INTERLACE), | ||
439 | &val); | ||
440 | if (val) vf->fmt.pix.width /= 2; | ||
441 | val = 0; | ||
442 | pvr2_ctrl_get_value( | ||
443 | pvr2_hdw_get_ctrl_by_id(hdw,PVR2_CID_VRES), | 437 | pvr2_hdw_get_ctrl_by_id(hdw,PVR2_CID_VRES), |
444 | &val); | 438 | &val); |
445 | vf->fmt.pix.height = val; | 439 | vf->fmt.pix.height = val; |
@@ -466,25 +460,22 @@ static int pvr2_v4l2_do_ioctl(struct inode *inode, struct file *file, | |||
466 | case V4L2_BUF_TYPE_VIDEO_CAPTURE: { | 460 | case V4L2_BUF_TYPE_VIDEO_CAPTURE: { |
467 | int h = vf->fmt.pix.height; | 461 | int h = vf->fmt.pix.height; |
468 | int w = vf->fmt.pix.width; | 462 | int w = vf->fmt.pix.width; |
469 | int vd_std, hf, hh; | ||
470 | 463 | ||
471 | vd_std = 0; | 464 | if (h < 200) { |
472 | pvr2_ctrl_get_value( | 465 | h = 200; |
473 | pvr2_hdw_get_ctrl_by_id(hdw,PVR2_CID_STDCUR), | 466 | } else if (h > 625) { |
474 | &vd_std); | 467 | h = 625; |
475 | if (vd_std & V4L2_STD_525_60) { | 468 | } |
476 | hf=480; | 469 | if (w < 320) { |
477 | } else { | 470 | w = 320; |
478 | hf=576; | 471 | } else if (w > 720) { |
472 | w = 720; | ||
479 | } | 473 | } |
480 | hh = (int) (hf / 2); | ||
481 | 474 | ||
482 | memcpy(vf, &pvr_format[PVR_FORMAT_PIX], | 475 | memcpy(vf, &pvr_format[PVR_FORMAT_PIX], |
483 | sizeof(struct v4l2_format)); | 476 | sizeof(struct v4l2_format)); |
484 | if (w > 720) | 477 | vf->fmt.pix.width = w; |
485 | vf->fmt.pix.width = 720; | 478 | vf->fmt.pix.height = h; |
486 | vf->fmt.pix.width &= 0xff0; | ||
487 | vf->fmt.pix.height = (h > hh) ? hf : hh; | ||
488 | 479 | ||
489 | if (cmd == VIDIOC_S_FMT) { | 480 | if (cmd == VIDIOC_S_FMT) { |
490 | pvr2_ctrl_set_value( | 481 | pvr2_ctrl_set_value( |
@@ -495,10 +486,6 @@ static int pvr2_v4l2_do_ioctl(struct inode *inode, struct file *file, | |||
495 | pvr2_hdw_get_ctrl_by_id(hdw, | 486 | pvr2_hdw_get_ctrl_by_id(hdw, |
496 | PVR2_CID_VRES), | 487 | PVR2_CID_VRES), |
497 | vf->fmt.pix.height); | 488 | vf->fmt.pix.height); |
498 | pvr2_ctrl_set_value( | ||
499 | pvr2_hdw_get_ctrl_by_id( | ||
500 | hdw,PVR2_CID_INTERLACE), | ||
501 | vf->fmt.pix.height != hf); | ||
502 | } | 489 | } |
503 | } break; | 490 | } break; |
504 | case V4L2_BUF_TYPE_VBI_CAPTURE: | 491 | case V4L2_BUF_TYPE_VBI_CAPTURE: |