23 #include <vdpau/vdpau.h>
43 VdpPictureInfoHEVC *
info = &pic_ctx->
info.hevc;
44 #ifdef VDP_YCBCR_FORMAT_Y_U_V_444
45 VdpPictureInfoHEVC444 *info2 = &pic_ctx->
info.hevc_444;
52 &
pps->scaling_list : &
sps->scaling_list;
57 info->chroma_format_idc =
sps->chroma_format_idc;
58 info->separate_colour_plane_flag =
sps->separate_colour_plane;
59 info->pic_width_in_luma_samples =
sps->width;
60 info->pic_height_in_luma_samples =
sps->height;
61 info->bit_depth_luma_minus8 =
sps->bit_depth - 8;
62 info->bit_depth_chroma_minus8 =
sps->bit_depth - 8;
63 info->log2_max_pic_order_cnt_lsb_minus4 =
sps->log2_max_poc_lsb - 4;
66 info->sps_max_dec_pic_buffering_minus1 =
sps->temporal_layer[
sps->max_sub_layers - 1].max_dec_pic_buffering - 1;
67 info->log2_min_luma_coding_block_size_minus3 =
sps->log2_min_cb_size - 3;
68 info->log2_diff_max_min_luma_coding_block_size =
sps->log2_diff_max_min_coding_block_size;
69 info->log2_min_transform_block_size_minus2 =
sps->log2_min_tb_size - 2;
70 info->log2_diff_max_min_transform_block_size =
sps->log2_max_trafo_size -
sps->log2_min_tb_size;
71 info->max_transform_hierarchy_depth_inter =
sps->max_transform_hierarchy_depth_inter;
72 info->max_transform_hierarchy_depth_intra =
sps->max_transform_hierarchy_depth_intra;
73 info->scaling_list_enabled_flag =
sps->scaling_list_enabled;
75 for (
size_t i = 0;
i < 6;
i++) {
76 for (
size_t j = 0; j < 16; j++) {
82 for (
size_t j = 0; j < 64; j++) {
93 info->ScalingList32x32[
i][j] = sl->
sl[3][
i * 3][
pos];
102 info->ScalingListDCCoeff32x32[
i] = sl->
sl_dc[1][
i * 3];
105 info->amp_enabled_flag =
sps->amp_enabled;
106 info->sample_adaptive_offset_enabled_flag =
sps->sao_enabled;
107 info->pcm_enabled_flag =
sps->pcm_enabled;
108 if (
info->pcm_enabled_flag) {
110 info->pcm_sample_bit_depth_luma_minus1 =
sps->pcm.bit_depth - 1;
112 info->pcm_sample_bit_depth_chroma_minus1 =
sps->pcm.bit_depth_chroma - 1;
114 info->log2_min_pcm_luma_coding_block_size_minus3 =
sps->pcm.log2_min_pcm_cb_size - 3;
116 info->log2_diff_max_min_pcm_luma_coding_block_size =
sps->pcm.log2_max_pcm_cb_size -
sps->pcm.log2_min_pcm_cb_size;
118 info->pcm_loop_filter_disabled_flag =
sps->pcm_loop_filter_disabled;
122 info->num_short_term_ref_pic_sets =
sps->nb_st_rps;
123 info->long_term_ref_pics_present_flag =
sps->long_term_ref_pics_present;
126 info->num_long_term_ref_pics_sps =
sps->num_long_term_ref_pics_sps;
127 info->sps_temporal_mvp_enabled_flag =
sps->temporal_mvp_enabled;
128 info->strong_intra_smoothing_enabled_flag =
sps->strong_intra_smoothing_enabled;
131 info->dependent_slice_segments_enabled_flag =
pps->dependent_slice_segments_enabled_flag;
132 info->output_flag_present_flag =
pps->output_flag_present_flag;
133 info->num_extra_slice_header_bits =
pps->num_extra_slice_header_bits;
134 info->sign_data_hiding_enabled_flag =
pps->sign_data_hiding_flag;
135 info->cabac_init_present_flag =
pps->cabac_init_present_flag;
136 info->num_ref_idx_l0_default_active_minus1 =
pps->num_ref_idx_l0_default_active - 1;
137 info->num_ref_idx_l1_default_active_minus1 =
pps->num_ref_idx_l1_default_active - 1;
138 info->init_qp_minus26 =
pps->pic_init_qp_minus26;
139 info->constrained_intra_pred_flag =
pps->constrained_intra_pred_flag;
140 info->transform_skip_enabled_flag =
pps->transform_skip_enabled_flag;
141 info->cu_qp_delta_enabled_flag =
pps->cu_qp_delta_enabled_flag;
143 info->diff_cu_qp_delta_depth =
pps->diff_cu_qp_delta_depth;
144 info->pps_cb_qp_offset =
pps->cb_qp_offset;
145 info->pps_cr_qp_offset =
pps->cr_qp_offset;
146 info->pps_slice_chroma_qp_offsets_present_flag =
pps->pic_slice_level_chroma_qp_offsets_present_flag;
147 info->weighted_pred_flag =
pps->weighted_pred_flag;
148 info->weighted_bipred_flag =
pps->weighted_bipred_flag;
149 info->transquant_bypass_enabled_flag =
pps->transquant_bypass_enable_flag;
150 info->tiles_enabled_flag =
pps->tiles_enabled_flag;
151 info->entropy_coding_sync_enabled_flag =
pps->entropy_coding_sync_enabled_flag;
152 if (
info->tiles_enabled_flag) {
154 info->num_tile_columns_minus1 =
pps->num_tile_columns - 1;
156 info->num_tile_rows_minus1 =
pps->num_tile_rows - 1;
158 info->uniform_spacing_flag =
pps->uniform_spacing_flag;
162 for (ssize_t
i = 0;
i <
pps->num_tile_columns;
i++) {
163 info->column_width_minus1[
i] =
pps->column_width[
i] - 1;
168 for (ssize_t
i = 0;
i <
pps->num_tile_rows;
i++) {
169 info->row_height_minus1[
i] =
pps->row_height[
i] - 1;
173 info->loop_filter_across_tiles_enabled_flag =
pps->loop_filter_across_tiles_enabled_flag;
175 info->pps_loop_filter_across_slices_enabled_flag =
pps->seq_loop_filter_across_slices_enabled_flag;
176 info->deblocking_filter_control_present_flag =
pps->deblocking_filter_control_present_flag;
179 info->deblocking_filter_override_enabled_flag =
pps->deblocking_filter_override_enabled_flag;
182 info->pps_deblocking_filter_disabled_flag =
pps->disable_dbf;
185 info->pps_beta_offset_div2 =
pps->beta_offset / 2;
188 info->pps_tc_offset_div2 =
pps->tc_offset / 2;
189 info->lists_modification_present_flag =
pps->lists_modification_present_flag;
190 info->log2_parallel_merge_level_minus2 =
pps->log2_parallel_merge_level - 2;
191 info->slice_segment_header_extension_present_flag =
pps->slice_header_extension_present_flag;
200 info->CurrRpsIdx =
sps->nb_st_rps;
202 for (
size_t i = 0;
i <
sps->nb_st_rps;
i++) {
204 info->CurrRpsIdx =
i;
233 info->CurrPicOrderCntVal =
h->poc;
236 for (
size_t i = 0;
i < 16;
i++) {
237 info->RefPics[
i] = VDP_INVALID_HANDLE;
238 info->PicOrderCntVal[
i] = 0;
239 info->IsLongTerm[
i] = 0;
247 "VDPAU only supports up to 16 references in the DPB. "
248 "This frame may not be decoded correctly.\n");
263 info->IsLongTerm[j] = 0;
270 if (
info->NumPocStCurrBefore > 8) {
272 "VDPAU only supports up to 8 references in StCurrBefore. "
273 "This frame may not be decoded correctly.\n");
274 info->NumPocStCurrBefore = 8;
279 if (
info->NumPocStCurrAfter > 8) {
281 "VDPAU only supports up to 8 references in StCurrAfter. "
282 "This frame may not be decoded correctly.\n");
283 info->NumPocStCurrAfter = 8;
288 if (
info->NumPocLtCurr > 8) {
290 "VDPAU only supports up to 8 references in LtCurr. "
291 "This frame may not be decoded correctly.\n");
292 info->NumPocLtCurr = 8;
301 for (
size_t k = 0; k < 16; k++) {
302 if (
id ==
info->RefPics[k]) {
303 info->RefPicSetStCurrBefore[j] = k;
324 for (
size_t k = 0; k < 16; k++) {
325 if (
id ==
info->RefPics[k]) {
326 info->RefPicSetStCurrAfter[j] = k;
342 for (ssize_t
i = 0, j = 0;
i <
h->rps[
LT_CURR].nb_refs;
i++) {
347 for (
size_t k = 0; k < 16; k++) {
348 if (
id ==
info->RefPics[k]) {
349 info->RefPicSetLtCurr[j] = k;
364 #ifdef VDP_YCBCR_FORMAT_Y_U_V_444
365 if (
sps->range_extension) {
366 info2->sps_range_extension_flag = 1;
367 info2->transformSkipRotationEnableFlag =
sps->transform_skip_rotation_enabled;
368 info2->transformSkipContextEnableFlag =
sps->transform_skip_context_enabled;
369 info2->implicitRdpcmEnableFlag =
sps->implicit_rdpcm_enabled;
370 info2->explicitRdpcmEnableFlag =
sps->explicit_rdpcm_enabled;
371 info2->extendedPrecisionProcessingFlag =
sps->extended_precision_processing;
372 info2->intraSmoothingDisabledFlag =
sps->intra_smoothing_disabled;
373 info2->highPrecisionOffsetsEnableFlag =
sps->high_precision_offsets_enabled;
374 info2->persistentRiceAdaptationEnableFlag =
sps->persistent_rice_adaptation_enabled;
375 info2->cabacBypassAlignmentEnableFlag =
sps->cabac_bypass_alignment_enabled;
377 info2->sps_range_extension_flag = 0;
379 if (
pps->pps_range_extensions_flag) {
380 info2->pps_range_extension_flag = 1;
381 info2->log2MaxTransformSkipSize =
pps->log2_max_transform_skip_block_size;
382 info2->crossComponentPredictionEnableFlag =
pps->cross_component_prediction_enabled_flag;
383 info2->chromaQpAdjustmentEnableFlag =
pps->chroma_qp_offset_list_enabled_flag;
384 info2->diffCuChromaQpAdjustmentDepth =
pps->diff_cu_chroma_qp_offset_depth;
385 info2->chromaQpAdjustmentTableSize =
pps->chroma_qp_offset_list_len_minus1 + 1;
386 info2->log2SaoOffsetScaleLuma =
pps->log2_sao_offset_scale_luma;
387 info2->log2SaoOffsetScaleChroma =
pps->log2_sao_offset_scale_chroma;
388 for (ssize_t
i = 0;
i < info2->chromaQpAdjustmentTableSize;
i++)
390 info2->cb_qp_adjustment[
i] =
pps->cb_qp_offset_list[
i];
391 info2->cr_qp_adjustment[
i] =
pps->cr_qp_offset_list[
i];
395 info2->pps_range_extension_flag = 0;
446 #define copy_field(name) h265_raw_ptl->general_ ## name = general_ptl->name
488 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN;
494 if (!strcmp(
profile->name,
"Main 12") ||
495 !strcmp(
profile->name,
"Main 12 Intra"))
496 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_12;
497 #ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444
498 else if (!strcmp(
profile->name,
"Main 4:4:4") ||
499 !strcmp(
profile->name,
"Main 4:4:4 Intra"))
500 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444;
502 #ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444_10
503 else if (!strcmp(
profile->name,
"Main 4:4:4 10") ||
504 !strcmp(
profile->name,
"Main 4:4:4 10 Intra"))
505 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_10;
506 else if (!strcmp(
profile->name,
"Main 4:4:4 12") ||
507 !strcmp(
profile->name,
"Main 4:4:4 12 Intra"))
508 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_12;
525 profile = VDP_DECODER_PROFILE_HEVC_MAIN;
528 profile = VDP_DECODER_PROFILE_HEVC_MAIN_10;
531 profile = VDP_DECODER_PROFILE_HEVC_MAIN_STILL;
546 .
p.
name =
"hevc_vdpau",