23 #include <vdpau/vdpau.h>
42 VdpPictureInfoHEVC *
info = &pic_ctx->
info.hevc;
43 #ifdef VDP_YCBCR_FORMAT_Y_U_V_444
44 VdpPictureInfoHEVC444 *info2 = &pic_ctx->
info.hevc_444;
51 &
pps->scaling_list : &
sps->scaling_list;
56 info->chroma_format_idc =
sps->chroma_format_idc;
57 info->separate_colour_plane_flag =
sps->separate_colour_plane_flag;
58 info->pic_width_in_luma_samples =
sps->width;
59 info->pic_height_in_luma_samples =
sps->height;
60 info->bit_depth_luma_minus8 =
sps->bit_depth - 8;
61 info->bit_depth_chroma_minus8 =
sps->bit_depth - 8;
62 info->log2_max_pic_order_cnt_lsb_minus4 =
sps->log2_max_poc_lsb - 4;
65 info->sps_max_dec_pic_buffering_minus1 =
sps->temporal_layer[
sps->max_sub_layers - 1].max_dec_pic_buffering - 1;
66 info->log2_min_luma_coding_block_size_minus3 =
sps->log2_min_cb_size - 3;
67 info->log2_diff_max_min_luma_coding_block_size =
sps->log2_diff_max_min_coding_block_size;
68 info->log2_min_transform_block_size_minus2 =
sps->log2_min_tb_size - 2;
69 info->log2_diff_max_min_transform_block_size =
sps->log2_max_trafo_size -
sps->log2_min_tb_size;
70 info->max_transform_hierarchy_depth_inter =
sps->max_transform_hierarchy_depth_inter;
71 info->max_transform_hierarchy_depth_intra =
sps->max_transform_hierarchy_depth_intra;
72 info->scaling_list_enabled_flag =
sps->scaling_list_enable_flag;
74 for (
size_t i = 0;
i < 6;
i++) {
75 for (
size_t j = 0; j < 16; j++) {
81 for (
size_t j = 0; j < 64; j++) {
92 info->ScalingList32x32[
i][j] = sl->
sl[3][
i * 3][
pos];
101 info->ScalingListDCCoeff32x32[
i] = sl->
sl_dc[1][
i * 3];
104 info->amp_enabled_flag =
sps->amp_enabled_flag;
105 info->sample_adaptive_offset_enabled_flag =
sps->sao_enabled;
106 info->pcm_enabled_flag =
sps->pcm_enabled_flag;
107 if (
info->pcm_enabled_flag) {
109 info->pcm_sample_bit_depth_luma_minus1 =
sps->pcm.bit_depth - 1;
111 info->pcm_sample_bit_depth_chroma_minus1 =
sps->pcm.bit_depth_chroma - 1;
113 info->log2_min_pcm_luma_coding_block_size_minus3 =
sps->pcm.log2_min_pcm_cb_size - 3;
115 info->log2_diff_max_min_pcm_luma_coding_block_size =
sps->pcm.log2_max_pcm_cb_size -
sps->pcm.log2_min_pcm_cb_size;
117 info->pcm_loop_filter_disabled_flag =
sps->pcm.loop_filter_disable_flag;
121 info->num_short_term_ref_pic_sets =
sps->nb_st_rps;
122 info->long_term_ref_pics_present_flag =
sps->long_term_ref_pics_present_flag;
125 info->num_long_term_ref_pics_sps =
sps->num_long_term_ref_pics_sps;
126 info->sps_temporal_mvp_enabled_flag =
sps->sps_temporal_mvp_enabled_flag;
127 info->strong_intra_smoothing_enabled_flag =
sps->sps_strong_intra_smoothing_enable_flag;
130 info->dependent_slice_segments_enabled_flag =
pps->dependent_slice_segments_enabled_flag;
131 info->output_flag_present_flag =
pps->output_flag_present_flag;
132 info->num_extra_slice_header_bits =
pps->num_extra_slice_header_bits;
133 info->sign_data_hiding_enabled_flag =
pps->sign_data_hiding_flag;
134 info->cabac_init_present_flag =
pps->cabac_init_present_flag;
135 info->num_ref_idx_l0_default_active_minus1 =
pps->num_ref_idx_l0_default_active - 1;
136 info->num_ref_idx_l1_default_active_minus1 =
pps->num_ref_idx_l1_default_active - 1;
137 info->init_qp_minus26 =
pps->pic_init_qp_minus26;
138 info->constrained_intra_pred_flag =
pps->constrained_intra_pred_flag;
139 info->transform_skip_enabled_flag =
pps->transform_skip_enabled_flag;
140 info->cu_qp_delta_enabled_flag =
pps->cu_qp_delta_enabled_flag;
142 info->diff_cu_qp_delta_depth =
pps->diff_cu_qp_delta_depth;
143 info->pps_cb_qp_offset =
pps->cb_qp_offset;
144 info->pps_cr_qp_offset =
pps->cr_qp_offset;
145 info->pps_slice_chroma_qp_offsets_present_flag =
pps->pic_slice_level_chroma_qp_offsets_present_flag;
146 info->weighted_pred_flag =
pps->weighted_pred_flag;
147 info->weighted_bipred_flag =
pps->weighted_bipred_flag;
148 info->transquant_bypass_enabled_flag =
pps->transquant_bypass_enable_flag;
149 info->tiles_enabled_flag =
pps->tiles_enabled_flag;
150 info->entropy_coding_sync_enabled_flag =
pps->entropy_coding_sync_enabled_flag;
151 if (
info->tiles_enabled_flag) {
153 info->num_tile_columns_minus1 =
pps->num_tile_columns - 1;
155 info->num_tile_rows_minus1 =
pps->num_tile_rows - 1;
157 info->uniform_spacing_flag =
pps->uniform_spacing_flag;
161 for (ssize_t
i = 0;
i <
pps->num_tile_columns;
i++) {
162 info->column_width_minus1[
i] =
pps->column_width[
i] - 1;
167 for (ssize_t
i = 0;
i <
pps->num_tile_rows;
i++) {
168 info->row_height_minus1[
i] =
pps->row_height[
i] - 1;
172 info->loop_filter_across_tiles_enabled_flag =
pps->loop_filter_across_tiles_enabled_flag;
174 info->pps_loop_filter_across_slices_enabled_flag =
pps->seq_loop_filter_across_slices_enabled_flag;
175 info->deblocking_filter_control_present_flag =
pps->deblocking_filter_control_present_flag;
178 info->deblocking_filter_override_enabled_flag =
pps->deblocking_filter_override_enabled_flag;
181 info->pps_deblocking_filter_disabled_flag =
pps->disable_dbf;
184 info->pps_beta_offset_div2 =
pps->beta_offset / 2;
187 info->pps_tc_offset_div2 =
pps->tc_offset / 2;
188 info->lists_modification_present_flag =
pps->lists_modification_present_flag;
189 info->log2_parallel_merge_level_minus2 =
pps->log2_parallel_merge_level - 2;
190 info->slice_segment_header_extension_present_flag =
pps->slice_header_extension_present_flag;
199 info->CurrRpsIdx =
sps->nb_st_rps;
201 for (
size_t i = 0;
i <
sps->nb_st_rps;
i++) {
203 info->CurrRpsIdx =
i;
232 info->CurrPicOrderCntVal =
h->poc;
235 for (
size_t i = 0;
i < 16;
i++) {
236 info->RefPics[
i] = VDP_INVALID_HANDLE;
237 info->PicOrderCntVal[
i] = 0;
238 info->IsLongTerm[
i] = 0;
246 "VDPAU only supports up to 16 references in the DPB. "
247 "This frame may not be decoded correctly.\n");
262 info->IsLongTerm[j] = 0;
269 if (
info->NumPocStCurrBefore > 8) {
271 "VDPAU only supports up to 8 references in StCurrBefore. "
272 "This frame may not be decoded correctly.\n");
273 info->NumPocStCurrBefore = 8;
278 if (
info->NumPocStCurrAfter > 8) {
280 "VDPAU only supports up to 8 references in StCurrAfter. "
281 "This frame may not be decoded correctly.\n");
282 info->NumPocStCurrAfter = 8;
287 if (
info->NumPocLtCurr > 8) {
289 "VDPAU only supports up to 8 references in LtCurr. "
290 "This frame may not be decoded correctly.\n");
291 info->NumPocLtCurr = 8;
300 for (
size_t k = 0; k < 16; k++) {
301 if (
id ==
info->RefPics[k]) {
302 info->RefPicSetStCurrBefore[j] = k;
323 for (
size_t k = 0; k < 16; k++) {
324 if (
id ==
info->RefPics[k]) {
325 info->RefPicSetStCurrAfter[j] = k;
341 for (ssize_t
i = 0, j = 0;
i <
h->rps[
LT_CURR].nb_refs;
i++) {
346 for (
size_t k = 0; k < 16; k++) {
347 if (
id ==
info->RefPics[k]) {
348 info->RefPicSetLtCurr[j] = k;
363 #ifdef VDP_YCBCR_FORMAT_Y_U_V_444
364 if (
sps->sps_range_extension_flag) {
365 info2->sps_range_extension_flag = 1;
366 info2->transformSkipRotationEnableFlag =
sps->transform_skip_rotation_enabled_flag;
367 info2->transformSkipContextEnableFlag =
sps->transform_skip_context_enabled_flag;
368 info2->implicitRdpcmEnableFlag =
sps->implicit_rdpcm_enabled_flag;
369 info2->explicitRdpcmEnableFlag =
sps->explicit_rdpcm_enabled_flag;
370 info2->extendedPrecisionProcessingFlag =
sps->extended_precision_processing_flag;
371 info2->intraSmoothingDisabledFlag =
sps->intra_smoothing_disabled_flag;
372 info2->highPrecisionOffsetsEnableFlag =
sps->high_precision_offsets_enabled_flag;
373 info2->persistentRiceAdaptationEnableFlag =
sps->persistent_rice_adaptation_enabled_flag;
374 info2->cabacBypassAlignmentEnableFlag =
sps->cabac_bypass_alignment_enabled_flag;
376 info2->sps_range_extension_flag = 0;
378 if (
pps->pps_range_extensions_flag) {
379 info2->pps_range_extension_flag = 1;
380 info2->log2MaxTransformSkipSize =
pps->log2_max_transform_skip_block_size;
381 info2->crossComponentPredictionEnableFlag =
pps->cross_component_prediction_enabled_flag;
382 info2->chromaQpAdjustmentEnableFlag =
pps->chroma_qp_offset_list_enabled_flag;
383 info2->diffCuChromaQpAdjustmentDepth =
pps->diff_cu_chroma_qp_offset_depth;
384 info2->chromaQpAdjustmentTableSize =
pps->chroma_qp_offset_list_len_minus1 + 1;
385 info2->log2SaoOffsetScaleLuma =
pps->log2_sao_offset_scale_luma;
386 info2->log2SaoOffsetScaleChroma =
pps->log2_sao_offset_scale_chroma;
387 for (ssize_t
i = 0;
i < info2->chromaQpAdjustmentTableSize;
i++)
389 info2->cb_qp_adjustment[
i] =
pps->cb_qp_offset_list[
i];
390 info2->cr_qp_adjustment[
i] =
pps->cr_qp_offset_list[
i];
394 info2->pps_range_extension_flag = 0;
445 #define copy_field(name) h265_raw_ptl->general_ ## name = general_ptl->name
487 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN;
493 if (!strcmp(
profile->name,
"Main 12") ||
494 !strcmp(
profile->name,
"Main 12 Intra"))
495 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_12;
496 #ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444
497 else if (!strcmp(
profile->name,
"Main 4:4:4") ||
498 !strcmp(
profile->name,
"Main 4:4:4 Intra"))
499 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444;
501 #ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444_10
502 else if (!strcmp(
profile->name,
"Main 4:4:4 10") ||
503 !strcmp(
profile->name,
"Main 4:4:4 10 Intra"))
504 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_10;
505 else if (!strcmp(
profile->name,
"Main 4:4:4 12") ||
506 !strcmp(
profile->name,
"Main 4:4:4 12 Intra"))
507 *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_12;
524 profile = VDP_DECODER_PROFILE_HEVC_MAIN;
527 profile = VDP_DECODER_PROFILE_HEVC_MAIN_10;
530 profile = VDP_DECODER_PROFILE_HEVC_MAIN_STILL;
545 .
name =
"hevc_vdpau",