From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org [79.124.17.100]) by master.gitmailbox.com (Postfix) with ESMTP id 15D9947BF4 for ; Wed, 4 Oct 2023 12:30:51 +0000 (UTC) Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 1A01868CD7A; Wed, 4 Oct 2023 15:29:14 +0300 (EEST) Received: from mail-pg1-f171.google.com (mail-pg1-f171.google.com [209.85.215.171]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id 0A58E68CCF7 for ; Wed, 4 Oct 2023 15:29:04 +0300 (EEST) Received: by mail-pg1-f171.google.com with SMTP id 41be03b00d2f7-5859b2eaa67so1348894a12.0 for ; Wed, 04 Oct 2023 05:29:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1696422541; x=1697027341; darn=ffmpeg.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:from:to:cc:subject:date:message-id :reply-to; bh=+RMs90a8Wd2hzR5o08Iof+OONaMQWo7cCpcSfrVqIPA=; b=hcJ8JJB1FDmUtAhh/WJBCf6RUJfNFA3eQux48E8dgqQtywwL6Xc5NvP+vhZR6dQr17 i4iCKYakpj0OxNTSZdkermt7gvqvB+Mb/f1dppotGcZ/lcpv2wpnwkEIzqqL5ilU8FNg 4Ww9eZpFVyPSlQ/KB+j13YUBlSYztMbra3S+J/YPqbCZcZ5o9IzgLy3K7U0IV40AFeNB jexcedsJkJFprCQCUMhO7F3B+cHRigc50Xg+veaVLnSGiaFKqQME2s0XcPpDNM24tY7B LKaJfUYKGIIbHCq09NkdrQXhwvqR1P1Muq++uoF/NmiQqztCk2M7YfOjtAWeJFtd3KaK B3Dg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1696422541; x=1697027341; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=+RMs90a8Wd2hzR5o08Iof+OONaMQWo7cCpcSfrVqIPA=; b=tbNtcudEU4HXUxDXfCWUVtvTMSapYPr+4CHgzZt2uQV+E7JTk5sUu4cN2SEZMBIFYZ 403eMrGK4QLY2niqtStDj01eAayWUfsFCkI4EVdr5xLT85ymB46Px5JPpsjsatfACg0w 9FFtO2GpLwiJHNmmDUe/gEtEE0y581V99v/LMxdZNxtsCslDIKm3rl4wFLF98xVcQN70 xwhKW71bXPqZy4H80RnDDNOxRqd8BY7B5okYnuRR1cCw3WzfSX0q5+nOIsCHKoskhLII l4EVP/VuYdhZ1DgPJbLFtaxMsY4xyehYvxK1MLTozQMOFmkNXuLsSDZrawE5f8IecnKK ViUA== X-Gm-Message-State: AOJu0YzwV609W0xSR/vZF1ajVH/UMqbAyJsnK4Prg3EExOT2MD9jZ4V6 Ctjnl89iapq/FN0jh0H6WzL9YpWZzek= X-Google-Smtp-Source: AGHT+IEZ4Q49UwIe2CvO/E6+shTPzrMDCmPv9V/Khk8LMkpXdMcM5cQcsPHlRswRQGmnFNNYs51fOQ== X-Received: by 2002:a05:6a20:9146:b0:15e:dc75:66af with SMTP id x6-20020a056a20914600b0015edc7566afmr2444684pzc.59.1696422541531; Wed, 04 Oct 2023 05:29:01 -0700 (PDT) Received: from localhost.localdomain (host197.190-225-105.telecom.net.ar. [190.225.105.197]) by smtp.gmail.com with ESMTPSA id h11-20020a170902748b00b001c57aac6e5esm3551831pll.23.2023.10.04.05.29.00 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 04 Oct 2023 05:29:01 -0700 (PDT) From: James Almer To: ffmpeg-devel@ffmpeg.org Date: Wed, 4 Oct 2023 09:28:46 -0300 Message-ID: <20231004122849.56604-9-jamrial@gmail.com> X-Mailer: git-send-email 2.42.0 In-Reply-To: <20231004122849.56604-1-jamrial@gmail.com> References: <20231004122849.56604-1-jamrial@gmail.com> MIME-Version: 1.0 Subject: [FFmpeg-devel] [PATCH 08/11] avcodec/hevcdec: check for DOVI configuration record in AVCodecContext side data X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" Archived-At: List-Archive: List-Post: Signed-off-by: James Almer --- libavcodec/avcodec.h | 2 +- libavcodec/decode.c | 10 ++++++++++ libavcodec/decode.h | 6 ++++++ libavcodec/hevcdec.c | 15 ++++++++++++++- 4 files changed, 31 insertions(+), 2 deletions(-) diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h index 09400b97b0..42b34ee89a 100644 --- a/libavcodec/avcodec.h +++ b/libavcodec/avcodec.h @@ -1907,7 +1907,7 @@ typedef struct AVCodecContext { /** * Additional data associated with the entire coded stream. * - * - decoding: unused + * - decoding: may be set by user before calling avcodec_open2(). * - encoding: may be set by libavcodec after avcodec_open2(). */ AVPacketSideData *coded_side_data; diff --git a/libavcodec/decode.c b/libavcodec/decode.c index 8f94678e9b..d81c418e10 100644 --- a/libavcodec/decode.c +++ b/libavcodec/decode.c @@ -1403,6 +1403,16 @@ int ff_get_format(AVCodecContext *avctx, const enum AVPixelFormat *fmt) return ret; } +const AVPacketSideData *ff_get_coded_side_data(const AVCodecContext *avctx, + enum AVPacketSideDataType type) +{ + for (int i = 0; i < avctx->nb_coded_side_data; i++) + if (avctx->coded_side_data[i].type == type) + return &avctx->coded_side_data[i]; + + return NULL; +} + static int add_metadata_from_side_data(const AVPacket *avpkt, AVFrame *frame) { size_t size; diff --git a/libavcodec/decode.h b/libavcodec/decode.h index a52152e4a7..be03c136e7 100644 --- a/libavcodec/decode.h +++ b/libavcodec/decode.h @@ -153,4 +153,10 @@ int ff_side_data_update_matrix_encoding(AVFrame *frame, int ff_hwaccel_frame_priv_alloc(AVCodecContext *avctx, void **hwaccel_picture_private, AVBufferRef **hwaccel_priv_buf); +/** + * Get side data of the given type from a decoding context. + */ +const AVPacketSideData *ff_get_coded_side_data(const AVCodecContext *avctx, + enum AVPacketSideDataType type); + #endif /* AVCODEC_DECODE_H */ diff --git a/libavcodec/hevcdec.c b/libavcodec/hevcdec.c index 2be62ddfb2..5acaa407dd 100644 --- a/libavcodec/hevcdec.c +++ b/libavcodec/hevcdec.c @@ -3343,8 +3343,15 @@ static int hevc_decode_frame(AVCodecContext *avctx, AVFrame *rframe, } sd = av_packet_get_side_data(avpkt, AV_PKT_DATA_DOVI_CONF, &sd_size); - if (sd && sd_size > 0) + if (sd && sd_size > 0) { + int old = s->dovi_ctx.dv_profile; + ff_dovi_update_cfg(&s->dovi_ctx, (AVDOVIDecoderConfigurationRecord *) sd); + if (old) + av_log(avctx, AV_LOG_DEBUG, + "New DOVI configuration record from input packet (profile %d -> %u).\n", + old, s->dovi_ctx.dv_profile); + } s->ref = NULL; ret = decode_nal_units(s, avpkt->data, avpkt->size); @@ -3649,12 +3656,18 @@ static av_cold int hevc_decode_init(AVCodecContext *avctx) atomic_init(&s->wpp_err, 0); if (!avctx->internal->is_copy) { + const AVPacketSideData *sd; + if (avctx->extradata_size > 0 && avctx->extradata) { ret = hevc_decode_extradata(s, avctx->extradata, avctx->extradata_size, 1); if (ret < 0) { return ret; } } + + sd = ff_get_coded_side_data(avctx, AV_PKT_DATA_DOVI_CONF); + if (sd && sd->size > 0) + ff_dovi_update_cfg(&s->dovi_ctx, (AVDOVIDecoderConfigurationRecord *) sd->data); } return 0; -- 2.42.0 _______________________________________________ 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".