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