media/libvpx/vpx/vpx_decoder.h

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     1 /*
     2  *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
     3  *
     4  *  Use of this source code is governed by a BSD-style license
     5  *  that can be found in the LICENSE file in the root of the source
     6  *  tree. An additional intellectual property rights grant can be found
     7  *  in the file PATENTS.  All contributing project authors may
     8  *  be found in the AUTHORS file in the root of the source tree.
     9  */
    10 #ifndef VPX_DECODER_H
    11 #define VPX_DECODER_H
    13 /*!\defgroup decoder Decoder Algorithm Interface
    14  * \ingroup codec
    15  * This abstraction allows applications using this decoder to easily support
    16  * multiple video formats with minimal code duplication. This section describes
    17  * the interface common to all decoders.
    18  * @{
    19  */
    21 /*!\file
    22  * \brief Describes the decoder algorithm interface to applications.
    23  *
    24  * This file describes the interface between an application and a
    25  * video decoder algorithm.
    26  *
    27  */
    28 #ifdef __cplusplus
    29 extern "C" {
    30 #endif
    32 #include "vpx_codec.h"
    34   /*!\brief Current ABI version number
    35    *
    36    * \internal
    37    * If this file is altered in any way that changes the ABI, this value
    38    * must be bumped.  Examples include, but are not limited to, changing
    39    * types, removing or reassigning enums, adding/removing/rearranging
    40    * fields to structures
    41    */
    42 #define VPX_DECODER_ABI_VERSION (2 + VPX_CODEC_ABI_VERSION) /**<\hideinitializer*/
    44   /*! \brief Decoder capabilities bitfield
    45    *
    46    *  Each decoder advertises the capabilities it supports as part of its
    47    *  ::vpx_codec_iface_t interface structure. Capabilities are extra interfaces
    48    *  or functionality, and are not required to be supported by a decoder.
    49    *
    50    *  The available flags are specified by VPX_CODEC_CAP_* defines.
    51    */
    52 #define VPX_CODEC_CAP_PUT_SLICE  0x10000 /**< Will issue put_slice callbacks */
    53 #define VPX_CODEC_CAP_PUT_FRAME  0x20000 /**< Will issue put_frame callbacks */
    54 #define VPX_CODEC_CAP_POSTPROC   0x40000 /**< Can postprocess decoded frame */
    55 #define VPX_CODEC_CAP_ERROR_CONCEALMENT   0x80000 /**< Can conceal errors due to
    56   packet loss */
    57 #define VPX_CODEC_CAP_INPUT_FRAGMENTS   0x100000 /**< Can receive encoded frames
    58   one fragment at a time */
    60   /*! \brief Initialization-time Feature Enabling
    61    *
    62    *  Certain codec features must be known at initialization time, to allow for
    63    *  proper memory allocation.
    64    *
    65    *  The available flags are specified by VPX_CODEC_USE_* defines.
    66    */
    67 #define VPX_CODEC_CAP_FRAME_THREADING   0x200000 /**< Can support frame-based
    68                                                       multi-threading */
    70 #define VPX_CODEC_USE_POSTPROC   0x10000 /**< Postprocess decoded frame */
    71 #define VPX_CODEC_USE_ERROR_CONCEALMENT 0x20000 /**< Conceal errors in decoded
    72   frames */
    73 #define VPX_CODEC_USE_INPUT_FRAGMENTS   0x40000 /**< The input frame should be
    74   passed to the decoder one
    75   fragment at a time */
    76 #define VPX_CODEC_USE_FRAME_THREADING   0x80000 /**< Enable frame-based
    77                                                      multi-threading */
    79   /*!\brief Stream properties
    80    *
    81    * This structure is used to query or set properties of the decoded
    82    * stream. Algorithms may extend this structure with data specific
    83    * to their bitstream by setting the sz member appropriately.
    84    */
    85   typedef struct vpx_codec_stream_info {
    86     unsigned int sz;     /**< Size of this structure */
    87     unsigned int w;      /**< Width (or 0 for unknown/default) */
    88     unsigned int h;      /**< Height (or 0 for unknown/default) */
    89     unsigned int is_kf;  /**< Current frame is a keyframe */
    90   } vpx_codec_stream_info_t;
    92   /* REQUIRED FUNCTIONS
    93    *
    94    * The following functions are required to be implemented for all decoders.
    95    * They represent the base case functionality expected of all decoders.
    96    */
    99   /*!\brief Initialization Configurations
   100    *
   101    * This structure is used to pass init time configuration options to the
   102    * decoder.
   103    */
   104   typedef struct vpx_codec_dec_cfg {
   105     unsigned int threads; /**< Maximum number of threads to use, default 1 */
   106     unsigned int w;      /**< Width */
   107     unsigned int h;      /**< Height */
   108   } vpx_codec_dec_cfg_t; /**< alias for struct vpx_codec_dec_cfg */
   111   /*!\brief Initialize a decoder instance
   112    *
   113    * Initializes a decoder context using the given interface. Applications
   114    * should call the vpx_codec_dec_init convenience macro instead of this
   115    * function directly, to ensure that the ABI version number parameter
   116    * is properly initialized.
   117    *
   118    * If the library was configured with --disable-multithread, this call
   119    * is not thread safe and should be guarded with a lock if being used
   120    * in a multithreaded context.
   121    *
   122    * In XMA mode (activated by setting VPX_CODEC_USE_XMA in the flags
   123    * parameter), the storage pointed to by the cfg parameter must be
   124    * kept readable and stable until all memory maps have been set.
   125    *
   126    * \param[in]    ctx     Pointer to this instance's context.
   127    * \param[in]    iface   Pointer to the algorithm interface to use.
   128    * \param[in]    cfg     Configuration to use, if known. May be NULL.
   129    * \param[in]    flags   Bitfield of VPX_CODEC_USE_* flags
   130    * \param[in]    ver     ABI version number. Must be set to
   131    *                       VPX_DECODER_ABI_VERSION
   132    * \retval #VPX_CODEC_OK
   133    *     The decoder algorithm initialized.
   134    * \retval #VPX_CODEC_MEM_ERROR
   135    *     Memory allocation failed.
   136    */
   137   vpx_codec_err_t vpx_codec_dec_init_ver(vpx_codec_ctx_t      *ctx,
   138                                          vpx_codec_iface_t    *iface,
   139                                          vpx_codec_dec_cfg_t  *cfg,
   140                                          vpx_codec_flags_t     flags,
   141                                          int                   ver);
   143   /*!\brief Convenience macro for vpx_codec_dec_init_ver()
   144    *
   145    * Ensures the ABI version parameter is properly set.
   146    */
   147 #define vpx_codec_dec_init(ctx, iface, cfg, flags) \
   148   vpx_codec_dec_init_ver(ctx, iface, cfg, flags, VPX_DECODER_ABI_VERSION)
   151   /*!\brief Parse stream info from a buffer
   152    *
   153    * Performs high level parsing of the bitstream. Construction of a decoder
   154    * context is not necessary. Can be used to determine if the bitstream is
   155    * of the proper format, and to extract information from the stream.
   156    *
   157    * \param[in]      iface   Pointer to the algorithm interface
   158    * \param[in]      data    Pointer to a block of data to parse
   159    * \param[in]      data_sz Size of the data buffer
   160    * \param[in,out]  si      Pointer to stream info to update. The size member
   161    *                         \ref MUST be properly initialized, but \ref MAY be
   162    *                         clobbered by the algorithm. This parameter \ref MAY
   163    *                         be NULL.
   164    *
   165    * \retval #VPX_CODEC_OK
   166    *     Bitstream is parsable and stream information updated
   167    */
   168   vpx_codec_err_t vpx_codec_peek_stream_info(vpx_codec_iface_t       *iface,
   169                                              const uint8_t           *data,
   170                                              unsigned int             data_sz,
   171                                              vpx_codec_stream_info_t *si);
   174   /*!\brief Return information about the current stream.
   175    *
   176    * Returns information about the stream that has been parsed during decoding.
   177    *
   178    * \param[in]      ctx     Pointer to this instance's context
   179    * \param[in,out]  si      Pointer to stream info to update. The size member
   180    *                         \ref MUST be properly initialized, but \ref MAY be
   181    *                         clobbered by the algorithm. This parameter \ref MAY
   182    *                         be NULL.
   183    *
   184    * \retval #VPX_CODEC_OK
   185    *     Bitstream is parsable and stream information updated
   186    */
   187   vpx_codec_err_t vpx_codec_get_stream_info(vpx_codec_ctx_t         *ctx,
   188                                             vpx_codec_stream_info_t *si);
   191   /*!\brief Decode data
   192    *
   193    * Processes a buffer of coded data. If the processing results in a new
   194    * decoded frame becoming available, PUT_SLICE and PUT_FRAME events may be
   195    * generated, as appropriate. Encoded data \ref MUST be passed in DTS (decode
   196    * time stamp) order. Frames produced will always be in PTS (presentation
   197    * time stamp) order.
   198    * If the decoder is configured with VPX_CODEC_USE_INPUT_FRAGMENTS enabled,
   199    * data and data_sz can contain a fragment of the encoded frame. Fragment
   200    * \#n must contain at least partition \#n, but can also contain subsequent
   201    * partitions (\#n+1 - \#n+i), and if so, fragments \#n+1, .., \#n+i must
   202    * be empty. When no more data is available, this function should be called
   203    * with NULL as data and 0 as data_sz. The memory passed to this function
   204    * must be available until the frame has been decoded.
   205    *
   206    * \param[in] ctx          Pointer to this instance's context
   207    * \param[in] data         Pointer to this block of new coded data. If
   208    *                         NULL, a VPX_CODEC_CB_PUT_FRAME event is posted
   209    *                         for the previously decoded frame.
   210    * \param[in] data_sz      Size of the coded data, in bytes.
   211    * \param[in] user_priv    Application specific data to associate with
   212    *                         this frame.
   213    * \param[in] deadline     Soft deadline the decoder should attempt to meet,
   214    *                         in us. Set to zero for unlimited.
   215    *
   216    * \return Returns #VPX_CODEC_OK if the coded data was processed completely
   217    *         and future pictures can be decoded without error. Otherwise,
   218    *         see the descriptions of the other error codes in ::vpx_codec_err_t
   219    *         for recoverability capabilities.
   220    */
   221   vpx_codec_err_t vpx_codec_decode(vpx_codec_ctx_t    *ctx,
   222                                    const uint8_t        *data,
   223                                    unsigned int            data_sz,
   224                                    void               *user_priv,
   225                                    long                deadline);
   228   /*!\brief Decoded frames iterator
   229    *
   230    * Iterates over a list of the frames available for display. The iterator
   231    * storage should be initialized to NULL to start the iteration. Iteration is
   232    * complete when this function returns NULL.
   233    *
   234    * The list of available frames becomes valid upon completion of the
   235    * vpx_codec_decode call, and remains valid until the next call to vpx_codec_decode.
   236    *
   237    * \param[in]     ctx      Pointer to this instance's context
   238    * \param[in,out] iter     Iterator storage, initialized to NULL
   239    *
   240    * \return Returns a pointer to an image, if one is ready for display. Frames
   241    *         produced will always be in PTS (presentation time stamp) order.
   242    */
   243   vpx_image_t *vpx_codec_get_frame(vpx_codec_ctx_t  *ctx,
   244                                    vpx_codec_iter_t *iter);
   247   /*!\defgroup cap_put_frame Frame-Based Decoding Functions
   248    *
   249    * The following functions are required to be implemented for all decoders
   250    * that advertise the VPX_CODEC_CAP_PUT_FRAME capability. Calling these functions
   251    * for codecs that don't advertise this capability will result in an error
   252    * code being returned, usually VPX_CODEC_ERROR
   253    * @{
   254    */
   256   /*!\brief put frame callback prototype
   257    *
   258    * This callback is invoked by the decoder to notify the application of
   259    * the availability of decoded image data.
   260    */
   261   typedef void (*vpx_codec_put_frame_cb_fn_t)(void        *user_priv,
   262                                               const vpx_image_t *img);
   265   /*!\brief Register for notification of frame completion.
   266    *
   267    * Registers a given function to be called when a decoded frame is
   268    * available.
   269    *
   270    * \param[in] ctx          Pointer to this instance's context
   271    * \param[in] cb           Pointer to the callback function
   272    * \param[in] user_priv    User's private data
   273    *
   274    * \retval #VPX_CODEC_OK
   275    *     Callback successfully registered.
   276    * \retval #VPX_CODEC_ERROR
   277    *     Decoder context not initialized, or algorithm not capable of
   278    *     posting slice completion.
   279    */
   280   vpx_codec_err_t vpx_codec_register_put_frame_cb(vpx_codec_ctx_t             *ctx,
   281                                                   vpx_codec_put_frame_cb_fn_t  cb,
   282                                                   void                        *user_priv);
   285   /*!@} - end defgroup cap_put_frame */
   287   /*!\defgroup cap_put_slice Slice-Based Decoding Functions
   288    *
   289    * The following functions are required to be implemented for all decoders
   290    * that advertise the VPX_CODEC_CAP_PUT_SLICE capability. Calling these functions
   291    * for codecs that don't advertise this capability will result in an error
   292    * code being returned, usually VPX_CODEC_ERROR
   293    * @{
   294    */
   296   /*!\brief put slice callback prototype
   297    *
   298    * This callback is invoked by the decoder to notify the application of
   299    * the availability of partially decoded image data. The
   300    */
   301   typedef void (*vpx_codec_put_slice_cb_fn_t)(void         *user_priv,
   302                                               const vpx_image_t      *img,
   303                                               const vpx_image_rect_t *valid,
   304                                               const vpx_image_rect_t *update);
   307   /*!\brief Register for notification of slice completion.
   308    *
   309    * Registers a given function to be called when a decoded slice is
   310    * available.
   311    *
   312    * \param[in] ctx          Pointer to this instance's context
   313    * \param[in] cb           Pointer to the callback function
   314    * \param[in] user_priv    User's private data
   315    *
   316    * \retval #VPX_CODEC_OK
   317    *     Callback successfully registered.
   318    * \retval #VPX_CODEC_ERROR
   319    *     Decoder context not initialized, or algorithm not capable of
   320    *     posting slice completion.
   321    */
   322   vpx_codec_err_t vpx_codec_register_put_slice_cb(vpx_codec_ctx_t             *ctx,
   323                                                   vpx_codec_put_slice_cb_fn_t  cb,
   324                                                   void                        *user_priv);
   327   /*!@} - end defgroup cap_put_slice*/
   329   /*!@} - end defgroup decoder*/
   330 #ifdef __cplusplus
   331 }
   332 #endif
   333 #endif

mercurial