diff options
author | Kuninori Morimoto <morimoto.kuninori@renesas.com> | 2008-12-29 04:04:16 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2008-12-30 06:40:28 -0500 |
commit | 6d75611231fb22dbce0019310a9f3dc66918317e (patch) | |
tree | ed6228f933a614e5e5c963b31938c6f2bf2348ab /drivers/media/video | |
parent | ed922a892e535c14035210b5be328af1f49561c8 (diff) |
V4L/DVB (10095): The failure of set_fmt is solved in tw9910
priv->scale is checked in start_capture.
Therefore, it should be NULL if failing in set_fmt.
This patch resolve this problem.
Signed-off-by: Kuninori Morimoto <morimoto.kuninori@renesas.com>
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/tw9910.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/drivers/media/video/tw9910.c b/drivers/media/video/tw9910.c index 75cfde02d026..d5cdc4be1a35 100644 --- a/drivers/media/video/tw9910.c +++ b/drivers/media/video/tw9910.c | |||
@@ -651,7 +651,7 @@ static int tw9910_set_fmt(struct soc_camera_device *icd, __u32 pixfmt, | |||
651 | */ | 651 | */ |
652 | priv->scale = tw9910_select_norm(icd, rect->width, rect->height); | 652 | priv->scale = tw9910_select_norm(icd, rect->width, rect->height); |
653 | if (!priv->scale) | 653 | if (!priv->scale) |
654 | return ret; | 654 | goto tw9910_set_fmt_error; |
655 | 655 | ||
656 | /* | 656 | /* |
657 | * reset hardware | 657 | * reset hardware |
@@ -659,7 +659,8 @@ static int tw9910_set_fmt(struct soc_camera_device *icd, __u32 pixfmt, | |||
659 | tw9910_reset(priv->client); | 659 | tw9910_reset(priv->client); |
660 | ret = tw9910_write_array(priv->client, tw9910_default_regs); | 660 | ret = tw9910_write_array(priv->client, tw9910_default_regs); |
661 | if (ret < 0) | 661 | if (ret < 0) |
662 | return ret; | 662 | goto tw9910_set_fmt_error; |
663 | |||
663 | /* | 664 | /* |
664 | * set bus width | 665 | * set bus width |
665 | */ | 666 | */ |
@@ -669,7 +670,7 @@ static int tw9910_set_fmt(struct soc_camera_device *icd, __u32 pixfmt, | |||
669 | 670 | ||
670 | ret = tw9910_mask_set(priv->client, OPFORM, LEN, val); | 671 | ret = tw9910_mask_set(priv->client, OPFORM, LEN, val); |
671 | if (ret < 0) | 672 | if (ret < 0) |
672 | return ret; | 673 | goto tw9910_set_fmt_error; |
673 | 674 | ||
674 | /* | 675 | /* |
675 | * select MPOUT behavior | 676 | * select MPOUT behavior |
@@ -697,26 +698,35 @@ static int tw9910_set_fmt(struct soc_camera_device *icd, __u32 pixfmt, | |||
697 | 698 | ||
698 | ret = tw9910_mask_set(priv->client, VBICNTL, RTSEL_MASK, val); | 699 | ret = tw9910_mask_set(priv->client, VBICNTL, RTSEL_MASK, val); |
699 | if (ret < 0) | 700 | if (ret < 0) |
700 | return ret; | 701 | goto tw9910_set_fmt_error; |
701 | 702 | ||
702 | /* | 703 | /* |
703 | * set scale | 704 | * set scale |
704 | */ | 705 | */ |
705 | ret = tw9910_set_scale(priv->client, priv->scale); | 706 | ret = tw9910_set_scale(priv->client, priv->scale); |
706 | if (ret < 0) | 707 | if (ret < 0) |
707 | return ret; | 708 | goto tw9910_set_fmt_error; |
708 | 709 | ||
709 | /* | 710 | /* |
710 | * set cropping | 711 | * set cropping |
711 | */ | 712 | */ |
712 | ret = tw9910_set_cropping(priv->client, &tw9910_cropping_ctrl); | 713 | ret = tw9910_set_cropping(priv->client, &tw9910_cropping_ctrl); |
713 | if (ret < 0) | 714 | if (ret < 0) |
714 | return ret; | 715 | goto tw9910_set_fmt_error; |
715 | 716 | ||
716 | /* | 717 | /* |
717 | * set hsync | 718 | * set hsync |
718 | */ | 719 | */ |
719 | ret = tw9910_set_hsync(priv->client, &tw9910_hsync_ctrl); | 720 | ret = tw9910_set_hsync(priv->client, &tw9910_hsync_ctrl); |
721 | if (ret < 0) | ||
722 | goto tw9910_set_fmt_error; | ||
723 | |||
724 | return ret; | ||
725 | |||
726 | tw9910_set_fmt_error: | ||
727 | |||
728 | tw9910_reset(priv->client); | ||
729 | priv->scale = NULL; | ||
720 | 730 | ||
721 | return ret; | 731 | return ret; |
722 | } | 732 | } |