1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * AVCodecContext functions for libavcodec
3cabdff1aSopenharmony_ci *
4cabdff1aSopenharmony_ci * This file is part of FFmpeg.
5cabdff1aSopenharmony_ci *
6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
10cabdff1aSopenharmony_ci *
11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14cabdff1aSopenharmony_ci * Lesser General Public License for more details.
15cabdff1aSopenharmony_ci *
16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19cabdff1aSopenharmony_ci */
20cabdff1aSopenharmony_ci
21cabdff1aSopenharmony_ci/**
22cabdff1aSopenharmony_ci * @file
23cabdff1aSopenharmony_ci * AVCodecContext functions for libavcodec
24cabdff1aSopenharmony_ci */
25cabdff1aSopenharmony_ci
26cabdff1aSopenharmony_ci#include "config.h"
27cabdff1aSopenharmony_ci#include "libavutil/avassert.h"
28cabdff1aSopenharmony_ci#include "libavutil/avstring.h"
29cabdff1aSopenharmony_ci#include "libavutil/bprint.h"
30cabdff1aSopenharmony_ci#include "libavutil/channel_layout.h"
31cabdff1aSopenharmony_ci#include "libavutil/fifo.h"
32cabdff1aSopenharmony_ci#include "libavutil/imgutils.h"
33cabdff1aSopenharmony_ci#include "libavutil/mem.h"
34cabdff1aSopenharmony_ci#include "libavutil/opt.h"
35cabdff1aSopenharmony_ci#include "libavutil/thread.h"
36cabdff1aSopenharmony_ci#include "avcodec.h"
37cabdff1aSopenharmony_ci#include "bsf.h"
38cabdff1aSopenharmony_ci#include "codec_internal.h"
39cabdff1aSopenharmony_ci#include "decode.h"
40cabdff1aSopenharmony_ci#include "encode.h"
41cabdff1aSopenharmony_ci#include "frame_thread_encoder.h"
42cabdff1aSopenharmony_ci#include "internal.h"
43cabdff1aSopenharmony_ci#include "thread.h"
44cabdff1aSopenharmony_ci
45cabdff1aSopenharmony_ciint avcodec_default_execute(AVCodecContext *c, int (*func)(AVCodecContext *c2, void *arg2), void *arg, int *ret, int count, int size)
46cabdff1aSopenharmony_ci{
47cabdff1aSopenharmony_ci    int i;
48cabdff1aSopenharmony_ci
49cabdff1aSopenharmony_ci    for (i = 0; i < count; i++) {
50cabdff1aSopenharmony_ci        int r = func(c, (char *)arg + i * size);
51cabdff1aSopenharmony_ci        if (ret)
52cabdff1aSopenharmony_ci            ret[i] = r;
53cabdff1aSopenharmony_ci    }
54cabdff1aSopenharmony_ci    emms_c();
55cabdff1aSopenharmony_ci    return 0;
56cabdff1aSopenharmony_ci}
57cabdff1aSopenharmony_ci
58cabdff1aSopenharmony_ciint avcodec_default_execute2(AVCodecContext *c, int (*func)(AVCodecContext *c2, void *arg2, int jobnr, int threadnr), void *arg, int *ret, int count)
59cabdff1aSopenharmony_ci{
60cabdff1aSopenharmony_ci    int i;
61cabdff1aSopenharmony_ci
62cabdff1aSopenharmony_ci    for (i = 0; i < count; i++) {
63cabdff1aSopenharmony_ci        int r = func(c, arg, i, 0);
64cabdff1aSopenharmony_ci        if (ret)
65cabdff1aSopenharmony_ci            ret[i] = r;
66cabdff1aSopenharmony_ci    }
67cabdff1aSopenharmony_ci    emms_c();
68cabdff1aSopenharmony_ci    return 0;
69cabdff1aSopenharmony_ci}
70cabdff1aSopenharmony_ci
71cabdff1aSopenharmony_cistatic AVMutex codec_mutex = AV_MUTEX_INITIALIZER;
72cabdff1aSopenharmony_ci
73cabdff1aSopenharmony_cistatic void lock_avcodec(const FFCodec *codec)
74cabdff1aSopenharmony_ci{
75cabdff1aSopenharmony_ci    if (!(codec->caps_internal & FF_CODEC_CAP_INIT_THREADSAFE) && codec->init)
76cabdff1aSopenharmony_ci        ff_mutex_lock(&codec_mutex);
77cabdff1aSopenharmony_ci}
78cabdff1aSopenharmony_ci
79cabdff1aSopenharmony_cistatic void unlock_avcodec(const FFCodec *codec)
80cabdff1aSopenharmony_ci{
81cabdff1aSopenharmony_ci    if (!(codec->caps_internal & FF_CODEC_CAP_INIT_THREADSAFE) && codec->init)
82cabdff1aSopenharmony_ci        ff_mutex_unlock(&codec_mutex);
83cabdff1aSopenharmony_ci}
84cabdff1aSopenharmony_ci
85cabdff1aSopenharmony_cistatic int64_t get_bit_rate(AVCodecContext *ctx)
86cabdff1aSopenharmony_ci{
87cabdff1aSopenharmony_ci    int64_t bit_rate;
88cabdff1aSopenharmony_ci    int bits_per_sample;
89cabdff1aSopenharmony_ci
90cabdff1aSopenharmony_ci    switch (ctx->codec_type) {
91cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_VIDEO:
92cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_DATA:
93cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_SUBTITLE:
94cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_ATTACHMENT:
95cabdff1aSopenharmony_ci        bit_rate = ctx->bit_rate;
96cabdff1aSopenharmony_ci        break;
97cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_AUDIO:
98cabdff1aSopenharmony_ci        bits_per_sample = av_get_bits_per_sample(ctx->codec_id);
99cabdff1aSopenharmony_ci        if (bits_per_sample) {
100cabdff1aSopenharmony_ci            bit_rate = ctx->sample_rate * (int64_t)ctx->ch_layout.nb_channels;
101cabdff1aSopenharmony_ci            if (bit_rate > INT64_MAX / bits_per_sample) {
102cabdff1aSopenharmony_ci                bit_rate = 0;
103cabdff1aSopenharmony_ci            } else
104cabdff1aSopenharmony_ci                bit_rate *= bits_per_sample;
105cabdff1aSopenharmony_ci        } else
106cabdff1aSopenharmony_ci            bit_rate = ctx->bit_rate;
107cabdff1aSopenharmony_ci        break;
108cabdff1aSopenharmony_ci    default:
109cabdff1aSopenharmony_ci        bit_rate = 0;
110cabdff1aSopenharmony_ci        break;
111cabdff1aSopenharmony_ci    }
112cabdff1aSopenharmony_ci    return bit_rate;
113cabdff1aSopenharmony_ci}
114cabdff1aSopenharmony_ci
115cabdff1aSopenharmony_ciint attribute_align_arg avcodec_open2(AVCodecContext *avctx, const AVCodec *codec, AVDictionary **options)
116cabdff1aSopenharmony_ci{
117cabdff1aSopenharmony_ci    int ret = 0;
118cabdff1aSopenharmony_ci    AVCodecInternal *avci;
119cabdff1aSopenharmony_ci    const FFCodec *codec2;
120cabdff1aSopenharmony_ci
121cabdff1aSopenharmony_ci    if (avcodec_is_open(avctx))
122cabdff1aSopenharmony_ci        return 0;
123cabdff1aSopenharmony_ci
124cabdff1aSopenharmony_ci    if (!codec && !avctx->codec) {
125cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "No codec provided to avcodec_open2()\n");
126cabdff1aSopenharmony_ci        return AVERROR(EINVAL);
127cabdff1aSopenharmony_ci    }
128cabdff1aSopenharmony_ci    if (codec && avctx->codec && codec != avctx->codec) {
129cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "This AVCodecContext was allocated for %s, "
130cabdff1aSopenharmony_ci                                    "but %s passed to avcodec_open2()\n", avctx->codec->name, codec->name);
131cabdff1aSopenharmony_ci        return AVERROR(EINVAL);
132cabdff1aSopenharmony_ci    }
133cabdff1aSopenharmony_ci    if (!codec)
134cabdff1aSopenharmony_ci        codec = avctx->codec;
135cabdff1aSopenharmony_ci    codec2 = ffcodec(codec);
136cabdff1aSopenharmony_ci
137cabdff1aSopenharmony_ci    if ((avctx->codec_type != AVMEDIA_TYPE_UNKNOWN && avctx->codec_type != codec->type) ||
138cabdff1aSopenharmony_ci        (avctx->codec_id   != AV_CODEC_ID_NONE     && avctx->codec_id   != codec->id)) {
139cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "Codec type or id mismatches\n");
140cabdff1aSopenharmony_ci        return AVERROR(EINVAL);
141cabdff1aSopenharmony_ci    }
142cabdff1aSopenharmony_ci
143cabdff1aSopenharmony_ci    avctx->codec_type = codec->type;
144cabdff1aSopenharmony_ci    avctx->codec_id   = codec->id;
145cabdff1aSopenharmony_ci    avctx->codec      = codec;
146cabdff1aSopenharmony_ci
147cabdff1aSopenharmony_ci    if (avctx->extradata_size < 0 || avctx->extradata_size >= FF_MAX_EXTRADATA_SIZE)
148cabdff1aSopenharmony_ci        return AVERROR(EINVAL);
149cabdff1aSopenharmony_ci
150cabdff1aSopenharmony_ci    avci = av_mallocz(sizeof(*avci));
151cabdff1aSopenharmony_ci    if (!avci) {
152cabdff1aSopenharmony_ci        ret = AVERROR(ENOMEM);
153cabdff1aSopenharmony_ci        goto end;
154cabdff1aSopenharmony_ci    }
155cabdff1aSopenharmony_ci    avctx->internal = avci;
156cabdff1aSopenharmony_ci
157cabdff1aSopenharmony_ci    avci->buffer_frame = av_frame_alloc();
158cabdff1aSopenharmony_ci    avci->buffer_pkt = av_packet_alloc();
159cabdff1aSopenharmony_ci    if (!avci->buffer_frame || !avci->buffer_pkt) {
160cabdff1aSopenharmony_ci        ret = AVERROR(ENOMEM);
161cabdff1aSopenharmony_ci        goto free_and_end;
162cabdff1aSopenharmony_ci    }
163cabdff1aSopenharmony_ci
164cabdff1aSopenharmony_ci    avci->skip_samples_multiplier = 1;
165cabdff1aSopenharmony_ci
166cabdff1aSopenharmony_ci    if (codec2->priv_data_size > 0) {
167cabdff1aSopenharmony_ci        if (!avctx->priv_data) {
168cabdff1aSopenharmony_ci            avctx->priv_data = av_mallocz(codec2->priv_data_size);
169cabdff1aSopenharmony_ci            if (!avctx->priv_data) {
170cabdff1aSopenharmony_ci                ret = AVERROR(ENOMEM);
171cabdff1aSopenharmony_ci                goto free_and_end;
172cabdff1aSopenharmony_ci            }
173cabdff1aSopenharmony_ci            if (codec->priv_class) {
174cabdff1aSopenharmony_ci                *(const AVClass **)avctx->priv_data = codec->priv_class;
175cabdff1aSopenharmony_ci                av_opt_set_defaults(avctx->priv_data);
176cabdff1aSopenharmony_ci            }
177cabdff1aSopenharmony_ci        }
178cabdff1aSopenharmony_ci        if (codec->priv_class && (ret = av_opt_set_dict(avctx->priv_data, options)) < 0)
179cabdff1aSopenharmony_ci            goto free_and_end;
180cabdff1aSopenharmony_ci    } else {
181cabdff1aSopenharmony_ci        avctx->priv_data = NULL;
182cabdff1aSopenharmony_ci    }
183cabdff1aSopenharmony_ci    if ((ret = av_opt_set_dict(avctx, options)) < 0)
184cabdff1aSopenharmony_ci        goto free_and_end;
185cabdff1aSopenharmony_ci
186cabdff1aSopenharmony_ci    if (avctx->codec_whitelist && av_match_list(codec->name, avctx->codec_whitelist, ',') <= 0) {
187cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "Codec (%s) not on whitelist \'%s\'\n", codec->name, avctx->codec_whitelist);
188cabdff1aSopenharmony_ci        ret = AVERROR(EINVAL);
189cabdff1aSopenharmony_ci        goto free_and_end;
190cabdff1aSopenharmony_ci    }
191cabdff1aSopenharmony_ci
192cabdff1aSopenharmony_ci    // only call ff_set_dimensions() for non H.264/VP6F/DXV codecs so as not to overwrite previously setup dimensions
193cabdff1aSopenharmony_ci    if (!(avctx->coded_width && avctx->coded_height && avctx->width && avctx->height &&
194cabdff1aSopenharmony_ci          (avctx->codec_id == AV_CODEC_ID_H264 || avctx->codec_id == AV_CODEC_ID_VP6F || avctx->codec_id == AV_CODEC_ID_DXV))) {
195cabdff1aSopenharmony_ci        if (avctx->coded_width && avctx->coded_height)
196cabdff1aSopenharmony_ci            ret = ff_set_dimensions(avctx, avctx->coded_width, avctx->coded_height);
197cabdff1aSopenharmony_ci        else if (avctx->width && avctx->height)
198cabdff1aSopenharmony_ci            ret = ff_set_dimensions(avctx, avctx->width, avctx->height);
199cabdff1aSopenharmony_ci        if (ret < 0)
200cabdff1aSopenharmony_ci            goto free_and_end;
201cabdff1aSopenharmony_ci    }
202cabdff1aSopenharmony_ci
203cabdff1aSopenharmony_ci    if ((avctx->coded_width || avctx->coded_height || avctx->width || avctx->height)
204cabdff1aSopenharmony_ci        && (  av_image_check_size2(avctx->coded_width, avctx->coded_height, avctx->max_pixels, AV_PIX_FMT_NONE, 0, avctx) < 0
205cabdff1aSopenharmony_ci           || av_image_check_size2(avctx->width,       avctx->height,       avctx->max_pixels, AV_PIX_FMT_NONE, 0, avctx) < 0)) {
206cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_WARNING, "Ignoring invalid width/height values\n");
207cabdff1aSopenharmony_ci        ff_set_dimensions(avctx, 0, 0);
208cabdff1aSopenharmony_ci    }
209cabdff1aSopenharmony_ci
210cabdff1aSopenharmony_ci    if (avctx->width > 0 && avctx->height > 0) {
211cabdff1aSopenharmony_ci        if (av_image_check_sar(avctx->width, avctx->height,
212cabdff1aSopenharmony_ci                               avctx->sample_aspect_ratio) < 0) {
213cabdff1aSopenharmony_ci            av_log(avctx, AV_LOG_WARNING, "ignoring invalid SAR: %u/%u\n",
214cabdff1aSopenharmony_ci                   avctx->sample_aspect_ratio.num,
215cabdff1aSopenharmony_ci                   avctx->sample_aspect_ratio.den);
216cabdff1aSopenharmony_ci            avctx->sample_aspect_ratio = (AVRational){ 0, 1 };
217cabdff1aSopenharmony_ci        }
218cabdff1aSopenharmony_ci    }
219cabdff1aSopenharmony_ci
220cabdff1aSopenharmony_ci    if (avctx->sample_rate < 0) {
221cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "Invalid sample rate: %d\n", avctx->sample_rate);
222cabdff1aSopenharmony_ci        ret = AVERROR(EINVAL);
223cabdff1aSopenharmony_ci        goto free_and_end;
224cabdff1aSopenharmony_ci    }
225cabdff1aSopenharmony_ci    if (avctx->block_align < 0) {
226cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "Invalid block align: %d\n", avctx->block_align);
227cabdff1aSopenharmony_ci        ret = AVERROR(EINVAL);
228cabdff1aSopenharmony_ci        goto free_and_end;
229cabdff1aSopenharmony_ci    }
230cabdff1aSopenharmony_ci
231cabdff1aSopenharmony_ci#if FF_API_OLD_CHANNEL_LAYOUT
232cabdff1aSopenharmony_ciFF_DISABLE_DEPRECATION_WARNINGS
233cabdff1aSopenharmony_ci    /* compat wrapper for old-style callers */
234cabdff1aSopenharmony_ci    if (avctx->channel_layout && !avctx->channels)
235cabdff1aSopenharmony_ci        avctx->channels = av_popcount64(avctx->channel_layout);
236cabdff1aSopenharmony_ci
237cabdff1aSopenharmony_ci    if ((avctx->channels > 0 && avctx->ch_layout.nb_channels != avctx->channels) ||
238cabdff1aSopenharmony_ci        (avctx->channel_layout && (avctx->ch_layout.order != AV_CHANNEL_ORDER_NATIVE ||
239cabdff1aSopenharmony_ci                                   avctx->ch_layout.u.mask != avctx->channel_layout))) {
240cabdff1aSopenharmony_ci        if (avctx->channel_layout) {
241cabdff1aSopenharmony_ci            av_channel_layout_from_mask(&avctx->ch_layout, avctx->channel_layout);
242cabdff1aSopenharmony_ci        } else {
243cabdff1aSopenharmony_ci            avctx->ch_layout.order       = AV_CHANNEL_ORDER_UNSPEC;
244cabdff1aSopenharmony_ci            avctx->ch_layout.nb_channels = avctx->channels;
245cabdff1aSopenharmony_ci        }
246cabdff1aSopenharmony_ci    }
247cabdff1aSopenharmony_ciFF_ENABLE_DEPRECATION_WARNINGS
248cabdff1aSopenharmony_ci#endif
249cabdff1aSopenharmony_ci
250cabdff1aSopenharmony_ci    if (avctx->ch_layout.nb_channels > FF_SANE_NB_CHANNELS) {
251cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR, "Too many channels: %d\n", avctx->ch_layout.nb_channels);
252cabdff1aSopenharmony_ci        ret = AVERROR(EINVAL);
253cabdff1aSopenharmony_ci        goto free_and_end;
254cabdff1aSopenharmony_ci    }
255cabdff1aSopenharmony_ci
256cabdff1aSopenharmony_ci    avctx->frame_number = 0;
257cabdff1aSopenharmony_ci    avctx->codec_descriptor = avcodec_descriptor_get(avctx->codec_id);
258cabdff1aSopenharmony_ci
259cabdff1aSopenharmony_ci    if ((avctx->codec->capabilities & AV_CODEC_CAP_EXPERIMENTAL) &&
260cabdff1aSopenharmony_ci        avctx->strict_std_compliance > FF_COMPLIANCE_EXPERIMENTAL) {
261cabdff1aSopenharmony_ci        const char *codec_string = av_codec_is_encoder(codec) ? "encoder" : "decoder";
262cabdff1aSopenharmony_ci        const AVCodec *codec2;
263cabdff1aSopenharmony_ci        av_log(avctx, AV_LOG_ERROR,
264cabdff1aSopenharmony_ci               "The %s '%s' is experimental but experimental codecs are not enabled, "
265cabdff1aSopenharmony_ci               "add '-strict %d' if you want to use it.\n",
266cabdff1aSopenharmony_ci               codec_string, codec->name, FF_COMPLIANCE_EXPERIMENTAL);
267cabdff1aSopenharmony_ci        codec2 = av_codec_is_encoder(codec) ? avcodec_find_encoder(codec->id) : avcodec_find_decoder(codec->id);
268cabdff1aSopenharmony_ci        if (!(codec2->capabilities & AV_CODEC_CAP_EXPERIMENTAL))
269cabdff1aSopenharmony_ci            av_log(avctx, AV_LOG_ERROR, "Alternatively use the non experimental %s '%s'.\n",
270cabdff1aSopenharmony_ci                codec_string, codec2->name);
271cabdff1aSopenharmony_ci        ret = AVERROR_EXPERIMENTAL;
272cabdff1aSopenharmony_ci        goto free_and_end;
273cabdff1aSopenharmony_ci    }
274cabdff1aSopenharmony_ci
275cabdff1aSopenharmony_ci    if (avctx->codec_type == AVMEDIA_TYPE_AUDIO &&
276cabdff1aSopenharmony_ci        (!avctx->time_base.num || !avctx->time_base.den)) {
277cabdff1aSopenharmony_ci        avctx->time_base.num = 1;
278cabdff1aSopenharmony_ci        avctx->time_base.den = avctx->sample_rate;
279cabdff1aSopenharmony_ci    }
280cabdff1aSopenharmony_ci
281cabdff1aSopenharmony_ci    if (av_codec_is_encoder(avctx->codec))
282cabdff1aSopenharmony_ci        ret = ff_encode_preinit(avctx);
283cabdff1aSopenharmony_ci    else
284cabdff1aSopenharmony_ci        ret = ff_decode_preinit(avctx);
285cabdff1aSopenharmony_ci    if (ret < 0)
286cabdff1aSopenharmony_ci        goto free_and_end;
287cabdff1aSopenharmony_ci
288cabdff1aSopenharmony_ci    if (CONFIG_FRAME_THREAD_ENCODER && av_codec_is_encoder(avctx->codec)) {
289cabdff1aSopenharmony_ci        ret = ff_frame_thread_encoder_init(avctx);
290cabdff1aSopenharmony_ci        if (ret < 0)
291cabdff1aSopenharmony_ci            goto free_and_end;
292cabdff1aSopenharmony_ci    }
293cabdff1aSopenharmony_ci
294cabdff1aSopenharmony_ci    if (HAVE_THREADS
295cabdff1aSopenharmony_ci        && !(avci->frame_thread_encoder && (avctx->active_thread_type&FF_THREAD_FRAME))) {
296cabdff1aSopenharmony_ci        /* Frame-threaded decoders call FFCodec.init for their child contexts. */
297cabdff1aSopenharmony_ci        lock_avcodec(codec2);
298cabdff1aSopenharmony_ci        ret = ff_thread_init(avctx);
299cabdff1aSopenharmony_ci        unlock_avcodec(codec2);
300cabdff1aSopenharmony_ci        if (ret < 0) {
301cabdff1aSopenharmony_ci            goto free_and_end;
302cabdff1aSopenharmony_ci        }
303cabdff1aSopenharmony_ci    }
304cabdff1aSopenharmony_ci    if (!HAVE_THREADS && !(codec2->caps_internal & FF_CODEC_CAP_AUTO_THREADS))
305cabdff1aSopenharmony_ci        avctx->thread_count = 1;
306cabdff1aSopenharmony_ci
307cabdff1aSopenharmony_ci    if (!(avctx->active_thread_type & FF_THREAD_FRAME) ||
308cabdff1aSopenharmony_ci        avci->frame_thread_encoder) {
309cabdff1aSopenharmony_ci        if (codec2->init) {
310cabdff1aSopenharmony_ci            lock_avcodec(codec2);
311cabdff1aSopenharmony_ci            ret = codec2->init(avctx);
312cabdff1aSopenharmony_ci            unlock_avcodec(codec2);
313cabdff1aSopenharmony_ci            if (ret < 0) {
314cabdff1aSopenharmony_ci                avci->needs_close = codec2->caps_internal & FF_CODEC_CAP_INIT_CLEANUP;
315cabdff1aSopenharmony_ci                goto free_and_end;
316cabdff1aSopenharmony_ci            }
317cabdff1aSopenharmony_ci        }
318cabdff1aSopenharmony_ci        avci->needs_close = 1;
319cabdff1aSopenharmony_ci    }
320cabdff1aSopenharmony_ci
321cabdff1aSopenharmony_ci    ret=0;
322cabdff1aSopenharmony_ci
323cabdff1aSopenharmony_ci    if (av_codec_is_decoder(avctx->codec)) {
324cabdff1aSopenharmony_ci        if (!avctx->bit_rate)
325cabdff1aSopenharmony_ci            avctx->bit_rate = get_bit_rate(avctx);
326cabdff1aSopenharmony_ci
327cabdff1aSopenharmony_ci#if FF_API_OLD_CHANNEL_LAYOUT
328cabdff1aSopenharmony_ciFF_DISABLE_DEPRECATION_WARNINGS
329cabdff1aSopenharmony_ci        /* update the deprecated fields for old-style callers */
330cabdff1aSopenharmony_ci        avctx->channels = avctx->ch_layout.nb_channels;
331cabdff1aSopenharmony_ci        avctx->channel_layout = avctx->ch_layout.order == AV_CHANNEL_ORDER_NATIVE ?
332cabdff1aSopenharmony_ci                                avctx->ch_layout.u.mask : 0;
333cabdff1aSopenharmony_ci
334cabdff1aSopenharmony_ci        /* validate channel layout from the decoder */
335cabdff1aSopenharmony_ci        if (avctx->channel_layout) {
336cabdff1aSopenharmony_ci            int channels = av_get_channel_layout_nb_channels(avctx->channel_layout);
337cabdff1aSopenharmony_ci            if (!avctx->channels)
338cabdff1aSopenharmony_ci                avctx->channels = channels;
339cabdff1aSopenharmony_ci            else if (channels != avctx->channels) {
340cabdff1aSopenharmony_ci                char buf[512];
341cabdff1aSopenharmony_ci                av_get_channel_layout_string(buf, sizeof(buf), -1, avctx->channel_layout);
342cabdff1aSopenharmony_ci                av_log(avctx, AV_LOG_WARNING,
343cabdff1aSopenharmony_ci                       "Channel layout '%s' with %d channels does not match specified number of channels %d: "
344cabdff1aSopenharmony_ci                       "ignoring specified channel layout\n",
345cabdff1aSopenharmony_ci                       buf, channels, avctx->channels);
346cabdff1aSopenharmony_ci                avctx->channel_layout = 0;
347cabdff1aSopenharmony_ci            }
348cabdff1aSopenharmony_ci        }
349cabdff1aSopenharmony_ci        if (avctx->channels && avctx->channels < 0 ||
350cabdff1aSopenharmony_ci            avctx->channels > FF_SANE_NB_CHANNELS) {
351cabdff1aSopenharmony_ci            ret = AVERROR(EINVAL);
352cabdff1aSopenharmony_ci            goto free_and_end;
353cabdff1aSopenharmony_ci        }
354cabdff1aSopenharmony_ci        if (avctx->bits_per_coded_sample < 0) {
355cabdff1aSopenharmony_ci            ret = AVERROR(EINVAL);
356cabdff1aSopenharmony_ci            goto free_and_end;
357cabdff1aSopenharmony_ci        }
358cabdff1aSopenharmony_ciFF_ENABLE_DEPRECATION_WARNINGS
359cabdff1aSopenharmony_ci#endif
360cabdff1aSopenharmony_ci
361cabdff1aSopenharmony_ci#if FF_API_AVCTX_TIMEBASE
362cabdff1aSopenharmony_ci        if (avctx->framerate.num > 0 && avctx->framerate.den > 0)
363cabdff1aSopenharmony_ci            avctx->time_base = av_inv_q(av_mul_q(avctx->framerate, (AVRational){avctx->ticks_per_frame, 1}));
364cabdff1aSopenharmony_ci#endif
365cabdff1aSopenharmony_ci    }
366cabdff1aSopenharmony_ci    if (codec->priv_class)
367cabdff1aSopenharmony_ci        av_assert0(*(const AVClass **)avctx->priv_data == codec->priv_class);
368cabdff1aSopenharmony_ci
369cabdff1aSopenharmony_ciend:
370cabdff1aSopenharmony_ci
371cabdff1aSopenharmony_ci    return ret;
372cabdff1aSopenharmony_cifree_and_end:
373cabdff1aSopenharmony_ci    avcodec_close(avctx);
374cabdff1aSopenharmony_ci    goto end;
375cabdff1aSopenharmony_ci}
376cabdff1aSopenharmony_ci
377cabdff1aSopenharmony_civoid avcodec_flush_buffers(AVCodecContext *avctx)
378cabdff1aSopenharmony_ci{
379cabdff1aSopenharmony_ci    AVCodecInternal *avci = avctx->internal;
380cabdff1aSopenharmony_ci
381cabdff1aSopenharmony_ci    if (av_codec_is_encoder(avctx->codec)) {
382cabdff1aSopenharmony_ci        int caps = avctx->codec->capabilities;
383cabdff1aSopenharmony_ci
384cabdff1aSopenharmony_ci        if (!(caps & AV_CODEC_CAP_ENCODER_FLUSH)) {
385cabdff1aSopenharmony_ci            // Only encoders that explicitly declare support for it can be
386cabdff1aSopenharmony_ci            // flushed. Otherwise, this is a no-op.
387cabdff1aSopenharmony_ci            av_log(avctx, AV_LOG_WARNING, "Ignoring attempt to flush encoder "
388cabdff1aSopenharmony_ci                   "that doesn't support it\n");
389cabdff1aSopenharmony_ci            return;
390cabdff1aSopenharmony_ci        }
391cabdff1aSopenharmony_ci        if (avci->in_frame)
392cabdff1aSopenharmony_ci            av_frame_unref(avci->in_frame);
393cabdff1aSopenharmony_ci    } else {
394cabdff1aSopenharmony_ci        av_packet_unref(avci->last_pkt_props);
395cabdff1aSopenharmony_ci        while (av_fifo_read(avci->pkt_props, avci->last_pkt_props, 1) >= 0)
396cabdff1aSopenharmony_ci            av_packet_unref(avci->last_pkt_props);
397cabdff1aSopenharmony_ci
398cabdff1aSopenharmony_ci        av_packet_unref(avci->in_pkt);
399cabdff1aSopenharmony_ci
400cabdff1aSopenharmony_ci        avctx->pts_correction_last_pts =
401cabdff1aSopenharmony_ci        avctx->pts_correction_last_dts = INT64_MIN;
402cabdff1aSopenharmony_ci
403cabdff1aSopenharmony_ci        av_bsf_flush(avci->bsf);
404cabdff1aSopenharmony_ci    }
405cabdff1aSopenharmony_ci
406cabdff1aSopenharmony_ci    avci->draining      = 0;
407cabdff1aSopenharmony_ci    avci->draining_done = 0;
408cabdff1aSopenharmony_ci    avci->nb_draining_errors = 0;
409cabdff1aSopenharmony_ci    av_frame_unref(avci->buffer_frame);
410cabdff1aSopenharmony_ci    av_packet_unref(avci->buffer_pkt);
411cabdff1aSopenharmony_ci
412cabdff1aSopenharmony_ci    if (HAVE_THREADS && avctx->active_thread_type & FF_THREAD_FRAME)
413cabdff1aSopenharmony_ci        ff_thread_flush(avctx);
414cabdff1aSopenharmony_ci    else if (ffcodec(avctx->codec)->flush)
415cabdff1aSopenharmony_ci        ffcodec(avctx->codec)->flush(avctx);
416cabdff1aSopenharmony_ci}
417cabdff1aSopenharmony_ci
418cabdff1aSopenharmony_civoid avsubtitle_free(AVSubtitle *sub)
419cabdff1aSopenharmony_ci{
420cabdff1aSopenharmony_ci    int i;
421cabdff1aSopenharmony_ci
422cabdff1aSopenharmony_ci    for (i = 0; i < sub->num_rects; i++) {
423cabdff1aSopenharmony_ci        AVSubtitleRect *const rect = sub->rects[i];
424cabdff1aSopenharmony_ci
425cabdff1aSopenharmony_ci        av_freep(&rect->data[0]);
426cabdff1aSopenharmony_ci        av_freep(&rect->data[1]);
427cabdff1aSopenharmony_ci        av_freep(&rect->data[2]);
428cabdff1aSopenharmony_ci        av_freep(&rect->data[3]);
429cabdff1aSopenharmony_ci        av_freep(&rect->text);
430cabdff1aSopenharmony_ci        av_freep(&rect->ass);
431cabdff1aSopenharmony_ci
432cabdff1aSopenharmony_ci        av_freep(&sub->rects[i]);
433cabdff1aSopenharmony_ci    }
434cabdff1aSopenharmony_ci
435cabdff1aSopenharmony_ci    av_freep(&sub->rects);
436cabdff1aSopenharmony_ci
437cabdff1aSopenharmony_ci    memset(sub, 0, sizeof(*sub));
438cabdff1aSopenharmony_ci}
439cabdff1aSopenharmony_ci
440cabdff1aSopenharmony_ciav_cold int avcodec_close(AVCodecContext *avctx)
441cabdff1aSopenharmony_ci{
442cabdff1aSopenharmony_ci    int i;
443cabdff1aSopenharmony_ci
444cabdff1aSopenharmony_ci    if (!avctx)
445cabdff1aSopenharmony_ci        return 0;
446cabdff1aSopenharmony_ci
447cabdff1aSopenharmony_ci    if (avcodec_is_open(avctx)) {
448cabdff1aSopenharmony_ci        AVCodecInternal *avci = avctx->internal;
449cabdff1aSopenharmony_ci
450cabdff1aSopenharmony_ci        if (CONFIG_FRAME_THREAD_ENCODER &&
451cabdff1aSopenharmony_ci            avci->frame_thread_encoder && avctx->thread_count > 1) {
452cabdff1aSopenharmony_ci            ff_frame_thread_encoder_free(avctx);
453cabdff1aSopenharmony_ci        }
454cabdff1aSopenharmony_ci        if (HAVE_THREADS && avci->thread_ctx)
455cabdff1aSopenharmony_ci            ff_thread_free(avctx);
456cabdff1aSopenharmony_ci        if (avci->needs_close && ffcodec(avctx->codec)->close)
457cabdff1aSopenharmony_ci            ffcodec(avctx->codec)->close(avctx);
458cabdff1aSopenharmony_ci        avci->byte_buffer_size = 0;
459cabdff1aSopenharmony_ci        av_freep(&avci->byte_buffer);
460cabdff1aSopenharmony_ci        av_frame_free(&avci->buffer_frame);
461cabdff1aSopenharmony_ci        av_packet_free(&avci->buffer_pkt);
462cabdff1aSopenharmony_ci        if (avci->pkt_props) {
463cabdff1aSopenharmony_ci            while (av_fifo_can_read(avci->pkt_props)) {
464cabdff1aSopenharmony_ci                av_packet_unref(avci->last_pkt_props);
465cabdff1aSopenharmony_ci                av_fifo_read(avci->pkt_props, avci->last_pkt_props, 1);
466cabdff1aSopenharmony_ci            }
467cabdff1aSopenharmony_ci            av_fifo_freep2(&avci->pkt_props);
468cabdff1aSopenharmony_ci        }
469cabdff1aSopenharmony_ci        av_packet_free(&avci->last_pkt_props);
470cabdff1aSopenharmony_ci
471cabdff1aSopenharmony_ci        av_packet_free(&avci->in_pkt);
472cabdff1aSopenharmony_ci        av_frame_free(&avci->in_frame);
473cabdff1aSopenharmony_ci
474cabdff1aSopenharmony_ci        av_buffer_unref(&avci->pool);
475cabdff1aSopenharmony_ci
476cabdff1aSopenharmony_ci        if (avctx->hwaccel && avctx->hwaccel->uninit)
477cabdff1aSopenharmony_ci            avctx->hwaccel->uninit(avctx);
478cabdff1aSopenharmony_ci        av_freep(&avci->hwaccel_priv_data);
479cabdff1aSopenharmony_ci
480cabdff1aSopenharmony_ci        av_bsf_free(&avci->bsf);
481cabdff1aSopenharmony_ci
482cabdff1aSopenharmony_ci        av_channel_layout_uninit(&avci->initial_ch_layout);
483cabdff1aSopenharmony_ci
484cabdff1aSopenharmony_ci        av_freep(&avctx->internal);
485cabdff1aSopenharmony_ci    }
486cabdff1aSopenharmony_ci
487cabdff1aSopenharmony_ci    for (i = 0; i < avctx->nb_coded_side_data; i++)
488cabdff1aSopenharmony_ci        av_freep(&avctx->coded_side_data[i].data);
489cabdff1aSopenharmony_ci    av_freep(&avctx->coded_side_data);
490cabdff1aSopenharmony_ci    avctx->nb_coded_side_data = 0;
491cabdff1aSopenharmony_ci
492cabdff1aSopenharmony_ci    av_buffer_unref(&avctx->hw_frames_ctx);
493cabdff1aSopenharmony_ci    av_buffer_unref(&avctx->hw_device_ctx);
494cabdff1aSopenharmony_ci
495cabdff1aSopenharmony_ci    if (avctx->priv_data && avctx->codec && avctx->codec->priv_class)
496cabdff1aSopenharmony_ci        av_opt_free(avctx->priv_data);
497cabdff1aSopenharmony_ci    av_opt_free(avctx);
498cabdff1aSopenharmony_ci    av_freep(&avctx->priv_data);
499cabdff1aSopenharmony_ci    if (av_codec_is_encoder(avctx->codec)) {
500cabdff1aSopenharmony_ci        av_freep(&avctx->extradata);
501cabdff1aSopenharmony_ci        avctx->extradata_size = 0;
502cabdff1aSopenharmony_ci    } else if (av_codec_is_decoder(avctx->codec))
503cabdff1aSopenharmony_ci        av_freep(&avctx->subtitle_header);
504cabdff1aSopenharmony_ci
505cabdff1aSopenharmony_ci    avctx->codec = NULL;
506cabdff1aSopenharmony_ci    avctx->active_thread_type = 0;
507cabdff1aSopenharmony_ci
508cabdff1aSopenharmony_ci    return 0;
509cabdff1aSopenharmony_ci}
510cabdff1aSopenharmony_ci
511cabdff1aSopenharmony_cistatic const char *unknown_if_null(const char *str)
512cabdff1aSopenharmony_ci{
513cabdff1aSopenharmony_ci    return str ? str : "unknown";
514cabdff1aSopenharmony_ci}
515cabdff1aSopenharmony_ci
516cabdff1aSopenharmony_civoid avcodec_string(char *buf, int buf_size, AVCodecContext *enc, int encode)
517cabdff1aSopenharmony_ci{
518cabdff1aSopenharmony_ci    const char *codec_type;
519cabdff1aSopenharmony_ci    const char *codec_name;
520cabdff1aSopenharmony_ci    const char *profile = NULL;
521cabdff1aSopenharmony_ci    AVBPrint bprint;
522cabdff1aSopenharmony_ci    int64_t bitrate;
523cabdff1aSopenharmony_ci    int new_line = 0;
524cabdff1aSopenharmony_ci    AVRational display_aspect_ratio;
525cabdff1aSopenharmony_ci    const char *separator = enc->dump_separator ? (const char *)enc->dump_separator : ", ";
526cabdff1aSopenharmony_ci    const char *str;
527cabdff1aSopenharmony_ci
528cabdff1aSopenharmony_ci    if (!buf || buf_size <= 0)
529cabdff1aSopenharmony_ci        return;
530cabdff1aSopenharmony_ci    av_bprint_init_for_buffer(&bprint, buf, buf_size);
531cabdff1aSopenharmony_ci    codec_type = av_get_media_type_string(enc->codec_type);
532cabdff1aSopenharmony_ci    codec_name = avcodec_get_name(enc->codec_id);
533cabdff1aSopenharmony_ci    profile = avcodec_profile_name(enc->codec_id, enc->profile);
534cabdff1aSopenharmony_ci
535cabdff1aSopenharmony_ci    av_bprintf(&bprint, "%s: %s", codec_type ? codec_type : "unknown",
536cabdff1aSopenharmony_ci               codec_name);
537cabdff1aSopenharmony_ci    buf[0] ^= 'a' ^ 'A'; /* first letter in uppercase */
538cabdff1aSopenharmony_ci
539cabdff1aSopenharmony_ci    if (enc->codec && strcmp(enc->codec->name, codec_name))
540cabdff1aSopenharmony_ci        av_bprintf(&bprint, " (%s)", enc->codec->name);
541cabdff1aSopenharmony_ci
542cabdff1aSopenharmony_ci    if (profile)
543cabdff1aSopenharmony_ci        av_bprintf(&bprint, " (%s)", profile);
544cabdff1aSopenharmony_ci    if (   enc->codec_type == AVMEDIA_TYPE_VIDEO
545cabdff1aSopenharmony_ci        && av_log_get_level() >= AV_LOG_VERBOSE
546cabdff1aSopenharmony_ci        && enc->refs)
547cabdff1aSopenharmony_ci        av_bprintf(&bprint, ", %d reference frame%s",
548cabdff1aSopenharmony_ci                   enc->refs, enc->refs > 1 ? "s" : "");
549cabdff1aSopenharmony_ci
550cabdff1aSopenharmony_ci    if (enc->codec_tag)
551cabdff1aSopenharmony_ci        av_bprintf(&bprint, " (%s / 0x%04X)",
552cabdff1aSopenharmony_ci                   av_fourcc2str(enc->codec_tag), enc->codec_tag);
553cabdff1aSopenharmony_ci
554cabdff1aSopenharmony_ci    switch (enc->codec_type) {
555cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_VIDEO:
556cabdff1aSopenharmony_ci        {
557cabdff1aSopenharmony_ci            unsigned len;
558cabdff1aSopenharmony_ci
559cabdff1aSopenharmony_ci            av_bprintf(&bprint, "%s%s", separator,
560cabdff1aSopenharmony_ci                       enc->pix_fmt == AV_PIX_FMT_NONE ? "none" :
561cabdff1aSopenharmony_ci                       unknown_if_null(av_get_pix_fmt_name(enc->pix_fmt)));
562cabdff1aSopenharmony_ci
563cabdff1aSopenharmony_ci            av_bprint_chars(&bprint, '(', 1);
564cabdff1aSopenharmony_ci            len = bprint.len;
565cabdff1aSopenharmony_ci
566cabdff1aSopenharmony_ci            /* The following check ensures that '(' has been written
567cabdff1aSopenharmony_ci             * and therefore allows us to erase it if it turns out
568cabdff1aSopenharmony_ci             * to be unnecessary. */
569cabdff1aSopenharmony_ci            if (!av_bprint_is_complete(&bprint))
570cabdff1aSopenharmony_ci                return;
571cabdff1aSopenharmony_ci
572cabdff1aSopenharmony_ci            if (enc->bits_per_raw_sample && enc->pix_fmt != AV_PIX_FMT_NONE &&
573cabdff1aSopenharmony_ci                enc->bits_per_raw_sample < av_pix_fmt_desc_get(enc->pix_fmt)->comp[0].depth)
574cabdff1aSopenharmony_ci                av_bprintf(&bprint, "%d bpc, ", enc->bits_per_raw_sample);
575cabdff1aSopenharmony_ci            if (enc->color_range != AVCOL_RANGE_UNSPECIFIED &&
576cabdff1aSopenharmony_ci                (str = av_color_range_name(enc->color_range)))
577cabdff1aSopenharmony_ci                av_bprintf(&bprint, "%s, ", str);
578cabdff1aSopenharmony_ci
579cabdff1aSopenharmony_ci            if (enc->colorspace != AVCOL_SPC_UNSPECIFIED ||
580cabdff1aSopenharmony_ci                enc->color_primaries != AVCOL_PRI_UNSPECIFIED ||
581cabdff1aSopenharmony_ci                enc->color_trc != AVCOL_TRC_UNSPECIFIED) {
582cabdff1aSopenharmony_ci                const char *col = unknown_if_null(av_color_space_name(enc->colorspace));
583cabdff1aSopenharmony_ci                const char *pri = unknown_if_null(av_color_primaries_name(enc->color_primaries));
584cabdff1aSopenharmony_ci                const char *trc = unknown_if_null(av_color_transfer_name(enc->color_trc));
585cabdff1aSopenharmony_ci                if (strcmp(col, pri) || strcmp(col, trc)) {
586cabdff1aSopenharmony_ci                    new_line = 1;
587cabdff1aSopenharmony_ci                    av_bprintf(&bprint, "%s/%s/%s, ", col, pri, trc);
588cabdff1aSopenharmony_ci                } else
589cabdff1aSopenharmony_ci                    av_bprintf(&bprint, "%s, ", col);
590cabdff1aSopenharmony_ci            }
591cabdff1aSopenharmony_ci
592cabdff1aSopenharmony_ci            if (enc->field_order != AV_FIELD_UNKNOWN) {
593cabdff1aSopenharmony_ci                const char *field_order = "progressive";
594cabdff1aSopenharmony_ci                if (enc->field_order == AV_FIELD_TT)
595cabdff1aSopenharmony_ci                    field_order = "top first";
596cabdff1aSopenharmony_ci                else if (enc->field_order == AV_FIELD_BB)
597cabdff1aSopenharmony_ci                    field_order = "bottom first";
598cabdff1aSopenharmony_ci                else if (enc->field_order == AV_FIELD_TB)
599cabdff1aSopenharmony_ci                    field_order = "top coded first (swapped)";
600cabdff1aSopenharmony_ci                else if (enc->field_order == AV_FIELD_BT)
601cabdff1aSopenharmony_ci                    field_order = "bottom coded first (swapped)";
602cabdff1aSopenharmony_ci
603cabdff1aSopenharmony_ci                av_bprintf(&bprint, "%s, ", field_order);
604cabdff1aSopenharmony_ci            }
605cabdff1aSopenharmony_ci
606cabdff1aSopenharmony_ci            if (av_log_get_level() >= AV_LOG_VERBOSE &&
607cabdff1aSopenharmony_ci                enc->chroma_sample_location != AVCHROMA_LOC_UNSPECIFIED &&
608cabdff1aSopenharmony_ci                (str = av_chroma_location_name(enc->chroma_sample_location)))
609cabdff1aSopenharmony_ci                av_bprintf(&bprint, "%s, ", str);
610cabdff1aSopenharmony_ci
611cabdff1aSopenharmony_ci            if (len == bprint.len) {
612cabdff1aSopenharmony_ci                bprint.str[len - 1] = '\0';
613cabdff1aSopenharmony_ci                bprint.len--;
614cabdff1aSopenharmony_ci            } else {
615cabdff1aSopenharmony_ci                if (bprint.len - 2 < bprint.size) {
616cabdff1aSopenharmony_ci                    /* Erase the last ", " */
617cabdff1aSopenharmony_ci                    bprint.len -= 2;
618cabdff1aSopenharmony_ci                    bprint.str[bprint.len] = '\0';
619cabdff1aSopenharmony_ci                }
620cabdff1aSopenharmony_ci                av_bprint_chars(&bprint, ')', 1);
621cabdff1aSopenharmony_ci            }
622cabdff1aSopenharmony_ci        }
623cabdff1aSopenharmony_ci
624cabdff1aSopenharmony_ci        if (enc->width) {
625cabdff1aSopenharmony_ci            av_bprintf(&bprint, "%s%dx%d", new_line ? separator : ", ",
626cabdff1aSopenharmony_ci                       enc->width, enc->height);
627cabdff1aSopenharmony_ci
628cabdff1aSopenharmony_ci            if (av_log_get_level() >= AV_LOG_VERBOSE &&
629cabdff1aSopenharmony_ci                (enc->width != enc->coded_width ||
630cabdff1aSopenharmony_ci                 enc->height != enc->coded_height))
631cabdff1aSopenharmony_ci                av_bprintf(&bprint, " (%dx%d)",
632cabdff1aSopenharmony_ci                           enc->coded_width, enc->coded_height);
633cabdff1aSopenharmony_ci
634cabdff1aSopenharmony_ci            if (enc->sample_aspect_ratio.num) {
635cabdff1aSopenharmony_ci                av_reduce(&display_aspect_ratio.num, &display_aspect_ratio.den,
636cabdff1aSopenharmony_ci                          enc->width * (int64_t)enc->sample_aspect_ratio.num,
637cabdff1aSopenharmony_ci                          enc->height * (int64_t)enc->sample_aspect_ratio.den,
638cabdff1aSopenharmony_ci                          1024 * 1024);
639cabdff1aSopenharmony_ci                av_bprintf(&bprint, " [SAR %d:%d DAR %d:%d]",
640cabdff1aSopenharmony_ci                         enc->sample_aspect_ratio.num, enc->sample_aspect_ratio.den,
641cabdff1aSopenharmony_ci                         display_aspect_ratio.num, display_aspect_ratio.den);
642cabdff1aSopenharmony_ci            }
643cabdff1aSopenharmony_ci            if (av_log_get_level() >= AV_LOG_DEBUG) {
644cabdff1aSopenharmony_ci                int g = av_gcd(enc->time_base.num, enc->time_base.den);
645cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", %d/%d",
646cabdff1aSopenharmony_ci                           enc->time_base.num / g, enc->time_base.den / g);
647cabdff1aSopenharmony_ci            }
648cabdff1aSopenharmony_ci        }
649cabdff1aSopenharmony_ci        if (encode) {
650cabdff1aSopenharmony_ci            av_bprintf(&bprint, ", q=%d-%d", enc->qmin, enc->qmax);
651cabdff1aSopenharmony_ci        } else {
652cabdff1aSopenharmony_ci            if (enc->properties & FF_CODEC_PROPERTY_CLOSED_CAPTIONS)
653cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", Closed Captions");
654cabdff1aSopenharmony_ci            if (enc->properties & FF_CODEC_PROPERTY_FILM_GRAIN)
655cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", Film Grain");
656cabdff1aSopenharmony_ci            if (enc->properties & FF_CODEC_PROPERTY_LOSSLESS)
657cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", lossless");
658cabdff1aSopenharmony_ci        }
659cabdff1aSopenharmony_ci        break;
660cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_AUDIO:
661cabdff1aSopenharmony_ci        av_bprintf(&bprint, "%s", separator);
662cabdff1aSopenharmony_ci
663cabdff1aSopenharmony_ci        if (enc->sample_rate) {
664cabdff1aSopenharmony_ci            av_bprintf(&bprint, "%d Hz, ", enc->sample_rate);
665cabdff1aSopenharmony_ci        }
666cabdff1aSopenharmony_ci        {
667cabdff1aSopenharmony_ci            char buf[512];
668cabdff1aSopenharmony_ci            int ret = av_channel_layout_describe(&enc->ch_layout, buf, sizeof(buf));
669cabdff1aSopenharmony_ci            if (ret >= 0)
670cabdff1aSopenharmony_ci                av_bprintf(&bprint, "%s", buf);
671cabdff1aSopenharmony_ci        }
672cabdff1aSopenharmony_ci        if (enc->sample_fmt != AV_SAMPLE_FMT_NONE &&
673cabdff1aSopenharmony_ci            (str = av_get_sample_fmt_name(enc->sample_fmt))) {
674cabdff1aSopenharmony_ci            av_bprintf(&bprint, ", %s", str);
675cabdff1aSopenharmony_ci        }
676cabdff1aSopenharmony_ci        if (   enc->bits_per_raw_sample > 0
677cabdff1aSopenharmony_ci            && enc->bits_per_raw_sample != av_get_bytes_per_sample(enc->sample_fmt) * 8)
678cabdff1aSopenharmony_ci            av_bprintf(&bprint, " (%d bit)", enc->bits_per_raw_sample);
679cabdff1aSopenharmony_ci        if (av_log_get_level() >= AV_LOG_VERBOSE) {
680cabdff1aSopenharmony_ci            if (enc->initial_padding)
681cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", delay %d", enc->initial_padding);
682cabdff1aSopenharmony_ci            if (enc->trailing_padding)
683cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", padding %d", enc->trailing_padding);
684cabdff1aSopenharmony_ci        }
685cabdff1aSopenharmony_ci        break;
686cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_DATA:
687cabdff1aSopenharmony_ci        if (av_log_get_level() >= AV_LOG_DEBUG) {
688cabdff1aSopenharmony_ci            int g = av_gcd(enc->time_base.num, enc->time_base.den);
689cabdff1aSopenharmony_ci            if (g)
690cabdff1aSopenharmony_ci                av_bprintf(&bprint, ", %d/%d",
691cabdff1aSopenharmony_ci                           enc->time_base.num / g, enc->time_base.den / g);
692cabdff1aSopenharmony_ci        }
693cabdff1aSopenharmony_ci        break;
694cabdff1aSopenharmony_ci    case AVMEDIA_TYPE_SUBTITLE:
695cabdff1aSopenharmony_ci        if (enc->width)
696cabdff1aSopenharmony_ci            av_bprintf(&bprint, ", %dx%d", enc->width, enc->height);
697cabdff1aSopenharmony_ci        break;
698cabdff1aSopenharmony_ci    default:
699cabdff1aSopenharmony_ci        return;
700cabdff1aSopenharmony_ci    }
701cabdff1aSopenharmony_ci    if (encode) {
702cabdff1aSopenharmony_ci        if (enc->flags & AV_CODEC_FLAG_PASS1)
703cabdff1aSopenharmony_ci            av_bprintf(&bprint, ", pass 1");
704cabdff1aSopenharmony_ci        if (enc->flags & AV_CODEC_FLAG_PASS2)
705cabdff1aSopenharmony_ci            av_bprintf(&bprint, ", pass 2");
706cabdff1aSopenharmony_ci    }
707cabdff1aSopenharmony_ci    bitrate = get_bit_rate(enc);
708cabdff1aSopenharmony_ci    if (bitrate != 0) {
709cabdff1aSopenharmony_ci        av_bprintf(&bprint, ", %"PRId64" kb/s", bitrate / 1000);
710cabdff1aSopenharmony_ci    } else if (enc->rc_max_rate > 0) {
711cabdff1aSopenharmony_ci        av_bprintf(&bprint, ", max. %"PRId64" kb/s", enc->rc_max_rate / 1000);
712cabdff1aSopenharmony_ci    }
713cabdff1aSopenharmony_ci}
714cabdff1aSopenharmony_ci
715cabdff1aSopenharmony_ciint avcodec_is_open(AVCodecContext *s)
716cabdff1aSopenharmony_ci{
717cabdff1aSopenharmony_ci    return !!s->internal;
718cabdff1aSopenharmony_ci}
719