[VDPAU] [PATCH 1/2] lavc/vdpau_hevc: add function to find exact vdp_profile for REXT

Rémi Denis-Courmont remi at remlab.net
Fri Jun 26 14:47:32 UTC 2020


Le perjantaina 26. kesäkuuta 2020, 10.13.28 EEST ManojGuptaBonda a écrit :
> Add vdpau_parse_rext_profile and use profile constraint flags to
> determine the exact vdp_profile for HEVC_REXT.
> 
> If profile mismatch is allowed, select Main profile by default.
> 
> Add build object in Makefile for h265_profile_level dependency.
> ---
>  libavcodec/Makefile     |  2 +-
>  libavcodec/vdpau_hevc.c | 89 ++++++++++++++++++++++++++++++++++++++++-
>  2 files changed, 89 insertions(+), 2 deletions(-)
> 
> diff --git a/libavcodec/vdpau_hevc.c b/libavcodec/vdpau_hevc.c
> index 29cb2da078..c17de0c5d0 100644
> --- a/libavcodec/vdpau_hevc.c
> +++ b/libavcodec/vdpau_hevc.c
> @@ -429,10 +431,93 @@ static int vdpau_hevc_end_frame(AVCodecContext *avctx)
> return 0;
>  }
> 
> +
> +
> +static int ptl_convert(const PTLCommon *general_ptl,
> H265RawProfileTierLevel *h265_raw_ptl) +{
> +    h265_raw_ptl->general_profile_space = general_ptl->profile_space;
> +    h265_raw_ptl->general_tier_flag     = general_ptl->tier_flag;
> +    h265_raw_ptl->general_profile_idc   = general_ptl->profile_idc;
> +
> +    memcpy(h265_raw_ptl->general_profile_compatibility_flag,
> +                                  general_ptl->profile_compatibility_flag,
> 32 * sizeof(uint8_t)); +
> +#define copy_field(name) h265_raw_ptl->general_ ## name = general_ptl->name
> +    copy_field(progressive_source_flag);
> +    copy_field(interlaced_source_flag);
> +    copy_field(non_packed_constraint_flag);
> +    copy_field(frame_only_constraint_flag);
> +    copy_field(max_12bit_constraint_flag);
> +    copy_field(max_10bit_constraint_flag);
> +    copy_field(max_8bit_constraint_flag);
> +    copy_field(max_422chroma_constraint_flag);
> +    copy_field(max_420chroma_constraint_flag);
> +    copy_field(max_monochrome_constraint_flag);
> +    copy_field(intra_constraint_flag);
> +    copy_field(one_picture_only_constraint_flag);
> +    copy_field(lower_bit_rate_constraint_flag);
> +    copy_field(max_14bit_constraint_flag);
> +    copy_field(inbld_flag);
> +    copy_field(level_idc);
> +#undef copy_field
> +
> +    return 0;
> +}
> +
> +/*
> + * Find exact vdpau_profile for HEVC Range Extension
> + */
> +static int vdpau_hevc_parse_rext_profile(AVCodecContext *avctx,
> VdpDecoderProfile *vdp_profile) +{
> +    const HEVCContext *h = avctx->priv_data;
> +    const HEVCSPS *sps = h->ps.sps;
> +    const PTL *ptl = &sps->ptl;
> +    const PTLCommon *general_ptl = &ptl->general_ptl;
> +    const H265ProfileDescriptor *profile;
> +    H265RawProfileTierLevel h265_raw_ptl = {0};
> +
> +    /* convert PTLCommon to H265RawProfileTierLevel */
> +    ptl_convert(general_ptl, &h265_raw_ptl);
> +
> +    profile = ff_h265_get_profile(&h265_raw_ptl);
> +    if (!profile) {
> +        av_log(avctx, AV_LOG_WARNING, "HEVC profile is not found.\n");
> +        if (avctx->hwaccel_flags & AV_HWACCEL_FLAG_ALLOW_PROFILE_MISMATCH)
> { +            // Default to selecting Main profile if profile mismatch is
> allowed +            *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN;
> +            return 0;
> +        } else
> +            return AVERROR(ENOTSUP);
> +    }
> +
> +    if (!strcmp(profile->name, "Main 12") ||
> +        !strcmp(profile->name, "Main 12 Intra"))

Is this really supposed to be done with string matching in libavcodec? That 
looks rather brittle to me.

> +        *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_12;
> +#ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444
> +    else if (!strcmp(profile->name, "Main 4:4:4") ||
> +             !strcmp(profile->name, "Main 4:4:4 Intra"))
> +        *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444;
> +#endif
> +#ifdef VDP_DECODER_PROFILE_HEVC_MAIN_444_10
> +    else if (!strcmp(profile->name, "Main 4:4:4 10") ||
> +             !strcmp(profile->name, "Main 4:4:4 10 Intra"))
> +        *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_10;
> +    else if (!strcmp(profile->name, "Main 4:4:4 12") ||
> +             !strcmp(profile->name, "Main 4:4:4 12 Intra"))
> +        *vdp_profile = VDP_DECODER_PROFILE_HEVC_MAIN_444_12;
> +#endif
> +    else
> +        return AVERROR(ENOTSUP);
> +
> +    return 0;
> +}
> +
> +
>  static int vdpau_hevc_init(AVCodecContext *avctx)
>  {
>      VdpDecoderProfile profile;
>      uint32_t level = avctx->level;
> +    int ret;
> 
>      switch (avctx->profile) {
>      case FF_PROFILE_HEVC_MAIN:

-- 
Rémi Denis-Courmont
http://www.remlab.net/





More information about the VDPAU mailing list