From: James Almer <jamrial@gmail.com> To: ffmpeg-devel@ffmpeg.org Subject: Re: [FFmpeg-devel] [RFC PATCH 3/4] avcodec/hevcdec: add nuh_layer_id option Date: Thu, 5 Jan 2023 08:21:37 -0300 Message-ID: <8cd994d5-e258-86ea-2069-4feb1b2267c0@gmail.com> (raw) In-Reply-To: <tencent_3267C7EA9413231C60CB8CA63CD0AF26ED06@qq.com> On 1/5/2023 1:14 PM, Zhao Zhili wrote: > From: Zhao Zhili <zhilizhao@tencent.com> > > It can be used to decode selected independent non-base layer. One > use case is alpha layer decoding. > > Signed-off-by: Zhao Zhili <zhilizhao@tencent.com> > --- > libavcodec/hevcdec.c | 20 +++++++++++++++++++- > libavcodec/version.h | 2 +- > 2 files changed, 20 insertions(+), 2 deletions(-) > > diff --git a/libavcodec/hevcdec.c b/libavcodec/hevcdec.c > index 567e8d81d4..9641922834 100644 > --- a/libavcodec/hevcdec.c > +++ b/libavcodec/hevcdec.c > @@ -3216,7 +3216,8 @@ static int decode_nal_units(HEVCContext *s, const uint8_t *buf, int length) > > if (s->avctx->skip_frame >= AVDISCARD_ALL || > (s->avctx->skip_frame >= AVDISCARD_NONREF > - && ff_hevc_nal_is_nonref(nal->type)) || nal->nuh_layer_id > 0) > + && ff_hevc_nal_is_nonref(nal->type)) || > + nal->nuh_layer_id != s->nuh_layer_id) > continue; > > ret = decode_nal_unit(s, nal); > @@ -3637,6 +3638,21 @@ static av_cold int hevc_decode_init(AVCodecContext *avctx) > HEVCContext *s = avctx->priv_data; > int ret; > > + if (s->nuh_layer_id > 0) { > + if (avctx->strict_std_compliance > FF_COMPLIANCE_EXPERIMENTAL) { > + av_log(avctx, AV_LOG_ERROR, > + "Decode selected nuh_layer_id is undef development. " > + "Use -strict -2 to use it anyway.\n"); "Undef development"? Does decoding of these non-base layers work or not? One thing is something being experimental (thus known to be working in at least some cases, even if not spec compliant), and another is enabling something we don't know if it's going to work or not at all. > + return AVERROR(EINVAL); > + } > + > + if (avctx->hwaccel) { > + av_log(avctx, AV_LOG_ERROR, > + "Decode selected nuh_layer_id doesn't work with hwaccel.\n"); > + return AVERROR(EINVAL); > + } > + } > + > if (avctx->active_thread_type & FF_THREAD_SLICE) { > s->threads_number = avctx->thread_count; > ret = ff_slice_thread_init_progress(avctx); > @@ -3691,6 +3707,8 @@ static const AVOption options[] = { > AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, PAR }, > { "strict-displaywin", "stricly apply default display window size", OFFSET(apply_defdispwin), > AV_OPT_TYPE_BOOL, {.i64 = 0}, 0, 1, PAR }, > + { "nuh_layer_id", "Select which nuh_layer_id to decode (only works with INBL)", OFFSET(nuh_layer_id), > + AV_OPT_TYPE_INT, {.i64 = 0}, 0, 62, PAR }, > { NULL }, > }; > > diff --git a/libavcodec/version.h b/libavcodec/version.h > index 6b8a1dbb79..15f7c3fe3d 100644 > --- a/libavcodec/version.h > +++ b/libavcodec/version.h > @@ -30,7 +30,7 @@ > #include "version_major.h" > > #define LIBAVCODEC_VERSION_MINOR 56 > -#define LIBAVCODEC_VERSION_MICRO 100 > +#define LIBAVCODEC_VERSION_MICRO 101 > > #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ > LIBAVCODEC_VERSION_MINOR, \ _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org https://ffmpeg.org/mailman/listinfo/ffmpeg-devel To unsubscribe, visit link above, or email ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next prev parent reply other threads:[~2023-01-05 11:21 UTC|newest] Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top [not found] <20230105161416.194463-1-quinkblack@foxmail.com> 2023-01-05 16:14 ` [FFmpeg-devel] [RFC PATCH 1/4] avcodec/hevc_parse: keep nal->nuh_layer_id > 0 Zhao Zhili 2023-01-05 16:14 ` [FFmpeg-devel] [RFC PATCH 2/4] avcodec/cbs_h2645: " Zhao Zhili 2023-01-05 11:18 ` James Almer 2023-01-05 12:06 ` "zhilizhao(赵志立)" 2023-01-05 16:14 ` [FFmpeg-devel] [RFC PATCH 3/4] avcodec/hevcdec: add nuh_layer_id option Zhao Zhili 2023-01-05 11:21 ` James Almer [this message] 2023-01-05 11:59 ` "zhilizhao(赵志立)" 2023-01-05 16:14 ` [FFmpeg-devel] [RFC PATCH 4/4] avcodec/h265_metadata_bsf: " Zhao Zhili 2023-01-05 21:48 ` Mark Thompson
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=8cd994d5-e258-86ea-2069-4feb1b2267c0@gmail.com \ --to=jamrial@gmail.com \ --cc=ffmpeg-devel@ffmpeg.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel This inbox may be cloned and mirrored by anyone: git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \ ffmpegdev@gitmailbox.com public-inbox-index ffmpegdev Example config snippet for mirrors. AGPL code for this site: git clone https://public-inbox.org/public-inbox.git