Commit d71f1222 authored by Michael Tretter's avatar Michael Tretter Committed by Mauro Carvalho Chehab

media: allegro: read bitrate mode directly from control

There is no need to copy the bitrate mode to a field in the channel and
the value can be read directly from the control.
Signed-off-by: default avatarMichael Tretter <m.tretter@pengutronix.de>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 80c8449f
...@@ -197,7 +197,6 @@ struct allegro_channel { ...@@ -197,7 +197,6 @@ struct allegro_channel {
unsigned int sizeimage_encoded; unsigned int sizeimage_encoded;
unsigned int csequence; unsigned int csequence;
enum v4l2_mpeg_video_bitrate_mode bitrate_mode;
bool frame_rc_enable; bool frame_rc_enable;
unsigned int bitrate; unsigned int bitrate;
unsigned int bitrate_peak; unsigned int bitrate_peak;
...@@ -1119,6 +1118,7 @@ static int allegro_mcu_send_create_channel(struct allegro_dev *dev, ...@@ -1119,6 +1118,7 @@ static int allegro_mcu_send_create_channel(struct allegro_dev *dev,
int i_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_i_frame_qp); int i_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_i_frame_qp);
int p_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_p_frame_qp); int p_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_p_frame_qp);
int b_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_b_frame_qp); int b_frame_qp = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_b_frame_qp);
int bitrate_mode = v4l2_ctrl_g_ctrl(channel->mpeg_video_bitrate_mode);
memset(&msg, 0, sizeof(msg)); memset(&msg, 0, sizeof(msg));
...@@ -1156,7 +1156,7 @@ static int allegro_mcu_send_create_channel(struct allegro_dev *dev, ...@@ -1156,7 +1156,7 @@ static int allegro_mcu_send_create_channel(struct allegro_dev *dev,
if (channel->frame_rc_enable) if (channel->frame_rc_enable)
msg.rate_control_mode = msg.rate_control_mode =
v4l2_bitrate_mode_to_mcu_mode(channel->bitrate_mode); v4l2_bitrate_mode_to_mcu_mode(bitrate_mode);
else else
msg.rate_control_mode = 0; msg.rate_control_mode = 0;
...@@ -2224,7 +2224,6 @@ static void allegro_set_default_params(struct allegro_channel *channel) ...@@ -2224,7 +2224,6 @@ static void allegro_set_default_params(struct allegro_channel *channel)
channel->sizeimage_encoded = channel->sizeimage_encoded =
estimate_stream_size(channel->width, channel->height); estimate_stream_size(channel->width, channel->height);
channel->bitrate_mode = V4L2_MPEG_VIDEO_BITRATE_MODE_CBR;
channel->bitrate = maximum_bitrate(channel->level); channel->bitrate = maximum_bitrate(channel->level);
channel->bitrate_peak = maximum_bitrate(channel->level); channel->bitrate_peak = maximum_bitrate(channel->level);
channel->cpb_size = maximum_cpb_size(channel->level); channel->cpb_size = maximum_cpb_size(channel->level);
...@@ -2422,9 +2421,6 @@ static int allegro_s_ctrl(struct v4l2_ctrl *ctrl) ...@@ -2422,9 +2421,6 @@ static int allegro_s_ctrl(struct v4l2_ctrl *ctrl)
case V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE: case V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE:
channel->frame_rc_enable = ctrl->val; channel->frame_rc_enable = ctrl->val;
break; break;
case V4L2_CID_MPEG_VIDEO_BITRATE_MODE:
channel->bitrate_mode = ctrl->val;
break;
case V4L2_CID_MPEG_VIDEO_BITRATE: case V4L2_CID_MPEG_VIDEO_BITRATE:
channel->bitrate = ctrl->val; channel->bitrate = ctrl->val;
break; break;
...@@ -2520,7 +2516,7 @@ static int allegro_open(struct file *file) ...@@ -2520,7 +2516,7 @@ static int allegro_open(struct file *file)
&allegro_ctrl_ops, &allegro_ctrl_ops,
V4L2_CID_MPEG_VIDEO_BITRATE_MODE, V4L2_CID_MPEG_VIDEO_BITRATE_MODE,
V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, 0, V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, 0,
channel->bitrate_mode); V4L2_MPEG_VIDEO_BITRATE_MODE_CBR);
channel->mpeg_video_bitrate = v4l2_ctrl_new_std(handler, channel->mpeg_video_bitrate = v4l2_ctrl_new_std(handler,
&allegro_ctrl_ops, &allegro_ctrl_ops,
V4L2_CID_MPEG_VIDEO_BITRATE, V4L2_CID_MPEG_VIDEO_BITRATE,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment