Index: source/libvpx/vpx/vpx_decoder.h |
=================================================================== |
--- source/libvpx/vpx/vpx_decoder.h (revision 172621) |
+++ source/libvpx/vpx/vpx_decoder.h (working copy) |
@@ -32,299 +32,297 @@ |
#define VPX_DECODER_H |
#include "vpx_codec.h" |
- /*!\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 |
- */ |
+ /*!\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 VPX_DECODER_ABI_VERSION (2 + VPX_CODEC_ABI_VERSION) /**<\hideinitializer*/ |
- /*! \brief Decoder capabilities bitfield |
- * |
- * Each decoder advertises the capabilities it supports as part of its |
- * ::vpx_codec_iface_t interface structure. Capabilities are extra interfaces |
- * or functionality, and are not required to be supported by a decoder. |
- * |
- * The available flags are specified by VPX_CODEC_CAP_* defines. |
- */ |
+ /*! \brief Decoder capabilities bitfield |
+ * |
+ * Each decoder advertises the capabilities it supports as part of its |
+ * ::vpx_codec_iface_t interface structure. Capabilities are extra interfaces |
+ * or functionality, and are not required to be supported by a decoder. |
+ * |
+ * The available flags are specified by VPX_CODEC_CAP_* defines. |
+ */ |
#define VPX_CODEC_CAP_PUT_SLICE 0x10000 /**< Will issue put_slice callbacks */ |
#define VPX_CODEC_CAP_PUT_FRAME 0x20000 /**< Will issue put_frame callbacks */ |
#define VPX_CODEC_CAP_POSTPROC 0x40000 /**< Can postprocess decoded frame */ |
#define VPX_CODEC_CAP_ERROR_CONCEALMENT 0x80000 /**< Can conceal errors due to |
- packet loss */ |
+ packet loss */ |
#define VPX_CODEC_CAP_INPUT_FRAGMENTS 0x100000 /**< Can receive encoded frames |
- one fragment at a time */ |
+ one fragment at a time */ |
- /*! \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 VPX_CODEC_USE_* defines. |
- */ |
+ /*! \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 VPX_CODEC_USE_* defines. |
+ */ |
#define VPX_CODEC_USE_POSTPROC 0x10000 /**< Postprocess decoded frame */ |
#define VPX_CODEC_USE_ERROR_CONCEALMENT 0x20000 /**< Conceal errors in decoded |
- frames */ |
+ frames */ |
#define VPX_CODEC_USE_INPUT_FRAGMENTS 0x40000 /**< The input frame should be |
- passed to the decoder one |
- fragment at a time */ |
+ passed to the decoder one |
+ fragment at a time */ |
- /*!\brief Stream properties |
- * |
- * This structure is used to query or set properties of the decoded |
- * stream. Algorithms may extend this structure with data specific |
- * to their bitstream by setting the sz member appropriately. |
- */ |
- typedef struct vpx_codec_stream_info |
- { |
- unsigned int sz; /**< Size of this structure */ |
- unsigned int w; /**< Width (or 0 for unknown/default) */ |
- unsigned int h; /**< Height (or 0 for unknown/default) */ |
- unsigned int is_kf; /**< Current frame is a keyframe */ |
- } vpx_codec_stream_info_t; |
+ /*!\brief Stream properties |
+ * |
+ * This structure is used to query or set properties of the decoded |
+ * stream. Algorithms may extend this structure with data specific |
+ * to their bitstream by setting the sz member appropriately. |
+ */ |
+ typedef struct vpx_codec_stream_info { |
+ unsigned int sz; /**< Size of this structure */ |
+ unsigned int w; /**< Width (or 0 for unknown/default) */ |
+ unsigned int h; /**< Height (or 0 for unknown/default) */ |
+ unsigned int is_kf; /**< Current frame is a keyframe */ |
+ } vpx_codec_stream_info_t; |
- /* REQUIRED FUNCTIONS |
- * |
- * The following functions are required to be implemented for all decoders. |
- * They represent the base case functionality expected of all decoders. |
- */ |
+ /* REQUIRED FUNCTIONS |
+ * |
+ * The following functions are required to be implemented for all decoders. |
+ * They represent the base case functionality expected of all decoders. |
+ */ |
- /*!\brief Initialization Configurations |
- * |
- * This structure is used to pass init time configuration options to the |
- * decoder. |
- */ |
- typedef struct vpx_codec_dec_cfg |
- { |
- unsigned int threads; /**< Maximum number of threads to use, default 1 */ |
- unsigned int w; /**< Width */ |
- unsigned int h; /**< Height */ |
- } vpx_codec_dec_cfg_t; /**< alias for struct vpx_codec_dec_cfg */ |
+ /*!\brief Initialization Configurations |
+ * |
+ * This structure is used to pass init time configuration options to the |
+ * decoder. |
+ */ |
+ typedef struct vpx_codec_dec_cfg { |
+ unsigned int threads; /**< Maximum number of threads to use, default 1 */ |
+ unsigned int w; /**< Width */ |
+ unsigned int h; /**< Height */ |
+ } vpx_codec_dec_cfg_t; /**< alias for struct vpx_codec_dec_cfg */ |
- /*!\brief Initialize a decoder instance |
- * |
- * Initializes a decoder context using the given interface. Applications |
- * should call the vpx_codec_dec_init convenience macro instead of this |
- * function directly, to ensure that the ABI version number parameter |
- * is properly initialized. |
- * |
- * If the library was configured with --disable-multithread, this call |
- * is not thread safe and should be guarded with a lock if being used |
- * in a multithreaded context. |
- * |
- * In XMA mode (activated by setting VPX_CODEC_USE_XMA in the flags |
- * parameter), the storage pointed to by the cfg parameter must be |
- * kept readable and stable until all memory maps have been set. |
- * |
- * \param[in] ctx Pointer to this instance's context. |
- * \param[in] iface Pointer to the algorithm interface to use. |
- * \param[in] cfg Configuration to use, if known. May be NULL. |
- * \param[in] flags Bitfield of VPX_CODEC_USE_* flags |
- * \param[in] ver ABI version number. Must be set to |
- * VPX_DECODER_ABI_VERSION |
- * \retval #VPX_CODEC_OK |
- * The decoder algorithm initialized. |
- * \retval #VPX_CODEC_MEM_ERROR |
- * Memory allocation failed. |
- */ |
- vpx_codec_err_t vpx_codec_dec_init_ver(vpx_codec_ctx_t *ctx, |
- vpx_codec_iface_t *iface, |
- vpx_codec_dec_cfg_t *cfg, |
- vpx_codec_flags_t flags, |
- int ver); |
+ /*!\brief Initialize a decoder instance |
+ * |
+ * Initializes a decoder context using the given interface. Applications |
+ * should call the vpx_codec_dec_init convenience macro instead of this |
+ * function directly, to ensure that the ABI version number parameter |
+ * is properly initialized. |
+ * |
+ * If the library was configured with --disable-multithread, this call |
+ * is not thread safe and should be guarded with a lock if being used |
+ * in a multithreaded context. |
+ * |
+ * In XMA mode (activated by setting VPX_CODEC_USE_XMA in the flags |
+ * parameter), the storage pointed to by the cfg parameter must be |
+ * kept readable and stable until all memory maps have been set. |
+ * |
+ * \param[in] ctx Pointer to this instance's context. |
+ * \param[in] iface Pointer to the algorithm interface to use. |
+ * \param[in] cfg Configuration to use, if known. May be NULL. |
+ * \param[in] flags Bitfield of VPX_CODEC_USE_* flags |
+ * \param[in] ver ABI version number. Must be set to |
+ * VPX_DECODER_ABI_VERSION |
+ * \retval #VPX_CODEC_OK |
+ * The decoder algorithm initialized. |
+ * \retval #VPX_CODEC_MEM_ERROR |
+ * Memory allocation failed. |
+ */ |
+ vpx_codec_err_t vpx_codec_dec_init_ver(vpx_codec_ctx_t *ctx, |
+ vpx_codec_iface_t *iface, |
+ vpx_codec_dec_cfg_t *cfg, |
+ vpx_codec_flags_t flags, |
+ int ver); |
- /*!\brief Convenience macro for vpx_codec_dec_init_ver() |
- * |
- * Ensures the ABI version parameter is properly set. |
- */ |
+ /*!\brief Convenience macro for vpx_codec_dec_init_ver() |
+ * |
+ * Ensures the ABI version parameter is properly set. |
+ */ |
#define vpx_codec_dec_init(ctx, iface, cfg, flags) \ |
- vpx_codec_dec_init_ver(ctx, iface, cfg, flags, VPX_DECODER_ABI_VERSION) |
+ vpx_codec_dec_init_ver(ctx, iface, cfg, flags, VPX_DECODER_ABI_VERSION) |
- /*!\brief Parse stream info from a buffer |
- * |
- * Performs high level parsing of the bitstream. Construction of a decoder |
- * context is not necessary. Can be used to determine if the bitstream is |
- * of the proper format, and to extract information from the stream. |
- * |
- * \param[in] iface Pointer to the algorithm interface |
- * \param[in] data Pointer to a block of data to parse |
- * \param[in] data_sz Size of the data buffer |
- * \param[in,out] si Pointer to stream info to update. The size member |
- * \ref MUST be properly initialized, but \ref MAY be |
- * clobbered by the algorithm. This parameter \ref MAY |
- * be NULL. |
- * |
- * \retval #VPX_CODEC_OK |
- * Bitstream is parsable and stream information updated |
- */ |
- vpx_codec_err_t vpx_codec_peek_stream_info(vpx_codec_iface_t *iface, |
- const uint8_t *data, |
- unsigned int data_sz, |
- vpx_codec_stream_info_t *si); |
+ /*!\brief Parse stream info from a buffer |
+ * |
+ * Performs high level parsing of the bitstream. Construction of a decoder |
+ * context is not necessary. Can be used to determine if the bitstream is |
+ * of the proper format, and to extract information from the stream. |
+ * |
+ * \param[in] iface Pointer to the algorithm interface |
+ * \param[in] data Pointer to a block of data to parse |
+ * \param[in] data_sz Size of the data buffer |
+ * \param[in,out] si Pointer to stream info to update. The size member |
+ * \ref MUST be properly initialized, but \ref MAY be |
+ * clobbered by the algorithm. This parameter \ref MAY |
+ * be NULL. |
+ * |
+ * \retval #VPX_CODEC_OK |
+ * Bitstream is parsable and stream information updated |
+ */ |
+ vpx_codec_err_t vpx_codec_peek_stream_info(vpx_codec_iface_t *iface, |
+ const uint8_t *data, |
+ unsigned int data_sz, |
+ vpx_codec_stream_info_t *si); |
- /*!\brief Return information about the current stream. |
- * |
- * Returns information about the stream that has been parsed during decoding. |
- * |
- * \param[in] ctx Pointer to this instance's context |
- * \param[in,out] si Pointer to stream info to update. The size member |
- * \ref MUST be properly initialized, but \ref MAY be |
- * clobbered by the algorithm. This parameter \ref MAY |
- * be NULL. |
- * |
- * \retval #VPX_CODEC_OK |
- * Bitstream is parsable and stream information updated |
- */ |
- vpx_codec_err_t vpx_codec_get_stream_info(vpx_codec_ctx_t *ctx, |
- vpx_codec_stream_info_t *si); |
+ /*!\brief Return information about the current stream. |
+ * |
+ * Returns information about the stream that has been parsed during decoding. |
+ * |
+ * \param[in] ctx Pointer to this instance's context |
+ * \param[in,out] si Pointer to stream info to update. The size member |
+ * \ref MUST be properly initialized, but \ref MAY be |
+ * clobbered by the algorithm. This parameter \ref MAY |
+ * be NULL. |
+ * |
+ * \retval #VPX_CODEC_OK |
+ * Bitstream is parsable and stream information updated |
+ */ |
+ vpx_codec_err_t vpx_codec_get_stream_info(vpx_codec_ctx_t *ctx, |
+ vpx_codec_stream_info_t *si); |
- /*!\brief Decode data |
- * |
- * Processes a buffer of coded data. If the processing results in a new |
- * decoded frame becoming available, PUT_SLICE and PUT_FRAME events may be |
- * generated, as appropriate. Encoded data \ref MUST be passed in DTS (decode |
- * time stamp) order. Frames produced will always be in PTS (presentation |
- * time stamp) order. |
- * If the decoder is configured with VPX_CODEC_USE_INPUT_FRAGMENTS enabled, |
- * data and data_sz can contain a fragment of the encoded frame. Fragment |
- * \#n must contain at least partition \#n, but can also contain subsequent |
- * partitions (\#n+1 - \#n+i), and if so, fragments \#n+1, .., \#n+i must |
- * be empty. When no more data is available, this function should be called |
- * with NULL as data and 0 as data_sz. The memory passed to this function |
- * must be available until the frame has been decoded. |
- * |
- * \param[in] ctx Pointer to this instance's context |
- * \param[in] data Pointer to this block of new coded data. If |
- * NULL, a VPX_CODEC_CB_PUT_FRAME event is posted |
- * for the previously decoded frame. |
- * \param[in] data_sz Size of the coded data, in bytes. |
- * \param[in] user_priv Application specific data to associate with |
- * this frame. |
- * \param[in] deadline Soft deadline the decoder should attempt to meet, |
- * in us. Set to zero for unlimited. |
- * |
- * \return Returns #VPX_CODEC_OK if the coded data was processed completely |
- * and future pictures can be decoded without error. Otherwise, |
- * see the descriptions of the other error codes in ::vpx_codec_err_t |
- * for recoverability capabilities. |
- */ |
- vpx_codec_err_t vpx_codec_decode(vpx_codec_ctx_t *ctx, |
- const uint8_t *data, |
- unsigned int data_sz, |
- void *user_priv, |
- long deadline); |
+ /*!\brief Decode data |
+ * |
+ * Processes a buffer of coded data. If the processing results in a new |
+ * decoded frame becoming available, PUT_SLICE and PUT_FRAME events may be |
+ * generated, as appropriate. Encoded data \ref MUST be passed in DTS (decode |
+ * time stamp) order. Frames produced will always be in PTS (presentation |
+ * time stamp) order. |
+ * If the decoder is configured with VPX_CODEC_USE_INPUT_FRAGMENTS enabled, |
+ * data and data_sz can contain a fragment of the encoded frame. Fragment |
+ * \#n must contain at least partition \#n, but can also contain subsequent |
+ * partitions (\#n+1 - \#n+i), and if so, fragments \#n+1, .., \#n+i must |
+ * be empty. When no more data is available, this function should be called |
+ * with NULL as data and 0 as data_sz. The memory passed to this function |
+ * must be available until the frame has been decoded. |
+ * |
+ * \param[in] ctx Pointer to this instance's context |
+ * \param[in] data Pointer to this block of new coded data. If |
+ * NULL, a VPX_CODEC_CB_PUT_FRAME event is posted |
+ * for the previously decoded frame. |
+ * \param[in] data_sz Size of the coded data, in bytes. |
+ * \param[in] user_priv Application specific data to associate with |
+ * this frame. |
+ * \param[in] deadline Soft deadline the decoder should attempt to meet, |
+ * in us. Set to zero for unlimited. |
+ * |
+ * \return Returns #VPX_CODEC_OK if the coded data was processed completely |
+ * and future pictures can be decoded without error. Otherwise, |
+ * see the descriptions of the other error codes in ::vpx_codec_err_t |
+ * for recoverability capabilities. |
+ */ |
+ vpx_codec_err_t vpx_codec_decode(vpx_codec_ctx_t *ctx, |
+ const uint8_t *data, |
+ unsigned int data_sz, |
+ void *user_priv, |
+ long deadline); |
- /*!\brief Decoded frames iterator |
- * |
- * Iterates over a list of the frames available for display. The iterator |
- * storage should be initialized to NULL to start the iteration. Iteration is |
- * complete when this function returns NULL. |
- * |
- * The list of available frames becomes valid upon completion of the |
- * vpx_codec_decode call, and remains valid until the next call to vpx_codec_decode. |
- * |
- * \param[in] ctx Pointer to this instance's context |
- * \param[in,out] iter Iterator storage, initialized to NULL |
- * |
- * \return Returns a pointer to an image, if one is ready for display. Frames |
- * produced will always be in PTS (presentation time stamp) order. |
- */ |
- vpx_image_t *vpx_codec_get_frame(vpx_codec_ctx_t *ctx, |
- vpx_codec_iter_t *iter); |
+ /*!\brief Decoded frames iterator |
+ * |
+ * Iterates over a list of the frames available for display. The iterator |
+ * storage should be initialized to NULL to start the iteration. Iteration is |
+ * complete when this function returns NULL. |
+ * |
+ * The list of available frames becomes valid upon completion of the |
+ * vpx_codec_decode call, and remains valid until the next call to vpx_codec_decode. |
+ * |
+ * \param[in] ctx Pointer to this instance's context |
+ * \param[in,out] iter Iterator storage, initialized to NULL |
+ * |
+ * \return Returns a pointer to an image, if one is ready for display. Frames |
+ * produced will always be in PTS (presentation time stamp) order. |
+ */ |
+ vpx_image_t *vpx_codec_get_frame(vpx_codec_ctx_t *ctx, |
+ vpx_codec_iter_t *iter); |
- /*!\defgroup cap_put_frame Frame-Based Decoding Functions |
- * |
- * The following functions are required to be implemented for all decoders |
- * that advertise the VPX_CODEC_CAP_PUT_FRAME capability. Calling these functions |
- * for codecs that don't advertise this capability will result in an error |
- * code being returned, usually VPX_CODEC_ERROR |
- * @{ |
- */ |
+ /*!\defgroup cap_put_frame Frame-Based Decoding Functions |
+ * |
+ * The following functions are required to be implemented for all decoders |
+ * that advertise the VPX_CODEC_CAP_PUT_FRAME capability. Calling these functions |
+ * for codecs that don't advertise this capability will result in an error |
+ * code being returned, usually VPX_CODEC_ERROR |
+ * @{ |
+ */ |
- /*!\brief put frame callback prototype |
- * |
- * This callback is invoked by the decoder to notify the application of |
- * the availability of decoded image data. |
- */ |
- typedef void (*vpx_codec_put_frame_cb_fn_t)(void *user_priv, |
- const vpx_image_t *img); |
+ /*!\brief put frame callback prototype |
+ * |
+ * This callback is invoked by the decoder to notify the application of |
+ * the availability of decoded image data. |
+ */ |
+ typedef void (*vpx_codec_put_frame_cb_fn_t)(void *user_priv, |
+ const vpx_image_t *img); |
- /*!\brief Register for notification of frame completion. |
- * |
- * Registers a given function to be called when a decoded frame is |
- * available. |
- * |
- * \param[in] ctx Pointer to this instance's context |
- * \param[in] cb Pointer to the callback function |
- * \param[in] user_priv User's private data |
- * |
- * \retval #VPX_CODEC_OK |
- * Callback successfully registered. |
- * \retval #VPX_CODEC_ERROR |
- * Decoder context not initialized, or algorithm not capable of |
- * posting slice completion. |
- */ |
- vpx_codec_err_t vpx_codec_register_put_frame_cb(vpx_codec_ctx_t *ctx, |
- vpx_codec_put_frame_cb_fn_t cb, |
- void *user_priv); |
+ /*!\brief Register for notification of frame completion. |
+ * |
+ * Registers a given function to be called when a decoded frame is |
+ * available. |
+ * |
+ * \param[in] ctx Pointer to this instance's context |
+ * \param[in] cb Pointer to the callback function |
+ * \param[in] user_priv User's private data |
+ * |
+ * \retval #VPX_CODEC_OK |
+ * Callback successfully registered. |
+ * \retval #VPX_CODEC_ERROR |
+ * Decoder context not initialized, or algorithm not capable of |
+ * posting slice completion. |
+ */ |
+ vpx_codec_err_t vpx_codec_register_put_frame_cb(vpx_codec_ctx_t *ctx, |
+ vpx_codec_put_frame_cb_fn_t cb, |
+ void *user_priv); |
- /*!@} - end defgroup cap_put_frame */ |
+ /*!@} - end defgroup cap_put_frame */ |
- /*!\defgroup cap_put_slice Slice-Based Decoding Functions |
- * |
- * The following functions are required to be implemented for all decoders |
- * that advertise the VPX_CODEC_CAP_PUT_SLICE capability. Calling these functions |
- * for codecs that don't advertise this capability will result in an error |
- * code being returned, usually VPX_CODEC_ERROR |
- * @{ |
- */ |
+ /*!\defgroup cap_put_slice Slice-Based Decoding Functions |
+ * |
+ * The following functions are required to be implemented for all decoders |
+ * that advertise the VPX_CODEC_CAP_PUT_SLICE capability. Calling these functions |
+ * for codecs that don't advertise this capability will result in an error |
+ * code being returned, usually VPX_CODEC_ERROR |
+ * @{ |
+ */ |
- /*!\brief put slice callback prototype |
- * |
- * This callback is invoked by the decoder to notify the application of |
- * the availability of partially decoded image data. The |
- */ |
- typedef void (*vpx_codec_put_slice_cb_fn_t)(void *user_priv, |
- const vpx_image_t *img, |
- const vpx_image_rect_t *valid, |
- const vpx_image_rect_t *update); |
+ /*!\brief put slice callback prototype |
+ * |
+ * This callback is invoked by the decoder to notify the application of |
+ * the availability of partially decoded image data. The |
+ */ |
+ typedef void (*vpx_codec_put_slice_cb_fn_t)(void *user_priv, |
+ const vpx_image_t *img, |
+ const vpx_image_rect_t *valid, |
+ const vpx_image_rect_t *update); |
- /*!\brief Register for notification of slice completion. |
- * |
- * Registers a given function to be called when a decoded slice is |
- * available. |
- * |
- * \param[in] ctx Pointer to this instance's context |
- * \param[in] cb Pointer to the callback function |
- * \param[in] user_priv User's private data |
- * |
- * \retval #VPX_CODEC_OK |
- * Callback successfully registered. |
- * \retval #VPX_CODEC_ERROR |
- * Decoder context not initialized, or algorithm not capable of |
- * posting slice completion. |
- */ |
- vpx_codec_err_t vpx_codec_register_put_slice_cb(vpx_codec_ctx_t *ctx, |
- vpx_codec_put_slice_cb_fn_t cb, |
- void *user_priv); |
+ /*!\brief Register for notification of slice completion. |
+ * |
+ * Registers a given function to be called when a decoded slice is |
+ * available. |
+ * |
+ * \param[in] ctx Pointer to this instance's context |
+ * \param[in] cb Pointer to the callback function |
+ * \param[in] user_priv User's private data |
+ * |
+ * \retval #VPX_CODEC_OK |
+ * Callback successfully registered. |
+ * \retval #VPX_CODEC_ERROR |
+ * Decoder context not initialized, or algorithm not capable of |
+ * posting slice completion. |
+ */ |
+ vpx_codec_err_t vpx_codec_register_put_slice_cb(vpx_codec_ctx_t *ctx, |
+ vpx_codec_put_slice_cb_fn_t cb, |
+ void *user_priv); |
- /*!@} - end defgroup cap_put_slice*/ |
+ /*!@} - end defgroup cap_put_slice*/ |
- /*!@} - end defgroup decoder*/ |
+ /*!@} - end defgroup decoder*/ |
#endif |