diff options
-rw-r--r-- | drivers/media/video/tvp7002.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/drivers/media/video/tvp7002.c b/drivers/media/video/tvp7002.c index 48f5c76ab521..45eb19fca078 100644 --- a/drivers/media/video/tvp7002.c +++ b/drivers/media/video/tvp7002.c | |||
@@ -695,6 +695,37 @@ static int tvp7002_queryctrl(struct v4l2_subdev *sd, struct v4l2_queryctrl *qc) | |||
695 | } | 695 | } |
696 | 696 | ||
697 | /* | 697 | /* |
698 | * tvp7002_mbus_fmt() - V4L2 decoder interface handler for try/s/g_mbus_fmt | ||
699 | * @sd: pointer to standard V4L2 sub-device structure | ||
700 | * @f: pointer to mediabus format structure | ||
701 | * | ||
702 | * Negotiate the image capture size and mediabus format. | ||
703 | * There is only one possible format, so this single function works for | ||
704 | * get, set and try. | ||
705 | */ | ||
706 | static int tvp7002_mbus_fmt(struct v4l2_subdev *sd, struct v4l2_mbus_framefmt *f) | ||
707 | { | ||
708 | struct tvp7002 *device = to_tvp7002(sd); | ||
709 | struct v4l2_dv_enum_preset e_preset; | ||
710 | int error; | ||
711 | |||
712 | /* Calculate height and width based on current standard */ | ||
713 | error = v4l_fill_dv_preset_info(device->current_preset->preset, &e_preset); | ||
714 | if (error) | ||
715 | return error; | ||
716 | |||
717 | f->width = e_preset.width; | ||
718 | f->height = e_preset.height; | ||
719 | f->code = V4L2_MBUS_FMT_YUYV10_1X20; | ||
720 | f->field = device->current_preset->scanmode; | ||
721 | f->colorspace = device->current_preset->color_space; | ||
722 | |||
723 | v4l2_dbg(1, debug, sd, "MBUS_FMT: Width - %d, Height - %d", | ||
724 | f->width, f->height); | ||
725 | return 0; | ||
726 | } | ||
727 | |||
728 | /* | ||
698 | * tvp7002_try_fmt_cap() - V4L2 decoder interface handler for try_fmt | 729 | * tvp7002_try_fmt_cap() - V4L2 decoder interface handler for try_fmt |
699 | * @sd: pointer to standard V4L2 sub-device structure | 730 | * @sd: pointer to standard V4L2 sub-device structure |
700 | * @f: pointer to standard V4L2 VIDIOC_TRY_FMT ioctl structure | 731 | * @f: pointer to standard V4L2 VIDIOC_TRY_FMT ioctl structure |
@@ -913,6 +944,25 @@ static int tvp7002_enum_fmt(struct v4l2_subdev *sd, | |||
913 | } | 944 | } |
914 | 945 | ||
915 | /* | 946 | /* |
947 | * tvp7002_enum_mbus_fmt() - Enum supported mediabus formats | ||
948 | * @sd: pointer to standard V4L2 sub-device structure | ||
949 | * @index: format index | ||
950 | * @code: pointer to mediabus format | ||
951 | * | ||
952 | * Enumerate supported mediabus formats. | ||
953 | */ | ||
954 | |||
955 | static int tvp7002_enum_mbus_fmt(struct v4l2_subdev *sd, unsigned index, | ||
956 | enum v4l2_mbus_pixelcode *code) | ||
957 | { | ||
958 | /* Check requested format index is within range */ | ||
959 | if (index) | ||
960 | return -EINVAL; | ||
961 | *code = V4L2_MBUS_FMT_YUYV10_1X20; | ||
962 | return 0; | ||
963 | } | ||
964 | |||
965 | /* | ||
916 | * tvp7002_s_stream() - V4L2 decoder i/f handler for s_stream | 966 | * tvp7002_s_stream() - V4L2 decoder i/f handler for s_stream |
917 | * @sd: pointer to standard V4L2 sub-device structure | 967 | * @sd: pointer to standard V4L2 sub-device structure |
918 | * @enable: streaming enable or disable | 968 | * @enable: streaming enable or disable |
@@ -1030,6 +1080,10 @@ static const struct v4l2_subdev_video_ops tvp7002_video_ops = { | |||
1030 | .g_fmt = tvp7002_g_fmt, | 1080 | .g_fmt = tvp7002_g_fmt, |
1031 | .s_fmt = tvp7002_s_fmt, | 1081 | .s_fmt = tvp7002_s_fmt, |
1032 | .enum_fmt = tvp7002_enum_fmt, | 1082 | .enum_fmt = tvp7002_enum_fmt, |
1083 | .g_mbus_fmt = tvp7002_mbus_fmt, | ||
1084 | .try_mbus_fmt = tvp7002_mbus_fmt, | ||
1085 | .s_mbus_fmt = tvp7002_mbus_fmt, | ||
1086 | .enum_mbus_fmt = tvp7002_enum_mbus_fmt, | ||
1033 | }; | 1087 | }; |
1034 | 1088 | ||
1035 | /* V4L2 top level operation handlers */ | 1089 | /* V4L2 top level operation handlers */ |