From patchwork Thu Sep 21 12:17:00 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?b?Q2zDqW1lbnQgUMOpcm9u?= X-Patchwork-Id: 43864 Delivered-To: ffmpegpatchwork2@gmail.com Received: by 2002:a05:6a20:38a7:b0:15d:8365:d4b8 with SMTP id n39csp77734pzf; Thu, 21 Sep 2023 05:18:08 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGmK/mevriQM+tbwNcENA0SdgIxXdI1EwgBg8lb2SUSBfW6bmPQ/jaJ9OSRIHnd4AZQK2js X-Received: by 2002:a17:906:2258:b0:9ae:5fdc:aee8 with SMTP id 24-20020a170906225800b009ae5fdcaee8mr1468779ejr.53.1695298687924; Thu, 21 Sep 2023 05:18:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695298687; cv=none; d=google.com; s=arc-20160816; b=epCTXKhzd+xzJJuFo1zJu13Aux27vSJdkaVhj/HB9PPdFb/3Zinq7ca3pQMPy7Fx/l XHHGitTq3Wl+FytobpH2RFHibZkMwCwINLsRga0B6yd1JSdgb+PS6YLcbWNnmDiRD3tO hsIW0xKuldy34CvrYKKlfFrXreNS5r7QuJ02Rp4CuISuqf4M6hJXcU4/IcVBvjumy2Au OtZKvwzzC7aolj2gMbJzwwTLyNULcQpYK39N//qOBQDrkIE2rRS33Tf30cNdBLr+B1CS gZpz4dnyC3Td+WoGY8Y//znryxJGxRE8vyYeXuHjP9fdx6IhXI+GQbsBxOY3ZjYqaVxA BZqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:cc:reply-to :list-subscribe:list-help:list-post:list-archive:list-unsubscribe :list-id:precedence:subject:mime-version:references:in-reply-to :message-id:date:to:from:dkim-signature:delivered-to; bh=lORG4XQkcZD4Qc3UXLwEAgIQQ11hK0ArE8m5cE8r0sM=; fh=t7y2C+eTeDTjU/IXcwx7KgHV+pYAZ1n9wIrNqt3BZNM=; b=ZhVpLVsszbHWyNoJ5vv/CEOHYrkqk0OJFS5j+V1uZKKTd8Pvf+OoYdb8Vc54zSGZvl TFtMjr/GEiSvk7f/O2rTAtNHRlZtabXPeetfT2X7tQIi7tee4JfFPamdl/fm92CSVZ87 l6IxuIHVpZcarcKsJyrWeQG1eJXHpzXINBM4LOw3n6KotTNkZM/YxMHvSdcMWLjnUX59 xvL+5KePLDQssfufPyQ4tSMbMGQ2M0Kf2u7e/CvzzZ4H80T9sJBXEdXbyZYN6urtTbgO 4WOTTMWEEl/ReswbmldTbC0ogu9HkN4x8H93PXWxdor9lWBdi8kn+CUl/4RqIOqYTdfr n7wQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20230601 header.b="ZDr/I3rK"; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org. [79.124.17.100]) by mx.google.com with ESMTP id f18-20020a170906495200b009936735fecdsi1137558ejt.901.2023.09.21.05.18.06; Thu, 21 Sep 2023 05:18:07 -0700 (PDT) Received-SPF: pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) client-ip=79.124.17.100; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20230601 header.b="ZDr/I3rK"; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 34C1E68C915; Thu, 21 Sep 2023 15:17:37 +0300 (EEST) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail-wm1-f44.google.com (mail-wm1-f44.google.com [209.85.128.44]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id A701968C8E7 for ; Thu, 21 Sep 2023 15:17:30 +0300 (EEST) Received: by mail-wm1-f44.google.com with SMTP id 5b1f17b1804b1-40472c3faadso9630545e9.2 for ; Thu, 21 Sep 2023 05:17:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1695298649; x=1695903449; darn=ffmpeg.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=0w7p1SZui6DQ6P1o4W+LkYeXPECOI3mq4PTq/tXsqLI=; b=ZDr/I3rKQ7WmdwuPhq+EvIB6+suHlmEhLBfhpNEgX6mqdwyK/VkjtwBZPQJJ26Avyj MjGjSqzG/5BO/WMYrEMWKxGvua7TnavQfVyUKLUHZAnk2NRdvVC5R21q79yQ1mXXOjvX yiFYzswmvdDgAdkBxb+WhHNTD2wzZdmdk/f7815NPksihohVpFFTqZjtjsGMi+wHgLpc ZUw1JdjFADNC7zsjmd/gFO58bI0C41NAMH2pbYtBIMCFcpUoMLgBJkNDgkd9hodHQNG0 dwo7B5NKSag5GvuvDk1vBO8ypKKwD8LhWoFEO/I8S+Qeh6WUeED1L3iWzHdK+5dmndss 4p/w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1695298649; x=1695903449; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=0w7p1SZui6DQ6P1o4W+LkYeXPECOI3mq4PTq/tXsqLI=; b=FPnjrhqei2Kkq5xqnDv6U93tgFueKFSQXMCppC7sSogUi9axUK+s0cCgdqneZ+b1kB BlJrAvg1jf5+367Cz0meA5KBhnw3aQ89uJuAH4gGL3Y1nKTMSyN7+mVmh5fRk1e2yihj pkk2IAAM9jEMJyvQUQlVOhmDxs5UFvtmklOPcRxevCCh1/Es7FbAYRHP4D7tTOgUyUMR 3M75gdI2b4ZVTgOcXO4N768hMi8B3PU5olNNWSAdMe7V4Y+0BiFiCHnwaWZV150c/Yxp 1FZcLa7upufLy+uGW8b2olIiEMT5HSmbq1BnpCs7CrXGopdBeWTJO4/Sn6Uhs2qin88P TuOw== X-Gm-Message-State: AOJu0YxejLkJGieEyhheXhuJixLBa1dEmEjZ9sLWAt6W22f7lvBQdUrL 8kLForsorZeXHr0cdaK3cQTJF2GRuK4= X-Received: by 2002:a5d:5742:0:b0:321:6673:4a9f with SMTP id q2-20020a5d5742000000b0032166734a9fmr4761195wrw.15.1695298649148; Thu, 21 Sep 2023 05:17:29 -0700 (PDT) Received: from Clement-Blade14.outsight.local (lputeaux-656-1-11-33.w82-127.abo.wanadoo.fr. [82.127.142.33]) by smtp.gmail.com with ESMTPSA id f11-20020adff98b000000b0030fd03e3d25sm1615108wrr.75.2023.09.21.05.17.26 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Sep 2023 05:17:27 -0700 (PDT) From: =?utf-8?b?Q2zDqW1lbnQgUMOpcm9u?= To: ffmpeg-devel@ffmpeg.org Date: Thu, 21 Sep 2023 14:17:00 +0200 Message-ID: <20230921121720.362842-4-peron.clem@gmail.com> X-Mailer: git-send-email 2.42.0 In-Reply-To: <20230921121720.362842-1-peron.clem@gmail.com> References: <20230921121720.362842-1-peron.clem@gmail.com> MIME-Version: 1.0 Subject: [FFmpeg-devel] [RFC PATCH 3/3] HACK: avformat: rawenc: allow to output a raw PRFT 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 Cc: =?utf-8?b?Q2zDqW1lbnQgUMOpcm9u?= Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" X-TUID: ytAoZPY5ap6q Output the producer reference time to a dirty raw output. Signed-off-by: Clément Péron --- libavformat/rawenc.c | 122 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 122 insertions(+) diff --git a/libavformat/rawenc.c b/libavformat/rawenc.c index f916db13a2..2953f07ec6 100644 --- a/libavformat/rawenc.c +++ b/libavformat/rawenc.c @@ -23,13 +23,49 @@ #include "config_components.h" #include "libavutil/intreadwrite.h" +#include "libavutil/opt.h" #include "avformat.h" #include "rawenc.h" #include "mux.h" +typedef struct RawVideoContext { + const AVClass *class; + + int write_prft; +} RawVideoContext; + +// We want to have access to the timestamp with rawvideo +static int ff_raw_write_prft(AVFormatContext *s, AVPacket *pkt) +{ + size_t prft_size = 0; + AVProducerReferenceTime *prft = + (AVProducerReferenceTime *)av_packet_get_side_data(pkt, AV_PKT_DATA_PRFT, &prft_size); + + double frame_ts; + + avio_write(s->pb, "TIMESTAMP_MAGIC", 16); + if (prft && prft_size == sizeof(AVProducerReferenceTime)) { + // Save the frame_ts as a double + frame_ts = (prft->wallclock) / (double)AV_TIME_BASE; + av_log(s, AV_LOG_DEBUG, "ff_raw_write_packet: frame_ts %f.\n", frame_ts); + avio_write(s->pb, (void *)&frame_ts, sizeof(frame_ts)); + } else { + av_log(s, AV_LOG_DEBUG, "ff_raw_write_packet: No Timestamp.\n"); + avio_write(s->pb, "\0\0\0\0\0\0\0", 8); + } + + avio_write(s->pb, "FRAMEDATA_MAGIC", 16); + return 0; +} + int ff_raw_write_packet(AVFormatContext *s, AVPacket *pkt) { + RawVideoContext *raw = s->priv_data; + + if (raw->write_prft) + ff_raw_write_prft(s, pkt); + avio_write(s->pb, pkt->data, pkt->size); return 0; } @@ -56,12 +92,27 @@ static int force_one_stream(AVFormatContext *s) return 0; } +#undef OFFSET +#define OFFSET(x) offsetof(RawVideoContext, x) +static const AVOption raw_options[] = { + { "write_prft", "Output the Producer Reference Time", OFFSET(write_prft), AV_OPT_TYPE_BOOL, {.i64=0}, 0, 1, AV_OPT_FLAG_DECODING_PARAM }, + { NULL } +}; + +static const AVClass raw_muxer_class = { + .class_name = "RAW muxer", + .item_name = av_default_item_name, + .option = raw_options, + .version = LIBAVUTIL_VERSION_INT, +}; + /* Note: Do not forget to add new entries to the Makefile as well. */ #if CONFIG_AC3_MUXER const FFOutputFormat ff_ac3_muxer = { .p.name = "ac3", .p.long_name = NULL_IF_CONFIG_SMALL("raw AC-3"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/x-ac3", .p.extensions = "ac3", .p.audio_codec = AV_CODEC_ID_AC3, @@ -69,6 +120,7 @@ const FFOutputFormat ff_ac3_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -95,6 +147,7 @@ static int adx_write_trailer(AVFormatContext *s) const FFOutputFormat ff_adx_muxer = { .p.name = "adx", .p.long_name = NULL_IF_CONFIG_SMALL("CRI ADX"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "adx", .p.audio_codec = AV_CODEC_ID_ADPCM_ADX, .p.video_codec = AV_CODEC_ID_NONE, @@ -102,6 +155,7 @@ const FFOutputFormat ff_adx_muxer = { .write_packet = ff_raw_write_packet, .write_trailer = adx_write_trailer, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -109,12 +163,14 @@ const FFOutputFormat ff_adx_muxer = { const FFOutputFormat ff_aptx_muxer = { .p.name = "aptx", .p.long_name = NULL_IF_CONFIG_SMALL("raw aptX (Audio Processing Technology for Bluetooth)"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "aptx", .p.audio_codec = AV_CODEC_ID_APTX, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -122,12 +178,14 @@ const FFOutputFormat ff_aptx_muxer = { const FFOutputFormat ff_aptx_hd_muxer = { .p.name = "aptx_hd", .p.long_name = NULL_IF_CONFIG_SMALL("raw aptX HD (Audio Processing Technology for Bluetooth)"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "aptxhd", .p.audio_codec = AV_CODEC_ID_APTX_HD, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -135,12 +193,14 @@ const FFOutputFormat ff_aptx_hd_muxer = { const FFOutputFormat ff_avs2_muxer = { .p.name = "avs2", .p.long_name = NULL_IF_CONFIG_SMALL("raw AVS2-P2/IEEE1857.4 video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "avs,avs2", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_AVS2, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -148,12 +208,14 @@ const FFOutputFormat ff_avs2_muxer = { const FFOutputFormat ff_avs3_muxer = { .p.name = "avs3", .p.long_name = NULL_IF_CONFIG_SMALL("AVS3-P2/IEEE1857.10"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "avs3", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_AVS3, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -162,12 +224,14 @@ const FFOutputFormat ff_avs3_muxer = { const FFOutputFormat ff_cavsvideo_muxer = { .p.name = "cavsvideo", .p.long_name = NULL_IF_CONFIG_SMALL("raw Chinese AVS (Audio Video Standard) video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "cavs", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_CAVS, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -175,11 +239,13 @@ const FFOutputFormat ff_cavsvideo_muxer = { const FFOutputFormat ff_codec2raw_muxer = { .p.name = "codec2raw", .p.long_name = NULL_IF_CONFIG_SMALL("raw codec2 muxer"), + .priv_data_size = sizeof(RawVideoContext), .p.audio_codec = AV_CODEC_ID_CODEC2, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -188,9 +254,11 @@ const FFOutputFormat ff_codec2raw_muxer = { const FFOutputFormat ff_data_muxer = { .p.name = "data", .p.long_name = NULL_IF_CONFIG_SMALL("raw data"), + .priv_data_size = sizeof(RawVideoContext), .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -198,12 +266,14 @@ const FFOutputFormat ff_data_muxer = { const FFOutputFormat ff_dfpwm_muxer = { .p.name = "dfpwm", .p.long_name = NULL_IF_CONFIG_SMALL("raw DFPWM1a"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "dfpwm", .p.audio_codec = AV_CODEC_ID_DFPWM, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -211,12 +281,14 @@ const FFOutputFormat ff_dfpwm_muxer = { const FFOutputFormat ff_dirac_muxer = { .p.name = "dirac", .p.long_name = NULL_IF_CONFIG_SMALL("raw Dirac"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "drc,vc2", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_DIRAC, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -224,12 +296,14 @@ const FFOutputFormat ff_dirac_muxer = { const FFOutputFormat ff_dnxhd_muxer = { .p.name = "dnxhd", .p.long_name = NULL_IF_CONFIG_SMALL("raw DNxHD (SMPTE VC-3)"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "dnxhd,dnxhr", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_DNXHD, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -237,6 +311,7 @@ const FFOutputFormat ff_dnxhd_muxer = { const FFOutputFormat ff_dts_muxer = { .p.name = "dts", .p.long_name = NULL_IF_CONFIG_SMALL("raw DTS"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/x-dca", .p.extensions = "dts", .p.audio_codec = AV_CODEC_ID_DTS, @@ -244,6 +319,7 @@ const FFOutputFormat ff_dts_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -251,6 +327,7 @@ const FFOutputFormat ff_dts_muxer = { const FFOutputFormat ff_eac3_muxer = { .p.name = "eac3", .p.long_name = NULL_IF_CONFIG_SMALL("raw E-AC-3"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/x-eac3", .p.extensions = "eac3,ec3", .p.audio_codec = AV_CODEC_ID_EAC3, @@ -258,6 +335,7 @@ const FFOutputFormat ff_eac3_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -265,6 +343,7 @@ const FFOutputFormat ff_eac3_muxer = { const FFOutputFormat ff_g722_muxer = { .p.name = "g722", .p.long_name = NULL_IF_CONFIG_SMALL("raw G.722"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/G722", .p.extensions = "g722", .p.audio_codec = AV_CODEC_ID_ADPCM_G722, @@ -272,6 +351,7 @@ const FFOutputFormat ff_g722_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -279,6 +359,7 @@ const FFOutputFormat ff_g722_muxer = { const FFOutputFormat ff_g723_1_muxer = { .p.name = "g723_1", .p.long_name = NULL_IF_CONFIG_SMALL("raw G.723.1"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/g723", .p.extensions = "tco,rco", .p.audio_codec = AV_CODEC_ID_G723_1, @@ -286,6 +367,7 @@ const FFOutputFormat ff_g723_1_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -293,11 +375,13 @@ const FFOutputFormat ff_g723_1_muxer = { const FFOutputFormat ff_g726_muxer = { .p.name = "g726", .p.long_name = NULL_IF_CONFIG_SMALL("raw big-endian G.726 (\"left-justified\")"), + .priv_data_size = sizeof(RawVideoContext), .p.audio_codec = AV_CODEC_ID_ADPCM_G726, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -305,11 +389,13 @@ const FFOutputFormat ff_g726_muxer = { const FFOutputFormat ff_g726le_muxer = { .p.name = "g726le", .p.long_name = NULL_IF_CONFIG_SMALL("raw little-endian G.726 (\"right-justified\")"), + .priv_data_size = sizeof(RawVideoContext), .p.audio_codec = AV_CODEC_ID_ADPCM_G726LE, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -317,6 +403,7 @@ const FFOutputFormat ff_g726le_muxer = { const FFOutputFormat ff_gsm_muxer = { .p.name = "gsm", .p.long_name = NULL_IF_CONFIG_SMALL("raw GSM"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/x-gsm", .p.extensions = "gsm", .p.audio_codec = AV_CODEC_ID_GSM, @@ -324,6 +411,7 @@ const FFOutputFormat ff_gsm_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -331,6 +419,7 @@ const FFOutputFormat ff_gsm_muxer = { const FFOutputFormat ff_h261_muxer = { .p.name = "h261", .p.long_name = NULL_IF_CONFIG_SMALL("raw H.261"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "video/x-h261", .p.extensions = "h261", .p.audio_codec = AV_CODEC_ID_NONE, @@ -338,6 +427,7 @@ const FFOutputFormat ff_h261_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -345,6 +435,7 @@ const FFOutputFormat ff_h261_muxer = { const FFOutputFormat ff_h263_muxer = { .p.name = "h263", .p.long_name = NULL_IF_CONFIG_SMALL("raw H.263"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "video/x-h263", .p.extensions = "h263", .p.audio_codec = AV_CODEC_ID_NONE, @@ -352,6 +443,7 @@ const FFOutputFormat ff_h263_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -368,6 +460,7 @@ static int h264_check_bitstream(AVFormatContext *s, AVStream *st, const FFOutputFormat ff_h264_muxer = { .p.name = "h264", .p.long_name = NULL_IF_CONFIG_SMALL("raw H.264 video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "h264,264", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_H264, @@ -375,6 +468,7 @@ const FFOutputFormat ff_h264_muxer = { .write_packet = ff_raw_write_packet, .check_bitstream = h264_check_bitstream, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -391,6 +485,7 @@ static int vvc_check_bitstream(AVFormatContext *s, AVStream *st, const FFOutputFormat ff_vvc_muxer = { .p.name = "vvc", .p.long_name = NULL_IF_CONFIG_SMALL("raw H.266/VVC video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "vvc,h266,266", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_VVC, @@ -398,6 +493,7 @@ const FFOutputFormat ff_vvc_muxer = { .write_packet = ff_raw_write_packet, .check_bitstream = vvc_check_bitstream, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -414,6 +510,7 @@ static int hevc_check_bitstream(AVFormatContext *s, AVStream *st, const FFOutputFormat ff_hevc_muxer = { .p.name = "hevc", .p.long_name = NULL_IF_CONFIG_SMALL("raw HEVC video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "hevc,h265,265", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_HEVC, @@ -421,6 +518,7 @@ const FFOutputFormat ff_hevc_muxer = { .write_packet = ff_raw_write_packet, .check_bitstream = hevc_check_bitstream, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -428,12 +526,14 @@ const FFOutputFormat ff_hevc_muxer = { const FFOutputFormat ff_evc_muxer = { .p.name = "evc", .p.long_name = NULL_IF_CONFIG_SMALL("raw EVC video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "evc", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_EVC, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -441,12 +541,14 @@ const FFOutputFormat ff_evc_muxer = { const FFOutputFormat ff_m4v_muxer = { .p.name = "m4v", .p.long_name = NULL_IF_CONFIG_SMALL("raw MPEG-4 video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "m4v", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_MPEG4, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -454,6 +556,7 @@ const FFOutputFormat ff_m4v_muxer = { const FFOutputFormat ff_mjpeg_muxer = { .p.name = "mjpeg", .p.long_name = NULL_IF_CONFIG_SMALL("raw MJPEG video"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "video/x-mjpeg", .p.extensions = "mjpg,mjpeg", .p.audio_codec = AV_CODEC_ID_NONE, @@ -461,6 +564,7 @@ const FFOutputFormat ff_mjpeg_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -468,12 +572,14 @@ const FFOutputFormat ff_mjpeg_muxer = { const FFOutputFormat ff_mlp_muxer = { .p.name = "mlp", .p.long_name = NULL_IF_CONFIG_SMALL("raw MLP"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "mlp", .p.audio_codec = AV_CODEC_ID_MLP, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -481,6 +587,7 @@ const FFOutputFormat ff_mlp_muxer = { const FFOutputFormat ff_mp2_muxer = { .p.name = "mp2", .p.long_name = NULL_IF_CONFIG_SMALL("MP2 (MPEG audio layer 2)"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/mpeg", .p.extensions = "mp2,m2a,mpa", .p.audio_codec = AV_CODEC_ID_MP2, @@ -488,6 +595,7 @@ const FFOutputFormat ff_mp2_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -495,6 +603,7 @@ const FFOutputFormat ff_mp2_muxer = { const FFOutputFormat ff_mpeg1video_muxer = { .p.name = "mpeg1video", .p.long_name = NULL_IF_CONFIG_SMALL("raw MPEG-1 video"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "video/mpeg", .p.extensions = "mpg,mpeg,m1v", .p.audio_codec = AV_CODEC_ID_NONE, @@ -502,6 +611,7 @@ const FFOutputFormat ff_mpeg1video_muxer = { .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -509,12 +619,14 @@ const FFOutputFormat ff_mpeg1video_muxer = { const FFOutputFormat ff_mpeg2video_muxer = { .p.name = "mpeg2video", .p.long_name = NULL_IF_CONFIG_SMALL("raw MPEG-2 video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "m2v", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_MPEG2VIDEO, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -528,6 +640,7 @@ static int obu_check_bitstream(AVFormatContext *s, AVStream *st, const FFOutputFormat ff_obu_muxer = { .p.name = "obu", .p.long_name = NULL_IF_CONFIG_SMALL("AV1 low overhead OBU"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "obu", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_AV1, @@ -535,6 +648,7 @@ const FFOutputFormat ff_obu_muxer = { .write_packet = ff_raw_write_packet, .check_bitstream = obu_check_bitstream, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -542,11 +656,13 @@ const FFOutputFormat ff_obu_muxer = { const FFOutputFormat ff_rawvideo_muxer = { .p.name = "rawvideo", .p.long_name = NULL_IF_CONFIG_SMALL("raw video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "yuv,rgb", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_RAWVIDEO, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -554,12 +670,14 @@ const FFOutputFormat ff_rawvideo_muxer = { const FFOutputFormat ff_sbc_muxer = { .p.name = "sbc", .p.long_name = NULL_IF_CONFIG_SMALL("raw SBC"), + .priv_data_size = sizeof(RawVideoContext), .p.mime_type = "audio/x-sbc", .p.extensions = "sbc,msbc", .p.audio_codec = AV_CODEC_ID_SBC, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -567,12 +685,14 @@ const FFOutputFormat ff_sbc_muxer = { const FFOutputFormat ff_truehd_muxer = { .p.name = "truehd", .p.long_name = NULL_IF_CONFIG_SMALL("raw TrueHD"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "thd", .p.audio_codec = AV_CODEC_ID_TRUEHD, .p.video_codec = AV_CODEC_ID_NONE, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif @@ -580,11 +700,13 @@ const FFOutputFormat ff_truehd_muxer = { const FFOutputFormat ff_vc1_muxer = { .p.name = "vc1", .p.long_name = NULL_IF_CONFIG_SMALL("raw VC-1 video"), + .priv_data_size = sizeof(RawVideoContext), .p.extensions = "vc1", .p.audio_codec = AV_CODEC_ID_NONE, .p.video_codec = AV_CODEC_ID_VC1, .init = force_one_stream, .write_packet = ff_raw_write_packet, .p.flags = AVFMT_NOTIMESTAMPS, + .p.priv_class = &raw_muxer_class, }; #endif