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