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

media: allegro: move encoding options to channel

There are several encoding options that are hard coded in the parameter
that is used to configure the hardware codec. However, some of the
options must be written to the SPS/PPS by the driver. Furthermore, some
of the options depend on the codec that is used (i.e. H.264 or HEVC).

Therefore, move options that depend on the codec to the channel and add
constants for options that are independent of the codec but must be
written to the SPS/PPS.
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 d2a1b58f
...@@ -94,6 +94,12 @@ ...@@ -94,6 +94,12 @@
#define SIZE_MACROBLOCK 16 #define SIZE_MACROBLOCK 16
/* Encoding options */
#define LOG2_MAX_FRAME_NUM 4
#define LOG2_MAX_PIC_ORDER_CNT 10
#define BETA_OFFSET_DIV_2 -1
#define TC_OFFSET_DIV_2 -1
static int debug; static int debug;
module_param(debug, int, 0644); module_param(debug, int, 0644);
MODULE_PARM_DESC(debug, "Debug level (0-2)"); MODULE_PARM_DESC(debug, "Debug level (0-2)");
...@@ -202,9 +208,30 @@ struct allegro_channel { ...@@ -202,9 +208,30 @@ struct allegro_channel {
struct allegro_buffer config_blob; struct allegro_buffer config_blob;
unsigned int log2_max_frame_num;
bool temporal_mvp_enable;
bool enable_loop_filter_across_tiles;
bool enable_loop_filter_across_slices;
bool dbf_ovr_en;
unsigned int num_ref_idx_l0; unsigned int num_ref_idx_l0;
unsigned int num_ref_idx_l1; unsigned int num_ref_idx_l1;
/* Maximum range for motion estimation */
int b_hrz_me_range;
int b_vrt_me_range;
int p_hrz_me_range;
int p_vrt_me_range;
/* Size limits of coding unit */
int min_cu_size;
int max_cu_size;
/* Size limits of transform unit */
int min_tu_size;
int max_tu_size;
int max_transfo_depth_intra;
int max_transfo_depth_inter;
struct v4l2_ctrl *mpeg_video_h264_profile; struct v4l2_ctrl *mpeg_video_h264_profile;
struct v4l2_ctrl *mpeg_video_h264_level; struct v4l2_ctrl *mpeg_video_h264_level;
struct v4l2_ctrl *mpeg_video_h264_i_frame_qp; struct v4l2_ctrl *mpeg_video_h264_i_frame_qp;
...@@ -911,32 +938,32 @@ static int fill_create_channel_param(struct allegro_channel *channel, ...@@ -911,32 +938,32 @@ static int fill_create_channel_param(struct allegro_channel *channel,
param->level = v4l2_level_to_mcu_level(channel->level); param->level = v4l2_level_to_mcu_level(channel->level);
param->tier = 0; param->tier = 0;
param->log2_max_poc = 10; param->log2_max_poc = LOG2_MAX_PIC_ORDER_CNT;
param->log2_max_frame_num = 4; param->log2_max_frame_num = channel->log2_max_frame_num;
param->temporal_mvp_enable = 1; param->temporal_mvp_enable = channel->temporal_mvp_enable;
param->dbf_ovr_en = 1; param->dbf_ovr_en = channel->dbf_ovr_en;
param->rdo_cost_mode = 1; param->rdo_cost_mode = 1;
param->custom_lda = 1; param->custom_lda = 1;
param->lf = 1; param->lf = 1;
param->lf_x_tile = 1; param->lf_x_tile = channel->enable_loop_filter_across_tiles;
param->lf_x_slice = 1; param->lf_x_slice = channel->enable_loop_filter_across_slices;
param->src_bit_depth = 8; param->src_bit_depth = 8;
param->beta_offset = -1; param->beta_offset = BETA_OFFSET_DIV_2;
param->tc_offset = -1; param->tc_offset = TC_OFFSET_DIV_2;
param->num_slices = 1; param->num_slices = 1;
param->me_range[0] = 8; param->me_range[0] = channel->b_hrz_me_range;
param->me_range[1] = 8; param->me_range[1] = channel->b_vrt_me_range;
param->me_range[2] = 16; param->me_range[2] = channel->p_hrz_me_range;
param->me_range[3] = 16; param->me_range[3] = channel->p_vrt_me_range;
param->max_cu_size = ilog2(SIZE_MACROBLOCK); param->max_cu_size = channel->max_cu_size;
param->min_cu_size = ilog2(8); param->min_cu_size = channel->min_cu_size;
param->max_tu_size = 2; param->max_tu_size = channel->max_tu_size;
param->min_tu_size = 2; param->min_tu_size = channel->min_tu_size;
param->max_transfo_depth_intra = 1; param->max_transfo_depth_intra = channel->max_transfo_depth_intra;
param->max_transfo_depth_inter = 1; param->max_transfo_depth_inter = channel->max_transfo_depth_inter;
param->prefetch_auto = 0; param->prefetch_auto = 0;
param->prefetch_mem_offset = 0; param->prefetch_mem_offset = 0;
...@@ -1266,9 +1293,9 @@ static ssize_t allegro_h264_write_sps(struct allegro_channel *channel, ...@@ -1266,9 +1293,9 @@ static ssize_t allegro_h264_write_sps(struct allegro_channel *channel,
sps->constraint_set5_flag = 0; sps->constraint_set5_flag = 0;
sps->level_idc = nal_h264_level_from_v4l2(channel->level); sps->level_idc = nal_h264_level_from_v4l2(channel->level);
sps->seq_parameter_set_id = 0; sps->seq_parameter_set_id = 0;
sps->log2_max_frame_num_minus4 = 0; sps->log2_max_frame_num_minus4 = LOG2_MAX_FRAME_NUM - 4;
sps->pic_order_cnt_type = 0; sps->pic_order_cnt_type = 0;
sps->log2_max_pic_order_cnt_lsb_minus4 = 6; sps->log2_max_pic_order_cnt_lsb_minus4 = LOG2_MAX_PIC_ORDER_CNT - 4;
sps->max_num_ref_frames = 3; sps->max_num_ref_frames = 3;
sps->gaps_in_frame_num_value_allowed_flag = 0; sps->gaps_in_frame_num_value_allowed_flag = 0;
sps->pic_width_in_mbs_minus1 = sps->pic_width_in_mbs_minus1 =
...@@ -2065,6 +2092,24 @@ static void allegro_channel_adjust(struct allegro_channel *channel) ...@@ -2065,6 +2092,24 @@ static void allegro_channel_adjust(struct allegro_channel *channel)
__v4l2_ctrl_modify_range(ctrl, ctrl->minimum, max, __v4l2_ctrl_modify_range(ctrl, ctrl->minimum, max,
ctrl->step, ctrl->default_value); ctrl->step, ctrl->default_value);
v4l2_ctrl_unlock(ctrl); v4l2_ctrl_unlock(ctrl);
channel->log2_max_frame_num = LOG2_MAX_FRAME_NUM;
channel->temporal_mvp_enable = true;
channel->dbf_ovr_en = true;
channel->enable_loop_filter_across_tiles = true;
channel->enable_loop_filter_across_slices = true;
channel->b_hrz_me_range = 8;
channel->b_vrt_me_range = 8;
channel->p_hrz_me_range = 16;
channel->p_vrt_me_range = 16;
channel->max_cu_size = ilog2(16);
channel->min_cu_size = ilog2(8);
channel->max_tu_size = ilog2(4);
channel->min_tu_size = ilog2(4);
channel->max_transfo_depth_intra = 1;
channel->max_transfo_depth_inter = 1;
} }
static void allegro_set_default_params(struct allegro_channel *channel) static void allegro_set_default_params(struct allegro_channel *channel)
......
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