| /* |
| * Copyright (c) 2021, Alliance for Open Media. All rights reserved |
| * |
| * This source code is subject to the terms of the BSD 3-Clause Clear License |
| * and the Alliance for Open Media Patent License 1.0. If the BSD 3-Clause Clear |
| * License was not distributed with this source code in the LICENSE file, you |
| * can obtain it at aomedia.org/license/software-license/bsd-3-c-c/. If the |
| * Alliance for Open Media Patent License 1.0 was not distributed with this |
| * source code in the PATENTS file, you can obtain it at |
| * aomedia.org/license/patent-license/. |
| */ |
| |
| /////////////////////////////////////////////////////////////////////////////// |
| // Internal implementation details |
| /////////////////////////////////////////////////////////////////////////////// |
| // |
| // There are two levels of interfaces used to access the AOM codec: the |
| // the aom_codec_iface and the aom_codec_ctx. |
| // |
| // 1. aom_codec_iface_t |
| // (Related files: aom/aom_codec.h, aom/src/aom_codec.c, |
| // aom/internal/aom_codec_internal.h, av1/av1_cx_iface.c, |
| // av1/av1_dx_iface.c) |
| // |
| // Used to initialize the codec context, which contains the configuration for |
| // for modifying the encoder/decoder during run-time. See the other |
| // documentation in this header file for more details. For the most part, |
| // users will call helper functions, such as aom_codec_iface_name, |
| // aom_codec_get_caps, etc., to interact with it. |
| // |
| // The main purpose of the aom_codec_iface_t is to provide a way to generate |
| // a default codec config, find out what capabilities the implementation has, |
| // and create an aom_codec_ctx_t (which is actually used to interact with the |
| // codec). |
| // |
| // Note that the implementations for the AV1 algorithm are located in |
| // av1/av1_cx_iface.c and av1/av1_dx_iface.c |
| // |
| // |
| // 2. aom_codec_ctx_t |
| // (Related files: aom/aom_codec.h, av1/av1_cx_iface.c, av1/av1_dx_iface.c, |
| // aom/aomcx.h, aom/aomdx.h, aom/src/aom_encoder.c, aom/src/aom_decoder.c) |
| // |
| // The actual interface between user code and the codec. It stores the name |
| // of the codec, a pointer back to the aom_codec_iface_t that initialized it, |
| // initialization flags, a config for either encoder or the decoder, and a |
| // pointer to internal data. |
| // |
| // The codec is configured / queried through calls to aom_codec_control, |
| // which takes a control ID (listed in aomcx.h and aomdx.h) and a parameter. |
| // In the case of "getter" control IDs, the parameter is modified to have |
| // the requested value; in the case of "setter" control IDs, the codec's |
| // configuration is changed based on the parameter. Note that a aom_codec_err_t |
| // is returned, which indicates if the operation was successful or not. |
| // |
| // Note that for the encoder, the aom_codec_alg_priv_t points to the |
| // the aom_codec_alg_priv structure in av1/av1_cx_iface.c, and for the decoder, |
| // the struct in av1/av1_dx_iface.c. Variables such as AV1_COMP cpi are stored |
| // here and also used in the core algorithm. |
| // |
| // At the end, aom_codec_destroy should be called for each initialized |
| // aom_codec_ctx_t. |
| |
| /*!\defgroup codec Common Algorithm Interface |
| * This abstraction allows applications to easily support multiple video |
| * formats with minimal code duplication. This section describes the interface |
| * common to all codecs (both encoders and decoders). |
| * @{ |
| */ |
| |
| /*!\file |
| * \brief Describes the codec algorithm interface to applications. |
| * |
| * This file describes the interface between an application and a |
| * video codec algorithm. |
| * |
| * An application instantiates a specific codec instance by using |
| * aom_codec_dec_init() or aom_codec_enc_init() and a pointer to the |
| * algorithm's interface structure: |
| * <pre> |
| * my_app.c: |
| * extern aom_codec_iface_t my_codec; |
| * { |
| * aom_codec_ctx_t algo; |
| * int threads = 4; |
| * aom_codec_dec_cfg_t cfg = { threads, 0, 0, 1 }; |
| * res = aom_codec_dec_init(&algo, &my_codec, &cfg, 0); |
| * } |
| * </pre> |
| * |
| * Once initialized, the instance is managed using other functions from |
| * the aom_codec_* family. |
| */ |
| #ifndef AOM_AOM_AOM_CODEC_H_ |
| #define AOM_AOM_AOM_CODEC_H_ |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #include "aom/aom_image.h" |
| #include "aom/aom_integer.h" |
| |
| /*!\brief Decorator indicating a function is deprecated */ |
| #ifndef AOM_DEPRECATED |
| #if defined(__GNUC__) && __GNUC__ |
| #define AOM_DEPRECATED __attribute__((deprecated)) |
| #elif defined(_MSC_VER) |
| #define AOM_DEPRECATED |
| #else |
| #define AOM_DEPRECATED |
| #endif |
| #endif /* AOM_DEPRECATED */ |
| |
| #ifndef AOM_DECLSPEC_DEPRECATED |
| #if defined(__GNUC__) && __GNUC__ |
| #define AOM_DECLSPEC_DEPRECATED /**< \copydoc #AOM_DEPRECATED */ |
| #elif defined(_MSC_VER) |
| /*!\brief \copydoc #AOM_DEPRECATED */ |
| #define AOM_DECLSPEC_DEPRECATED __declspec(deprecated) |
| #else |
| #define AOM_DECLSPEC_DEPRECATED /**< \copydoc #AOM_DEPRECATED */ |
| #endif |
| #endif /* AOM_DECLSPEC_DEPRECATED */ |
| |
| /*!\brief Decorator indicating a function is potentially unused */ |
| #ifdef AOM_UNUSED |
| #elif defined(__GNUC__) || defined(__clang__) |
| #define AOM_UNUSED __attribute__((unused)) |
| #else |
| #define AOM_UNUSED |
| #endif |
| |
| /*!\brief Decorator indicating that given struct/union/enum is packed */ |
| #ifndef ATTRIBUTE_PACKED |
| #if defined(__GNUC__) && __GNUC__ |
| #define ATTRIBUTE_PACKED __attribute__((packed)) |
| #elif defined(_MSC_VER) |
| #define ATTRIBUTE_PACKED |
| #else |
| #define ATTRIBUTE_PACKED |
| #endif |
| #endif /* ATTRIBUTE_PACKED */ |
| |
| /*!\brief Current ABI version number |
| * |
| * \internal |
| * If this file is altered in any way that changes the ABI, this value |
| * must be bumped. Examples include, but are not limited to, changing |
| * types, removing or reassigning enums, adding/removing/rearranging |
| * fields to structures |
| */ |
| #define AOM_CODEC_ABI_VERSION (6 + AOM_IMAGE_ABI_VERSION) /**<\hideinitializer*/ |
| |
| /*!\brief Algorithm return codes */ |
| typedef enum { |
| /*!\brief Operation completed without error */ |
| AOM_CODEC_OK, |
| |
| /*!\brief Unspecified error */ |
| AOM_CODEC_ERROR, |
| |
| /*!\brief Memory operation failed */ |
| AOM_CODEC_MEM_ERROR, |
| |
| /*!\brief ABI version mismatch */ |
| AOM_CODEC_ABI_MISMATCH, |
| |
| /*!\brief Algorithm does not have required capability */ |
| AOM_CODEC_INCAPABLE, |
| |
| /*!\brief The given bitstream is not supported. |
| * |
| * The bitstream was unable to be parsed at the highest level. The decoder |
| * is unable to proceed. This error \ref SHOULD be treated as fatal to the |
| * stream. */ |
| AOM_CODEC_UNSUP_BITSTREAM, |
| |
| /*!\brief Encoded bitstream uses an unsupported feature |
| * |
| * The decoder does not implement a feature required by the encoder. This |
| * return code should only be used for features that prevent future |
| * pictures from being properly decoded. This error \ref MAY be treated as |
| * fatal to the stream or \ref MAY be treated as fatal to the current GOP. |
| */ |
| AOM_CODEC_UNSUP_FEATURE, |
| |
| /*!\brief The coded data for this stream is corrupt or incomplete |
| * |
| * There was a problem decoding the current frame. This return code |
| * should only be used for failures that prevent future pictures from |
| * being properly decoded. This error \ref MAY be treated as fatal to the |
| * stream or \ref MAY be treated as fatal to the current GOP. If decoding |
| * is continued for the current GOP, artifacts may be present. |
| */ |
| AOM_CODEC_CORRUPT_FRAME, |
| |
| /*!\brief An application-supplied parameter is not valid. |
| * |
| */ |
| AOM_CODEC_INVALID_PARAM, |
| |
| /*!\brief An iterator reached the end of list. |
| * |
| */ |
| AOM_CODEC_LIST_END |
| |
| } aom_codec_err_t; |
| |
| /*! \brief Codec capabilities bitfield |
| * |
| * Each codec advertises the capabilities it supports as part of its |
| * ::aom_codec_iface_t interface structure. Capabilities are extra interfaces |
| * or functionality, and are not required to be supported. |
| * |
| * The available flags are specified by AOM_CODEC_CAP_* defines. |
| */ |
| typedef long aom_codec_caps_t; |
| #define AOM_CODEC_CAP_DECODER 0x1 /**< Is a decoder */ |
| #define AOM_CODEC_CAP_ENCODER 0x2 /**< Is an encoder */ |
| |
| /*! \brief Initialization-time Feature Enabling |
| * |
| * Certain codec features must be known at initialization time, to allow for |
| * proper memory allocation. |
| * |
| * The available flags are specified by AOM_CODEC_USE_* defines. |
| */ |
| typedef long aom_codec_flags_t; |
| |
| /*!\brief Time Stamp Type |
| * |
| * An integer, which when multiplied by the stream's time base, provides |
| * the absolute time of a sample. |
| */ |
| typedef int64_t aom_codec_pts_t; |
| |
| /*!\brief Codec interface structure. |
| * |
| * Contains function pointers and other data private to the codec |
| * implementation. This structure is opaque to the application. Common |
| * functions used with this structure: |
| * - aom_codec_iface_name(aom_codec_iface_t *iface): get the |
| * name of the codec |
| * - aom_codec_get_caps(aom_codec_iface_t *iface): returns |
| * the capabilities of the codec |
| * - aom_codec_enc_config_default: generate the default config for |
| * initializing the encoder (see documention in aom_encoder.h) |
| * - aom_codec_dec_init, aom_codec_enc_init: initialize the codec context |
| * structure (see documentation on aom_codec_ctx). |
| * |
| * To get access to the AV1 encoder and decoder, use aom_codec_av1_cx() and |
| * aom_codec_av1_dx(). |
| */ |
| typedef const struct aom_codec_iface aom_codec_iface_t; |
| |
| /*!\brief Codec private data structure. |
| * |
| * Contains data private to the codec implementation. This structure is opaque |
| * to the application. |
| */ |
| typedef struct aom_codec_priv aom_codec_priv_t; |
| |
| /*!\brief Compressed Frame Flags |
| * |
| * This type represents a bitfield containing information about a compressed |
| * frame that may be useful to an application. The most significant 16 bits |
| * can be used by an algorithm to provide additional detail, for example to |
| * support frame types that are codec specific (MPEG-1 D-frames for example) |
| */ |
| typedef uint32_t aom_codec_frame_flags_t; |
| #define AOM_FRAME_IS_KEY 0x1 /**< frame is the start of a GOP */ |
| /*!\brief frame can be dropped without affecting the stream (no future frame |
| * depends on this one) */ |
| #define AOM_FRAME_IS_DROPPABLE 0x2 |
| /*!\brief this is an INTRA_ONLY frame */ |
| #define AOM_FRAME_IS_INTRAONLY 0x10 |
| /*!\brief this is an S-frame */ |
| #define AOM_FRAME_IS_SWITCH 0x20 |
| /*!\brief this is an error-resilient frame */ |
| #define AOM_FRAME_IS_ERROR_RESILIENT 0x40 |
| /*!\brief this is a key-frame dependent recovery-point frame */ |
| #define AOM_FRAME_IS_DELAYED_RANDOM_ACCESS_POINT 0x80 |
| |
| /*!\brief Iterator |
| * |
| * Opaque storage used for iterating over lists. |
| */ |
| typedef const void *aom_codec_iter_t; |
| |
| /*!\brief Codec context structure |
| * |
| * All codecs \ref MUST support this context structure fully. In general, |
| * this data should be considered private to the codec algorithm, and |
| * not be manipulated or examined by the calling application. Applications |
| * may reference the 'name' member to get a printable description of the |
| * algorithm. |
| */ |
| typedef struct aom_codec_ctx { |
| const char *name; /**< Printable interface name */ |
| aom_codec_iface_t *iface; /**< Interface pointers */ |
| aom_codec_err_t err; /**< Last returned error */ |
| const char *err_detail; /**< Detailed info, if available */ |
| aom_codec_flags_t init_flags; /**< Flags passed at init time */ |
| union { |
| /**< Decoder Configuration Pointer */ |
| const struct aom_codec_dec_cfg *dec; |
| /**< Encoder Configuration Pointer */ |
| const struct aom_codec_enc_cfg *enc; |
| const void *raw; |
| } config; /**< Configuration pointer aliasing union */ |
| aom_codec_priv_t *priv; /**< Algorithm private storage */ |
| } aom_codec_ctx_t; |
| |
| /*!\brief Bit depth for codec |
| * * |
| * This enumeration determines the bit depth of the codec. |
| */ |
| typedef enum aom_bit_depth { |
| AOM_BITS_8 = 8, /**< 8 bits */ |
| AOM_BITS_10 = 10, /**< 10 bits */ |
| AOM_BITS_12 = 12, /**< 12 bits */ |
| } aom_bit_depth_t; |
| |
| /*!\brief Superblock size selection. |
| * |
| * Defines the superblock size used for encoding. The superblock size can |
| * either be fixed at 64x64 or 128x128 pixels, or it can be dynamically |
| * selected by the encoder for each frame. |
| */ |
| typedef enum aom_superblock_size { |
| AOM_SUPERBLOCK_SIZE_64X64, /**< Always use 64x64 superblocks. */ |
| AOM_SUPERBLOCK_SIZE_128X128, /**< Always use 128x128 superblocks. */ |
| AOM_SUPERBLOCK_SIZE_DYNAMIC /**< Select superblock size dynamically. */ |
| } aom_superblock_size_t; |
| |
| /* |
| * Library Version Number Interface |
| * |
| * For example, see the following sample return values: |
| * aom_codec_version() (1<<16 | 2<<8 | 3) |
| * aom_codec_version_str() "v1.2.3-rc1-16-gec6a1ba" |
| * aom_codec_version_extra_str() "rc1-16-gec6a1ba" |
| */ |
| |
| /*!\brief Return the version information (as an integer) |
| * |
| * Returns a packed encoding of the library version number. This will only |
| * include the major.minor.patch component of the version number. Note that this |
| * encoded value should be accessed through the macros provided, as the encoding |
| * may change in the future. |
| * |
| */ |
| int aom_codec_version(void); |
| |
| /*!\brief Return the major version number */ |
| #define aom_codec_version_major() ((aom_codec_version() >> 16) & 0xff) |
| |
| /*!\brief Return the minor version number */ |
| #define aom_codec_version_minor() ((aom_codec_version() >> 8) & 0xff) |
| |
| /*!\brief Return the patch version number */ |
| #define aom_codec_version_patch() ((aom_codec_version() >> 0) & 0xff) |
| |
| /*!\brief Return the version information (as a string) |
| * |
| * Returns a printable string containing the full library version number. This |
| * may contain additional text following the three digit version number, as to |
| * indicate release candidates, prerelease versions, etc. |
| * |
| */ |
| const char *aom_codec_version_str(void); |
| |
| /*!\brief Return the version information (as a string) |
| * |
| * Returns a printable "extra string". This is the component of the string |
| * returned by aom_codec_version_str() following the three digit version number. |
| * |
| */ |
| const char *aom_codec_version_extra_str(void); |
| |
| /*!\brief Return the build configuration |
| * |
| * Returns a printable string containing an encoded version of the build |
| * configuration. This may be useful to aom support. |
| * |
| */ |
| const char *aom_codec_build_config(void); |
| |
| /*!\brief Return the name for a given interface |
| * |
| * Returns a human readable string for name of the given codec interface. |
| * |
| * \param[in] iface Interface pointer |
| * |
| */ |
| const char *aom_codec_iface_name(aom_codec_iface_t *iface); |
| |
| /*!\brief Convert error number to printable string |
| * |
| * Returns a human readable string for the last error returned by the |
| * algorithm. The returned error will be one line and will not contain |
| * any newline characters. |
| * |
| * |
| * \param[in] err Error number. |
| * |
| */ |
| const char *aom_codec_err_to_string(aom_codec_err_t err); |
| |
| /*!\brief Retrieve error synopsis for codec context |
| * |
| * Returns a human readable string for the last error returned by the |
| * algorithm. The returned error will be one line and will not contain |
| * any newline characters. |
| * |
| * |
| * \param[in] ctx Pointer to this instance's context. |
| * |
| */ |
| const char *aom_codec_error(aom_codec_ctx_t *ctx); |
| |
| /*!\brief Retrieve detailed error information for codec context |
| * |
| * Returns a human readable string providing detailed information about |
| * the last error. |
| * |
| * \param[in] ctx Pointer to this instance's context. |
| * |
| * \retval NULL |
| * No detailed information is available. |
| */ |
| const char *aom_codec_error_detail(aom_codec_ctx_t *ctx); |
| |
| /* REQUIRED FUNCTIONS |
| * |
| * The following functions are required to be implemented for all codecs. |
| * They represent the base case functionality expected of all codecs. |
| */ |
| |
| /*!\brief Destroy a codec instance |
| * |
| * Destroys a codec context, freeing any associated memory buffers. |
| * |
| * \param[in] ctx Pointer to this instance's context |
| * |
| * \retval #AOM_CODEC_OK |
| * The codec algorithm initialized. |
| * \retval #AOM_CODEC_MEM_ERROR |
| * Memory allocation failed. |
| */ |
| aom_codec_err_t aom_codec_destroy(aom_codec_ctx_t *ctx); |
| |
| /*!\brief Get the capabilities of an algorithm. |
| * |
| * Retrieves the capabilities bitfield from the algorithm's interface. |
| * |
| * \param[in] iface Pointer to the algorithm interface |
| * |
| */ |
| aom_codec_caps_t aom_codec_get_caps(aom_codec_iface_t *iface); |
| |
| /*!\name Codec Control |
| * |
| * The aom_codec_control function exchanges algorithm specific data with the |
| * codec instance. Additionally, the macro AOM_CODEC_CONTROL_TYPECHECKED is |
| * provided, which will type-check the parameter against the control ID before |
| * calling aom_codec_control - note that this macro requires the control ID |
| * to be directly encoded in it, e.g., |
| * AOM_CODEC_CONTROL_TYPECHECKED(&ctx, AOME_SET_CPUUSED, 8). |
| * |
| * The codec control IDs can be found in aom.h, aomcx.h, and aomdx.h |
| * (defined as aom_com_control_id, aome_enc_control_id, and aom_dec_control_id). |
| * @{ |
| */ |
| /*!\brief Algorithm Control |
| * |
| * aom_codec_control takes a context, a control ID, and a third parameter |
| * (with varying type). If the context is non-null and an error occurs, |
| * ctx->err will be set to the same value as the return value. |
| * |
| * \param[in] ctx Pointer to this instance's context |
| * \param[in] ctrl_id Algorithm specific control identifier |
| * |
| * \retval #AOM_CODEC_OK |
| * The control request was processed. |
| * \retval #AOM_CODEC_ERROR |
| * The control request was not processed. |
| * \retval #AOM_CODEC_INVALID_PARAM |
| * The data was not valid. |
| */ |
| aom_codec_err_t aom_codec_control(aom_codec_ctx_t *ctx, int ctrl_id, ...); |
| |
| /*!\brief Key & Value API |
| * |
| * aom_codec_set_option() takes a context, a key (option name) and a value. If |
| * the context is non-null and an error occurs, ctx->err will be set to the same |
| * value as the return value. |
| * |
| * \param[in] ctx Pointer to this instance's context |
| * \param[in] name The name of the option (key) |
| * \param[in] value The value of the option |
| * |
| * \retval #AOM_CODEC_OK |
| * The value of the option was set. |
| * \retval #AOM_CODEC_INVALID_PARAM |
| * The data was not valid. |
| * \retval #AOM_CODEC_ERROR |
| * The option was not successfully set. |
| */ |
| aom_codec_err_t aom_codec_set_option(aom_codec_ctx_t *ctx, const char *name, |
| const char *value); |
| |
| /*!\brief aom_codec_control wrapper macro (adds type-checking, less flexible) |
| * |
| * This macro allows for type safe conversions across the variadic parameter |
| * to aom_codec_control(). However, it requires the explicit control ID |
| * be passed in (it cannot be passed in via a variable) -- otherwise a compiler |
| * error will occur. After the type checking, it calls aom_codec_control. |
| */ |
| #define AOM_CODEC_CONTROL_TYPECHECKED(ctx, id, data) \ |
| aom_codec_control_typechecked_##id(ctx, id, data) /**<\hideinitializer*/ |
| |
| /*!\brief Creates typechecking mechanisms for aom_codec_control |
| * |
| * It defines a static function with the correctly typed arguments as a wrapper |
| * to the type-unsafe aom_codec_control function. It also creates a typedef |
| * for each type. |
| */ |
| #define AOM_CTRL_USE_TYPE(id, typ) \ |
| static aom_codec_err_t aom_codec_control_typechecked_##id( \ |
| aom_codec_ctx_t *, int, typ) AOM_UNUSED; \ |
| static aom_codec_err_t aom_codec_control_typechecked_##id( \ |
| aom_codec_ctx_t *ctx, int ctrl, typ data) { \ |
| return aom_codec_control(ctx, ctrl, data); \ |
| } /**<\hideinitializer*/ \ |
| typedef typ aom_codec_control_type_##id; |
| /*!@} end Codec Control group */ |
| |
| /*!\brief OBU types. */ |
| typedef enum ATTRIBUTE_PACKED { |
| OBU_SEQUENCE_HEADER = 1, |
| OBU_TEMPORAL_DELIMITER = 2, |
| OBU_FRAME_HEADER = 3, |
| OBU_TILE_GROUP = 4, |
| OBU_METADATA = 5, |
| OBU_FRAME = 6, |
| OBU_REDUNDANT_FRAME_HEADER = 7, |
| OBU_TILE_LIST = 8, |
| OBU_PADDING = 15, |
| } OBU_TYPE; |
| |
| /*!\brief OBU metadata types. */ |
| typedef enum { |
| OBU_METADATA_TYPE_AOM_RESERVED_0 = 0, |
| OBU_METADATA_TYPE_HDR_CLL = 1, |
| OBU_METADATA_TYPE_HDR_MDCV = 2, |
| OBU_METADATA_TYPE_SCALABILITY = 3, |
| OBU_METADATA_TYPE_ITUT_T35 = 4, |
| OBU_METADATA_TYPE_TIMECODE = 5, |
| } OBU_METADATA_TYPE; |
| |
| /*!\brief Returns string representation of OBU_TYPE. |
| * |
| * \param[in] type The OBU_TYPE to convert to string. |
| */ |
| const char *aom_obu_type_to_string(OBU_TYPE type); |
| |
| /*!@} - end defgroup codec*/ |
| #ifdef __cplusplus |
| } |
| #endif |
| #endif // AOM_AOM_AOM_CODEC_H_ |