diff options
author | Guennadi Liakhovetski <g.liakhovetski@gmx.de> | 2009-03-13 05:08:20 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-03-30 11:43:21 -0400 |
commit | 09e231b35173313cd92e27532e5028f2042dcee4 (patch) | |
tree | 3ecda063aa52f954d2f797921bdce131d7f1cc28 /drivers/media/video/tw9910.c | |
parent | 1cd3c0fa927084549005fc22e54d99684b314f14 (diff) |
V4L/DVB (11024): soc-camera: separate S_FMT and S_CROP operations
As host and camera drivers become more complex, differences between S_FMT and
S_CROP functionality grow, this patch separates them.
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/tw9910.c')
-rw-r--r-- | drivers/media/video/tw9910.c | 45 |
1 files changed, 29 insertions, 16 deletions
diff --git a/drivers/media/video/tw9910.c b/drivers/media/video/tw9910.c index 0558b22fd3fb..a39947643992 100644 --- a/drivers/media/video/tw9910.c +++ b/drivers/media/video/tw9910.c | |||
@@ -641,25 +641,12 @@ static int tw9910_set_register(struct soc_camera_device *icd, | |||
641 | } | 641 | } |
642 | #endif | 642 | #endif |
643 | 643 | ||
644 | static int tw9910_set_fmt(struct soc_camera_device *icd, __u32 pixfmt, | 644 | static int tw9910_set_crop(struct soc_camera_device *icd, |
645 | struct v4l2_rect *rect) | 645 | struct v4l2_rect *rect) |
646 | { | 646 | { |
647 | struct tw9910_priv *priv = container_of(icd, struct tw9910_priv, icd); | 647 | struct tw9910_priv *priv = container_of(icd, struct tw9910_priv, icd); |
648 | int ret = -EINVAL; | 648 | int ret = -EINVAL; |
649 | u8 val; | 649 | u8 val; |
650 | int i; | ||
651 | |||
652 | /* | ||
653 | * check color format | ||
654 | */ | ||
655 | for (i = 0 ; i < ARRAY_SIZE(tw9910_color_fmt) ; i++) { | ||
656 | if (pixfmt == tw9910_color_fmt[i].fourcc) { | ||
657 | ret = 0; | ||
658 | break; | ||
659 | } | ||
660 | } | ||
661 | if (ret < 0) | ||
662 | goto tw9910_set_fmt_error; | ||
663 | 650 | ||
664 | /* | 651 | /* |
665 | * select suitable norm | 652 | * select suitable norm |
@@ -746,8 +733,33 @@ tw9910_set_fmt_error: | |||
746 | return ret; | 733 | return ret; |
747 | } | 734 | } |
748 | 735 | ||
736 | static int tw9910_set_fmt(struct soc_camera_device *icd, | ||
737 | struct v4l2_format *f) | ||
738 | { | ||
739 | struct v4l2_pix_format *pix = &f->fmt.pix; | ||
740 | struct v4l2_rect rect = { | ||
741 | .left = icd->x_current, | ||
742 | .top = icd->y_current, | ||
743 | .width = pix->width, | ||
744 | .height = pix->height, | ||
745 | }; | ||
746 | int i; | ||
747 | |||
748 | /* | ||
749 | * check color format | ||
750 | */ | ||
751 | for (i = 0; i < ARRAY_SIZE(tw9910_color_fmt); i++) | ||
752 | if (pix->pixelformat == tw9910_color_fmt[i].fourcc) | ||
753 | break; | ||
754 | |||
755 | if (i == ARRAY_SIZE(tw9910_color_fmt)) | ||
756 | return -EINVAL; | ||
757 | |||
758 | return tw9910_set_crop(icd, &rect); | ||
759 | } | ||
760 | |||
749 | static int tw9910_try_fmt(struct soc_camera_device *icd, | 761 | static int tw9910_try_fmt(struct soc_camera_device *icd, |
750 | struct v4l2_format *f) | 762 | struct v4l2_format *f) |
751 | { | 763 | { |
752 | struct v4l2_pix_format *pix = &f->fmt.pix; | 764 | struct v4l2_pix_format *pix = &f->fmt.pix; |
753 | const struct tw9910_scale_ctrl *scale; | 765 | const struct tw9910_scale_ctrl *scale; |
@@ -835,6 +847,7 @@ static struct soc_camera_ops tw9910_ops = { | |||
835 | .release = tw9910_release, | 847 | .release = tw9910_release, |
836 | .start_capture = tw9910_start_capture, | 848 | .start_capture = tw9910_start_capture, |
837 | .stop_capture = tw9910_stop_capture, | 849 | .stop_capture = tw9910_stop_capture, |
850 | .set_crop = tw9910_set_crop, | ||
838 | .set_fmt = tw9910_set_fmt, | 851 | .set_fmt = tw9910_set_fmt, |
839 | .try_fmt = tw9910_try_fmt, | 852 | .try_fmt = tw9910_try_fmt, |
840 | .set_bus_param = tw9910_set_bus_param, | 853 | .set_bus_param = tw9910_set_bus_param, |