aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHans Verkuil <hans.verkuil@cisco.com>2013-03-17 09:47:02 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2013-03-24 11:59:42 -0400
commit778ca511537da58d9154ab8e1c1f0d1bf738aec8 (patch)
treeb1b69af965371a0a1867e93c96285401a0289fae
parent7e4bfb9ec0663d08bcd1c4d10bc13412b0f66d36 (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.h1
-rw-r--r--drivers/staging/media/go7007/go7007-v4l2.c5
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,