diff options
author | Hans Verkuil <hans.verkuil@cisco.com> | 2013-03-17 09:47:02 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2013-03-24 11:59:42 -0400 |
commit | 778ca511537da58d9154ab8e1c1f0d1bf738aec8 (patch) | |
tree | b1b69af965371a0a1867e93c96285401a0289fae | |
parent | 7e4bfb9ec0663d08bcd1c4d10bc13412b0f66d36 (diff) |
[media] go7007: add back 'repeat sequence header' control
But now as a proper standard MPEG control.
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r-- | drivers/staging/media/go7007/go7007-priv.h | 1 | ||||
-rw-r--r-- | drivers/staging/media/go7007/go7007-v4l2.c | 5 |
2 files changed, 5 insertions, 1 deletions
diff --git a/drivers/staging/media/go7007/go7007-priv.h b/drivers/staging/media/go7007/go7007-priv.h index 5f9b38955f40..cfa4c8474744 100644 --- a/drivers/staging/media/go7007/go7007-priv.h +++ b/drivers/staging/media/go7007/go7007-priv.h | |||
@@ -167,6 +167,7 @@ struct go7007 { | |||
167 | struct v4l2_ctrl *mpeg_video_bitrate; | 167 | struct v4l2_ctrl *mpeg_video_bitrate; |
168 | struct v4l2_ctrl *mpeg_video_aspect_ratio; | 168 | struct v4l2_ctrl *mpeg_video_aspect_ratio; |
169 | struct v4l2_ctrl *mpeg_video_b_frames; | 169 | struct v4l2_ctrl *mpeg_video_b_frames; |
170 | struct v4l2_ctrl *mpeg_video_rep_seqheader; | ||
170 | enum { STATUS_INIT, STATUS_ONLINE, STATUS_SHUTDOWN } status; | 171 | enum { STATUS_INIT, STATUS_ONLINE, STATUS_SHUTDOWN } status; |
171 | spinlock_t spinlock; | 172 | spinlock_t spinlock; |
172 | struct mutex hw_lock; | 173 | struct mutex hw_lock; |
diff --git a/drivers/staging/media/go7007/go7007-v4l2.c b/drivers/staging/media/go7007/go7007-v4l2.c index 0dc316063b5d..45be5189e944 100644 --- a/drivers/staging/media/go7007/go7007-v4l2.c +++ b/drivers/staging/media/go7007/go7007-v4l2.c | |||
@@ -163,6 +163,7 @@ static void set_formatting(struct go7007 *go) | |||
163 | go->closed_gop = v4l2_ctrl_g_ctrl(go->mpeg_video_gop_closure); | 163 | go->closed_gop = v4l2_ctrl_g_ctrl(go->mpeg_video_gop_closure); |
164 | go->ipb = v4l2_ctrl_g_ctrl(go->mpeg_video_b_frames) != 0; | 164 | go->ipb = v4l2_ctrl_g_ctrl(go->mpeg_video_b_frames) != 0; |
165 | go->bitrate = v4l2_ctrl_g_ctrl(go->mpeg_video_bitrate); | 165 | go->bitrate = v4l2_ctrl_g_ctrl(go->mpeg_video_bitrate); |
166 | go->repeat_seqhead = v4l2_ctrl_g_ctrl(go->mpeg_video_rep_seqheader); | ||
166 | go->gop_header_enable = 1; | 167 | go->gop_header_enable = 1; |
167 | go->dvd_mode = 0; | 168 | go->dvd_mode = 0; |
168 | if (go->format == V4L2_PIX_FMT_MPEG2) | 169 | if (go->format == V4L2_PIX_FMT_MPEG2) |
@@ -170,8 +171,8 @@ static void set_formatting(struct go7007 *go) | |||
170 | go->bitrate == 9800000 && | 171 | go->bitrate == 9800000 && |
171 | go->gop_size == 15 && | 172 | go->gop_size == 15 && |
172 | go->ipb == 0 && | 173 | go->ipb == 0 && |
174 | go->repeat_seqhead == 1 && | ||
173 | go->closed_gop; | 175 | go->closed_gop; |
174 | go->repeat_seqhead = go->dvd_mode; | ||
175 | 176 | ||
176 | switch (v4l2_ctrl_g_ctrl(go->mpeg_video_aspect_ratio)) { | 177 | switch (v4l2_ctrl_g_ctrl(go->mpeg_video_aspect_ratio)) { |
177 | default: | 178 | default: |
@@ -946,6 +947,8 @@ int go7007_v4l2_ctrl_init(struct go7007 *go) | |||
946 | 64000, 10000000, 1, 9800000); | 947 | 64000, 10000000, 1, 9800000); |
947 | go->mpeg_video_b_frames = v4l2_ctrl_new_std(hdl, NULL, | 948 | go->mpeg_video_b_frames = v4l2_ctrl_new_std(hdl, NULL, |
948 | V4L2_CID_MPEG_VIDEO_B_FRAMES, 0, 2, 2, 0); | 949 | V4L2_CID_MPEG_VIDEO_B_FRAMES, 0, 2, 2, 0); |
950 | go->mpeg_video_rep_seqheader = v4l2_ctrl_new_std(hdl, NULL, | ||
951 | V4L2_CID_MPEG_VIDEO_REPEAT_SEQ_HEADER, 0, 1, 1, 1); | ||
949 | 952 | ||
950 | go->mpeg_video_aspect_ratio = v4l2_ctrl_new_std_menu(hdl, NULL, | 953 | go->mpeg_video_aspect_ratio = v4l2_ctrl_new_std_menu(hdl, NULL, |
951 | V4L2_CID_MPEG_VIDEO_ASPECT, | 954 | V4L2_CID_MPEG_VIDEO_ASPECT, |