FFmpeg
Data Structures | Macros | Enumerations | Functions
codec_internal.h File Reference
#include <stdint.h>
#include "libavutil/attributes.h"
#include "avcodec.h"
#include "codec.h"
#include "config.h"

Go to the source code of this file.

Data Structures

struct  FFCodecDefault
 
struct  FFCodec
 

Macros

#define FF_CODEC_CAP_NOT_INIT_THREADSAFE   (1 << 0)
 The codec is not known to be init-threadsafe (i.e. More...
 
#define FF_CODEC_CAP_INIT_CLEANUP   (1 << 1)
 The codec allows calling the close function for deallocation even if the init function returned a failure. More...
 
#define FF_CODEC_CAP_SETS_PKT_DTS   (1 << 2)
 Decoders marked with FF_CODEC_CAP_SETS_PKT_DTS want to set AVFrame.pkt_dts manually. More...
 
#define FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM   (1 << 3)
 The decoder extracts and fills its parameters even if the frame is skipped due to the skip_frame setting. More...
 
#define FF_CODEC_CAP_EXPORTS_CROPPING   (1 << 4)
 The decoder sets the cropping fields in the output frames manually. More...
 
#define FF_CODEC_CAP_SLICE_THREAD_HAS_MF   (1 << 5)
 Codec initializes slice-based threading with a main function. More...
 
#define FF_CODEC_CAP_USES_PROGRESSFRAMES   (1 << 6)
 The decoder might make use of the ProgressFrame API. More...
 
#define FF_CODEC_CAP_AUTO_THREADS   (1 << 7)
 Codec handles avctx->thread_count == 0 (auto) internally. More...
 
#define FF_CODEC_CAP_SETS_FRAME_PROPS   (1 << 8)
 Codec handles output frame properties internally instead of letting the internal logic derive them from AVCodecInternal.last_pkt_props. More...
 
#define FF_CODEC_CAP_ICC_PROFILES   (1 << 9)
 Codec supports embedded ICC profiles (AV_FRAME_DATA_ICC_PROFILE). More...
 
#define FF_CODEC_CAP_EOF_FLUSH   (1 << 10)
 The encoder has AV_CODEC_CAP_DELAY set, but does not actually have delay - it only wants to be flushed at the end to update some context variables (e.g. More...
 
#define FF_CODEC_TAGS_END   -1
 FFCodec.codec_tags termination value. More...
 
#define CODEC_LONG_NAME(str)   .p.long_name = str
 
#define UPDATE_THREAD_CONTEXT(func)   .update_thread_context = NULL
 
#define UPDATE_THREAD_CONTEXT_FOR_USER(func)   .update_thread_context_for_user = NULL
 
#define FF_CODEC_DECODE_CB(func)
 
#define FF_CODEC_DECODE_SUB_CB(func)
 
#define FF_CODEC_RECEIVE_FRAME_CB(func)
 
#define FF_CODEC_ENCODE_CB(func)
 
#define FF_CODEC_ENCODE_SUB_CB(func)
 
#define FF_CODEC_RECEIVE_PACKET_CB(func)
 

Enumerations

enum  FFCodecType {
  FF_CODEC_CB_TYPE_DECODE, FF_CODEC_CB_TYPE_DECODE_SUB, FF_CODEC_CB_TYPE_RECEIVE_FRAME, FF_CODEC_CB_TYPE_ENCODE,
  FF_CODEC_CB_TYPE_ENCODE_SUB, FF_CODEC_CB_TYPE_RECEIVE_PACKET
}
 

Functions

int ff_default_get_supported_config (const AVCodecContext *avctx, const AVCodec *codec, enum AVCodecConfig config, unsigned flags, const void **out_configs, int *out_num_configs)
 Default implementation for avcodec_get_supported_config(). More...
 
static const av_always_inline FFCodecffcodec (const AVCodec *codec)
 

Macro Definition Documentation

◆ FF_CODEC_CAP_NOT_INIT_THREADSAFE

#define FF_CODEC_CAP_NOT_INIT_THREADSAFE   (1 << 0)

The codec is not known to be init-threadsafe (i.e.

it might be unsafe to initialize this codec and another codec concurrently, typically because the codec calls external APIs that are not known to be thread-safe). Therefore calling the codec's init function needs to be guarded with a lock.

Definition at line 35 of file codec_internal.h.

◆ FF_CODEC_CAP_INIT_CLEANUP

#define FF_CODEC_CAP_INIT_CLEANUP   (1 << 1)

The codec allows calling the close function for deallocation even if the init function returned a failure.

Without this capability flag, a codec does such cleanup internally when returning failures from the init function and does not expect the close function to be called at all.

Definition at line 43 of file codec_internal.h.

◆ FF_CODEC_CAP_SETS_PKT_DTS

#define FF_CODEC_CAP_SETS_PKT_DTS   (1 << 2)

Decoders marked with FF_CODEC_CAP_SETS_PKT_DTS want to set AVFrame.pkt_dts manually.

If the flag is set, decode.c won't overwrite this field. If it's unset, decode.c tries to guess the pkt_dts field from the input AVPacket.

Definition at line 50 of file codec_internal.h.

◆ FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM

#define FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM   (1 << 3)

The decoder extracts and fills its parameters even if the frame is skipped due to the skip_frame setting.

Definition at line 55 of file codec_internal.h.

◆ FF_CODEC_CAP_EXPORTS_CROPPING

#define FF_CODEC_CAP_EXPORTS_CROPPING   (1 << 4)

The decoder sets the cropping fields in the output frames manually.

If this cap is set, the generic code will initialize output frame dimensions to coded rather than display values.

Definition at line 61 of file codec_internal.h.

◆ FF_CODEC_CAP_SLICE_THREAD_HAS_MF

#define FF_CODEC_CAP_SLICE_THREAD_HAS_MF   (1 << 5)

Codec initializes slice-based threading with a main function.

Definition at line 65 of file codec_internal.h.

◆ FF_CODEC_CAP_USES_PROGRESSFRAMES

#define FF_CODEC_CAP_USES_PROGRESSFRAMES   (1 << 6)

The decoder might make use of the ProgressFrame API.

Definition at line 69 of file codec_internal.h.

◆ FF_CODEC_CAP_AUTO_THREADS

#define FF_CODEC_CAP_AUTO_THREADS   (1 << 7)

Codec handles avctx->thread_count == 0 (auto) internally.

Definition at line 73 of file codec_internal.h.

◆ FF_CODEC_CAP_SETS_FRAME_PROPS

#define FF_CODEC_CAP_SETS_FRAME_PROPS   (1 << 8)

Codec handles output frame properties internally instead of letting the internal logic derive them from AVCodecInternal.last_pkt_props.

Definition at line 78 of file codec_internal.h.

◆ FF_CODEC_CAP_ICC_PROFILES

#define FF_CODEC_CAP_ICC_PROFILES   (1 << 9)

Codec supports embedded ICC profiles (AV_FRAME_DATA_ICC_PROFILE).

Definition at line 82 of file codec_internal.h.

◆ FF_CODEC_CAP_EOF_FLUSH

#define FF_CODEC_CAP_EOF_FLUSH   (1 << 10)

The encoder has AV_CODEC_CAP_DELAY set, but does not actually have delay - it only wants to be flushed at the end to update some context variables (e.g.

2pass stats) or produce a trailing packet. Besides that it immediately produces exactly one output packet per each input frame, just as no-delay encoders do.

Definition at line 90 of file codec_internal.h.

◆ FF_CODEC_TAGS_END

#define FF_CODEC_TAGS_END   -1

FFCodec.codec_tags termination value.

Definition at line 95 of file codec_internal.h.

◆ CODEC_LONG_NAME

#define CODEC_LONG_NAME (   str)    .p.long_name = str

Definition at line 296 of file codec_internal.h.

◆ UPDATE_THREAD_CONTEXT

#define UPDATE_THREAD_CONTEXT (   func)    .update_thread_context = NULL

Definition at line 305 of file codec_internal.h.

◆ UPDATE_THREAD_CONTEXT_FOR_USER

#define UPDATE_THREAD_CONTEXT_FOR_USER (   func)    .update_thread_context_for_user = NULL

Definition at line 307 of file codec_internal.h.

◆ FF_CODEC_DECODE_CB

#define FF_CODEC_DECODE_CB (   func)
Value:
.cb.decode = (func)

Definition at line 311 of file codec_internal.h.

◆ FF_CODEC_DECODE_SUB_CB

#define FF_CODEC_DECODE_SUB_CB (   func)
Value:
.cb.decode_sub = (func)

Definition at line 314 of file codec_internal.h.

◆ FF_CODEC_RECEIVE_FRAME_CB

#define FF_CODEC_RECEIVE_FRAME_CB (   func)
Value:
.cb.receive_frame = (func)

Definition at line 317 of file codec_internal.h.

◆ FF_CODEC_ENCODE_CB

#define FF_CODEC_ENCODE_CB (   func)
Value:
.cb.encode = (func)

Definition at line 320 of file codec_internal.h.

◆ FF_CODEC_ENCODE_SUB_CB

#define FF_CODEC_ENCODE_SUB_CB (   func)
Value:
.cb.encode_sub = (func)

Definition at line 323 of file codec_internal.h.

◆ FF_CODEC_RECEIVE_PACKET_CB

#define FF_CODEC_RECEIVE_PACKET_CB (   func)
Value:
.cb.receive_packet = (func)

Definition at line 326 of file codec_internal.h.

Enumeration Type Documentation

◆ FFCodecType

Enumerator
FF_CODEC_CB_TYPE_DECODE 
FF_CODEC_CB_TYPE_DECODE_SUB 
FF_CODEC_CB_TYPE_RECEIVE_FRAME 
FF_CODEC_CB_TYPE_ENCODE 
FF_CODEC_CB_TYPE_ENCODE_SUB 
FF_CODEC_CB_TYPE_RECEIVE_PACKET 

Definition at line 106 of file codec_internal.h.

Function Documentation

◆ ff_default_get_supported_config()

int ff_default_get_supported_config ( const AVCodecContext avctx,
const AVCodec codec,
enum AVCodecConfig  config,
unsigned  flags,
const void **  out_configs,
int *  out_num_configs 
)

Default implementation for avcodec_get_supported_config().

Will return the relevant fields from AVCodec if present, or NULL otherwise.

For AVCODEC_CONFIG_COLOR_RANGE, the output will depend on the bitmask in FFCodec.color_ranges, with a value of 0 returning NULL.

Definition at line 757 of file avcodec.c.

Referenced by av1_get_supported_config(), avcodec_get_supported_config(), and libx265_get_supported_config().

◆ ffcodec()

static const av_always_inline FFCodec* ffcodec ( const AVCodec codec)
static
func
int(* func)(AVBPrint *dst, const char *in, const char *arg)
Definition: jacosubdec.c:68
FF_CODEC_CB_TYPE_RECEIVE_PACKET
@ FF_CODEC_CB_TYPE_RECEIVE_PACKET
Definition: codec_internal.h:124
FF_CODEC_CB_TYPE_ENCODE_SUB
@ FF_CODEC_CB_TYPE_ENCODE_SUB
Definition: codec_internal.h:121
FF_CODEC_CB_TYPE_DECODE
@ FF_CODEC_CB_TYPE_DECODE
Definition: codec_internal.h:109
FF_CODEC_CB_TYPE_ENCODE
@ FF_CODEC_CB_TYPE_ENCODE
Definition: codec_internal.h:118
FF_CODEC_CB_TYPE_DECODE_SUB
@ FF_CODEC_CB_TYPE_DECODE_SUB
Definition: codec_internal.h:112
FF_CODEC_CB_TYPE_RECEIVE_FRAME
@ FF_CODEC_CB_TYPE_RECEIVE_FRAME
Definition: codec_internal.h:115