xref: /aosp_15_r20/external/libvpx/vpx/vpx_decoder.h (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
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