#define FRAME_TYPE_SWITCH (3)
#define OBU_TYPE_SEQUENCE_HEADER (1)
#define OBU_TYPE_FRAME_HEADER (3)
+#define OBU_TYPE_FRAME (6)
+#define AV1_MIN_QP_DEFAULT (1)
+#define AV1_MAX_QP_DEFAULT (255)
static unsigned av1_f(struct vl_vlc *vlc, unsigned n)
{
VAEncSequenceParameterBufferAV1 *av1 = buf->data;
if (!context->decoder) {
+ context->templat.max_references = PIPE_AV1_MAX_REFERENCES;
context->templat.level = av1->seq_level_idx;
context->decoder = drv->pipe->create_video_codec(drv->pipe, &context->templat);
context->desc.av1enc.seq.tier = av1->seq_tier;
context->desc.av1enc.seq.level = av1->seq_level_idx;
context->desc.av1enc.seq.intra_period = av1->intra_period;
+ context->desc.av1enc.seq.ip_period = av1->ip_period;
context->desc.av1enc.seq.bit_depth_minus8 = av1->seq_fields.bits.bit_depth_minus8;
context->desc.av1enc.seq.seq_bits.enable_cdef = av1->seq_fields.bits.enable_cdef;
context->desc.av1enc.seq.seq_bits.enable_order_hint = av1->seq_fields.bits.enable_order_hint;
context->desc.av1enc.allow_high_precision_mv = av1->picture_flags.bits.allow_high_precision_mv;
context->desc.av1enc.palette_mode_enable = av1->picture_flags.bits.palette_mode_enable;
context->desc.av1enc.num_tiles_in_pic = av1->tile_cols * av1->tile_rows;
+ context->desc.av1enc.tile_rows = av1->tile_rows;
+ context->desc.av1enc.tile_cols = av1->tile_cols;
+ context->desc.av1enc.context_update_tile_id = av1->context_update_tile_id;
+ context->desc.av1enc.use_superres = av1->picture_flags.bits.use_superres;
+ context->desc.av1enc.reduced_tx_set = av1->picture_flags.bits.reduced_tx_set;
+ context->desc.av1enc.skip_mode_present = av1->mode_control_flags.bits.skip_mode_present;
+ context->desc.av1enc.tx_mode = av1->mode_control_flags.bits.tx_mode;
+ context->desc.av1enc.compound_reference_mode = av1->mode_control_flags.bits.reference_mode;
+ context->desc.av1enc.superres_scale_denominator = av1->superres_scale_denominator;
+ context->desc.av1enc.interpolation_filter = av1->interpolation_filter;
+
+ /* The last tile column or row size needs to be derived. */
+ for (uint8_t i = 0 ; i < ARRAY_SIZE(av1->width_in_sbs_minus_1); i++)
+ context->desc.av1enc.width_in_sbs_minus_1[i] = av1->width_in_sbs_minus_1[i];
+
+ /* The last tile column or row size needs to be derived. */
+ for (uint8_t i = 0 ; i < ARRAY_SIZE(av1->height_in_sbs_minus_1); i++)
+ context->desc.av1enc.height_in_sbs_minus_1[i] = av1->height_in_sbs_minus_1[i];
+
+ context->desc.av1enc.cdef.cdef_damping_minus_3 = av1->cdef_damping_minus_3;
+ context->desc.av1enc.cdef.cdef_bits = av1->cdef_bits;
+
+ for (uint8_t i = 0 ; i < ARRAY_SIZE(av1->cdef_y_strengths); i++)
+ context->desc.av1enc.cdef.cdef_y_strengths[i] = av1->cdef_y_strengths[i];
+
+ for (uint8_t i = 0 ; i < ARRAY_SIZE(av1->cdef_uv_strengths); i++)
+ context->desc.av1enc.cdef.cdef_uv_strengths[i] = av1->cdef_uv_strengths[i];
+
+ context->desc.av1enc.loop_filter.filter_level[0] = av1->filter_level[0];
+ context->desc.av1enc.loop_filter.filter_level[1] = av1->filter_level[1];
+ context->desc.av1enc.loop_filter.filter_level_u = av1->filter_level_u;
+ context->desc.av1enc.loop_filter.filter_level_v = av1->filter_level_v;
+ context->desc.av1enc.loop_filter.sharpness_level = av1->loop_filter_flags.bits.sharpness_level;
+ context->desc.av1enc.loop_filter.mode_ref_delta_enabled = av1->loop_filter_flags.bits.mode_ref_delta_enabled;
+ context->desc.av1enc.loop_filter.mode_ref_delta_update = av1->loop_filter_flags.bits.mode_ref_delta_update;
+ context->desc.av1enc.loop_filter.delta_lf_present = av1->mode_control_flags.bits.delta_lf_present;
+ context->desc.av1enc.loop_filter.delta_lf_res = av1->mode_control_flags.bits.delta_lf_res;
+ context->desc.av1enc.loop_filter.delta_lf_multi = av1->mode_control_flags.bits.delta_lf_multi;
+
+ context->desc.av1enc.restoration.yframe_restoration_type = av1->loop_restoration_flags.bits.yframe_restoration_type;
+ context->desc.av1enc.restoration.cbframe_restoration_type = av1->loop_restoration_flags.bits.cbframe_restoration_type;
+ context->desc.av1enc.restoration.crframe_restoration_type = av1->loop_restoration_flags.bits.crframe_restoration_type;
+ context->desc.av1enc.restoration.lr_unit_shift = av1->loop_restoration_flags.bits.lr_unit_shift;
+ context->desc.av1enc.restoration.lr_uv_shift = av1->loop_restoration_flags.bits.lr_uv_shift;
+ context->desc.av1enc.quantization.base_qindex = av1->base_qindex;
+ context->desc.av1enc.quantization.y_dc_delta_q = av1->y_dc_delta_q;
+ context->desc.av1enc.quantization.u_dc_delta_q = av1->u_dc_delta_q;
+ context->desc.av1enc.quantization.u_ac_delta_q = av1->u_ac_delta_q;
+ context->desc.av1enc.quantization.v_dc_delta_q = av1->v_dc_delta_q;
+ context->desc.av1enc.quantization.v_ac_delta_q = av1->v_ac_delta_q;
+ context->desc.av1enc.quantization.min_base_qindex = av1->min_base_qindex;
+ context->desc.av1enc.quantization.max_base_qindex = av1->max_base_qindex;
+ context->desc.av1enc.quantization.using_qmatrix = av1->qmatrix_flags.bits.using_qmatrix;
+ context->desc.av1enc.quantization.qm_y = av1->qmatrix_flags.bits.qm_y;
+ context->desc.av1enc.quantization.qm_u = av1->qmatrix_flags.bits.qm_u;
+ context->desc.av1enc.quantization.qm_v = av1->qmatrix_flags.bits.qm_v;
+ context->desc.av1enc.quantization.delta_q_present = av1->mode_control_flags.bits.delta_q_present;
+ context->desc.av1enc.quantization.delta_q_res = av1->mode_control_flags.bits.delta_q_res;
+
+ /* VAEncWarpedMotionParamsAV1 wm[7]; */
+
+ context->desc.av1enc.tg_obu_header.obu_extension_flag = av1->tile_group_obu_hdr_info.bits.obu_extension_flag;
+ context->desc.av1enc.tg_obu_header.obu_has_size_field = av1->tile_group_obu_hdr_info.bits.obu_has_size_field;
+ context->desc.av1enc.tg_obu_header.obu_has_size_field = av1->tile_group_obu_hdr_info.bits.obu_has_size_field;
+ context->desc.av1enc.tg_obu_header.temporal_id = av1->tile_group_obu_hdr_info.bits.temporal_id;
+ context->desc.av1enc.tg_obu_header.spatial_id = av1->tile_group_obu_hdr_info.bits.spatial_id;
coded_buf = handle_table_get(drv->htab, av1->coded_buf);
if (!coded_buf)
for (i = 0; i < ARRAY_SIZE(context->desc.av1enc.rc); i++) {
context->desc.av1enc.rc[i].qp = av1->base_qindex ? av1->base_qindex : 60;
+ /* Distinguishes from the default params set for these values and app specific params passed down */
+ context->desc.av1enc.rc[i].app_requested_initial_qp = (av1->base_qindex != 0);
context->desc.av1enc.rc[i].min_qp = av1->min_base_qindex ? av1->min_base_qindex : 1;
context->desc.av1enc.rc[i].max_qp = av1->max_base_qindex ? av1->max_base_qindex : 255;
+ /* Distinguishes from the default params set for these values and app specific params passed down */
+ context->desc.av1enc.rc[i].app_requested_qp_range =
+ ((context->desc.av1enc.rc[i].max_qp != AV1_MAX_QP_DEFAULT) || (context->desc.av1enc.rc[i].min_qp != AV1_MIN_QP_DEFAULT));
}
/* these frame types will need to be seen as force type */
break;
};
+ if (context->desc.av1enc.frame_type == FRAME_TYPE_KEY_FRAME)
+ context->desc.av1enc.last_key_frame_num = context->desc.av1enc.frame_num;
+
+ for (uint8_t i = 0 ; i < ARRAY_SIZE(av1->ref_frame_idx); i++)
+ context->desc.av1enc.ref_frame_idx[i] = av1->ref_frame_idx[i];
+
+ /* Initialize slice descriptors for this picture */
+ context->desc.av1enc.num_tile_groups = 0;
+ memset(&context->desc.av1enc.tile_groups, 0, sizeof(context->desc.av1enc.tile_groups));
+
return VA_STATUS_SUCCESS;
}
pipe_rc->fill_data_enable = !(rc->rc_flags.bits.disable_bit_stuffing);
pipe_rc->skip_frame_enable = 0;/* !(rc->rc_flags.bits.disable_frame_skip); */
+
+ if (pipe_rc->rate_ctrl_method == PIPE_H2645_ENC_RATE_CONTROL_METHOD_QUALITY_VARIABLE)
+ pipe_rc->vbr_quality_factor = rc->quality_factor;
}
return VA_STATUS_SUCCESS;
if (ms->buffer_size) {
context->desc.av1enc.rc[0].vbv_buffer_size = ms->buffer_size;
context->desc.av1enc.rc[0].vbv_buf_lv = (ms->initial_buffer_fullness << 6 ) / ms->buffer_size;
+ context->desc.av1enc.rc[0].vbv_buf_initial_size = ms->initial_buffer_fullness;
+ /* Distinguishes from the default params set for these values in other
+ * functions and app specific params passed down via HRD buffer */
+ context->desc.av1enc.rc[0].app_requested_hrd_buffer = true;
}
return VA_STATUS_SUCCESS;
static void av1_color_config(vlVaContext *context, struct vl_vlc *vlc)
{
- unsigned high_bitdepth;
+ unsigned high_bitdepth = 0;
unsigned bit_depth = 8;
- unsigned mono_chrome;
+ unsigned mono_chrome = 0;
unsigned subsampling_x = 0, subsampling_y = 0;
struct pipe_av1_enc_seq_param *seq = &context->desc.av1enc.seq;
seq->delta_frame_id_length = av1_f(vlc, 4) + 2;
seq->additional_frame_id_length = av1_f(vlc, 3) + 1;
}
- av1_f(vlc, 1);
- av1_f(vlc, 1);
- av1_f(vlc, 1);
+ seq->seq_bits.use_128x128_superblock = av1_f(vlc, 1);
+ seq->seq_bits.enable_filter_intra = av1_f(vlc, 1);
+ seq->seq_bits.enable_intra_edge_filter = av1_f(vlc, 1);
/* reduced_still_pictuer_header should be zero */
- av1_f(vlc, 1);
- av1_f(vlc, 1);
- av1_f(vlc, 1);
- av1_f(vlc, 1);
+ seq->seq_bits.enable_interintra_compound = av1_f(vlc, 1);
+ seq->seq_bits.enable_masked_compound = av1_f(vlc, 1);
+ seq->seq_bits.enable_warped_motion = av1_f(vlc, 1);
+ seq->seq_bits.enable_dual_filter = av1_f(vlc, 1);
seq->seq_bits.enable_order_hint = av1_f(vlc, 1);
if (seq->seq_bits.enable_order_hint) {
- av1_f(vlc, 1);
+ seq->seq_bits.enable_jnt_comp = av1_f(vlc, 1);
seq->seq_bits.enable_ref_frame_mvs = av1_f(vlc, 1);
} else
seq->seq_bits.enable_ref_frame_mvs = 0;
seq->seq_bits.enable_superres = av1_f(vlc, 1);
seq->seq_bits.enable_cdef = av1_f(vlc, 1);
- av1_f(vlc, 1);
+ seq->seq_bits.enable_restoration = av1_f(vlc, 1);
av1_color_config(context, vlc);
}
if (av1->frame_size_override_flag) {
av1->frame_width = av1_f(vlc, av1->seq.frame_width_bits_minus1 + 1) + 1;
- av1_f(vlc, av1->seq.frame_height_bits_minus1 + 1);
- } else
+ av1->frame_height = av1_f(vlc, av1->seq.frame_height_bits_minus1 + 1) + 1;
+ } else {
av1->frame_width = av1->seq.pic_width_in_luma_samples;
+ av1->frame_height = av1->seq.pic_height_in_luma_samples;
+ }
+
+ unsigned MiCols = 2 * (((av1->frame_width - 1) + 8) >> 3);
+ unsigned MiRows = 2 * (((av1->frame_height - 1) + 8) >> 3);
+ context->desc.av1enc.frame_width_sb = (av1->seq.seq_bits.use_128x128_superblock) ?
+ ((MiCols + 31) >> 5) : ((MiCols + 15) >> 4);
+ context->desc.av1enc.frame_height_sb = (av1->seq.seq_bits.use_128x128_superblock) ?
+ ((MiRows + 31) >> 5) : ((MiRows + 15) >> 4);
av1_superres_params(context, vlc);
}
struct pipe_av1_enc_picture_desc *av1 = &context->desc.av1enc;
uint32_t frame_type;
uint32_t id_len, all_frames, show_frame;
- uint32_t refresh_frame_flags = 0;
bool frame_is_intra = false;
av1->frame_size_override_flag = av1_f(vlc, 1);
if (av1->seq.seq_bits.enable_order_hint)
- av1_f(vlc, av1->seq.order_hint_bits);
+ av1->order_hint = av1_f(vlc, av1->seq.order_hint_bits);
if (!(frame_is_intra || av1->error_resilient_mode))
- av1_f(vlc, 3);
+ av1->primary_ref_frame = av1_f(vlc, 3);
if (av1->seq.seq_bits.decoder_model_info_present_flag) {
unsigned buffer_removal_time_present_flag = av1_f(vlc, 1);
if (frame_type == FRAME_TYPE_SWITCH ||
(frame_type == FRAME_TYPE_KEY_FRAME && show_frame))
- refresh_frame_flags = all_frames;
+ av1->refresh_frame_flags = all_frames;
else
- refresh_frame_flags = av1_f(vlc, 8);
+ av1->refresh_frame_flags = av1_f(vlc, 8);
- if ( !frame_is_intra || refresh_frame_flags != all_frames) {
+ if ( !frame_is_intra || av1->refresh_frame_flags != all_frames) {
if (av1->error_resilient_mode && av1->seq.seq_bits.enable_order_hint)
for (int i = 0; i < AV1_MAXNUM_REF_FRAMES; i++)
av1_f(vlc, av1->seq.order_hint_bits);
av1_frame_size(context, vlc);
av1_render_size(context, vlc);
if (av1->allow_screen_content_tools && av1->upscaled_width == av1->frame_width)
- av1_f(vlc, 1);
+ av1->allow_intrabc = av1_f(vlc, 1);
} else {
unsigned frame_refs_short_signaling = 0;
if (av1->seq.seq_bits.enable_order_hint) {
for (int i = 0; i < 8 && vl_vlc_bits_left(&vlc) >= 8; ++i) {
/* then start decoding , first 5 bits has to be 0000 1xxx for sequence header */
obu_type = vl_vlc_peekbits(&vlc, 5);
- if (obu_type == OBU_TYPE_SEQUENCE_HEADER || obu_type == OBU_TYPE_FRAME_HEADER)
+ if (obu_type == OBU_TYPE_SEQUENCE_HEADER
+ || obu_type == OBU_TYPE_FRAME_HEADER
+ || obu_type == OBU_TYPE_FRAME)
break;
vl_vlc_eatbits(&vlc, 8);
vl_vlc_fillbits(&vlc);
if (obu_type == OBU_TYPE_SEQUENCE_HEADER)
av1_sequence_header(context, &vlc);
- else if (obu_type == OBU_TYPE_FRAME_HEADER)
+ else if (obu_type == OBU_TYPE_FRAME_HEADER || obu_type == OBU_TYPE_FRAME)
av1_frame_header(context, &vlc);
else
assert(0);
}
}
+VAStatus vlVaHandleVAEncSliceParameterBufferTypeAV1(vlVaDriver *drv, vlVaContext *context, vlVaBuffer *buf)
+{
+ VAEncTileGroupBufferAV1 *tile_buf = (VAEncTileGroupBufferAV1*) buf->data;
+
+ if (context->desc.av1enc.num_tile_groups < ARRAY_SIZE(context->desc.av1enc.tile_groups)) {
+ context->desc.av1enc.tile_groups[context->desc.av1enc.num_tile_groups].tile_group_start = tile_buf->tg_start;
+ context->desc.av1enc.tile_groups[context->desc.av1enc.num_tile_groups].tile_group_end = tile_buf->tg_end;
+ context->desc.av1enc.num_tile_groups++;
+ } else {
+ return VA_STATUS_ERROR_NOT_ENOUGH_BUFFER;
+ }
+
+ return VA_STATUS_SUCCESS;
+}
#endif /* VA_CHECK_VERSION(1, 16, 0) */
#endif
#define PIPE_H265_MAX_REFERENCES 15
+#define PIPE_AV1_MAX_REFERENCES 8
#define PIPE_DEFAULT_FRAME_RATE_DEN 1
#define PIPE_DEFAULT_FRAME_RATE_NUM 30
#define PIPE_DEFAULT_INTRA_IDR_PERIOD 30
unsigned frame_rate_den;
unsigned vbv_buffer_size;
unsigned vbv_buf_lv;
+ unsigned vbv_buf_initial_size;
+ bool app_requested_hrd_buffer;
unsigned target_bits_picture;
unsigned peak_bits_picture_integer;
unsigned peak_bits_picture_fraction;
unsigned skip_frame_enable;
unsigned enforce_hrd;
unsigned max_au_size;
- unsigned qp;
+ unsigned qp; /* Initial QP */
unsigned max_qp;
unsigned min_qp;
+ bool app_requested_qp_range;
+ bool app_requested_initial_qp;
+
+ /* Used with PIPE_H2645_ENC_RATE_CONTROL_METHOD_QUALITY_VARIABLE */
+ unsigned vbr_quality_factor;
};
struct pipe_av1_enc_decoder_model_info
uint32_t tier;
uint32_t num_temporal_layers;
uint32_t intra_period;
+ uint32_t ip_period;
uint32_t bit_depth_minus8;
uint32_t pic_width_in_luma_samples;
uint32_t pic_height_in_luma_samples;
struct
{
+ uint32_t use_128x128_superblock:1;
+ uint32_t enable_filter_intra :1;
+ uint32_t enable_intra_edge_filter :1;
+ uint32_t enable_interintra_compound :1;
+ uint32_t enable_masked_compound :1;
+ uint32_t enable_warped_motion :1;
+ uint32_t enable_dual_filter :1;
uint32_t enable_cdef:1;
+ uint32_t enable_restoration:1;
uint32_t enable_superres:1;
uint32_t enable_order_hint:1;
+ uint32_t enable_jnt_comp:1;
uint32_t color_description_present_flag:1;
uint32_t enable_ref_frame_mvs:1;
uint32_t frame_id_number_present_flag:1;
uint8_t decoder_model_present_for_this_op[32];
};
+struct pipe_av1_tile_group {
+ uint8_t tile_group_start;
+ uint8_t tile_group_end;
+};
+
struct pipe_av1_enc_picture_desc
{
struct pipe_picture_desc base;
uint32_t disable_cdf_update:1;
uint32_t frame_size_override_flag:1;
uint32_t allow_screen_content_tools:1;
+ uint32_t allow_intrabc:1;
uint32_t force_integer_mv:1;
uint32_t disable_frame_end_update_cdf:1;
uint32_t palette_mode_enable:1;
uint32_t use_ref_frame_mvs;
uint32_t show_existing_frame:1;
uint32_t enable_render_size:1;
+ uint32_t use_superres:1;
+ uint32_t reduced_tx_set:1;
+ uint32_t skip_mode_present:1;
};
struct pipe_enc_quality_modes quality_modes;
uint32_t num_tiles_in_pic; /* [1, 32], */
+ uint32_t tile_rows;
+ uint32_t tile_cols;
+ unsigned num_tile_groups;
+ struct pipe_av1_tile_group tile_groups[256];
+ uint32_t context_update_tile_id;
+ uint16_t width_in_sbs_minus_1[63];
+ uint16_t height_in_sbs_minus_1[63];
uint32_t frame_num;
+ uint32_t last_key_frame_num;
uint32_t number_of_skips;
uint32_t temporal_id;
uint32_t spatial_id;
uint16_t frame_width;
+ uint16_t frame_height;
+ uint16_t frame_width_sb;
+ uint16_t frame_height_sb;
uint16_t upscaled_width;
uint16_t render_width;
uint16_t render_height;
+ uint32_t interpolation_filter;
+ uint8_t tx_mode;
+ uint8_t compound_reference_mode;
+ uint32_t order_hint;
+ uint8_t superres_scale_denominator;
+ uint32_t primary_ref_frame;
+ uint8_t refresh_frame_flags;
+ uint8_t ref_frame_idx[7];
+
+ struct {
+ uint8_t cdef_damping_minus_3;
+ uint8_t cdef_bits;
+ uint8_t cdef_y_strengths[8];
+ uint8_t cdef_uv_strengths[8];
+ } cdef;
+
+ struct {
+ uint8_t yframe_restoration_type;
+ uint8_t cbframe_restoration_type;
+ uint8_t crframe_restoration_type;
+ uint8_t lr_unit_shift;
+ uint8_t lr_uv_shift;
+ } restoration;
+
+ struct {
+ uint8_t filter_level[2];
+ uint8_t filter_level_u;
+ uint8_t filter_level_v;
+ uint8_t sharpness_level;
+ uint8_t mode_ref_delta_enabled;
+ uint8_t mode_ref_delta_update;
+ int8_t ref_deltas[8];
+ int8_t mode_deltas[2];
+ uint8_t delta_lf_present;
+ uint8_t delta_lf_res;
+ uint8_t delta_lf_multi;
+ } loop_filter;
+
+ struct {
+ uint8_t base_qindex;
+ int8_t y_dc_delta_q;
+ int8_t u_dc_delta_q;
+ int8_t u_ac_delta_q;
+ int8_t v_dc_delta_q;
+ int8_t v_ac_delta_q;
+ uint8_t min_base_qindex;
+ uint8_t max_base_qindex;
+ uint8_t using_qmatrix;
+ uint8_t qm_y;
+ uint8_t qm_u;
+ uint8_t qm_v;
+ uint8_t delta_q_present;
+ uint8_t delta_q_res;
+ } quantization;
+
+ struct {
+ uint8_t obu_extension_flag;
+ uint8_t obu_has_size_field;
+ uint8_t temporal_id;
+ uint8_t spatial_id;
+ } tg_obu_header;
};
struct pipe_h265_sps