2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved.
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.
12 /*!\defgroup codec Common Algorithm Interface
13 * This abstraction allows applications to easily support multiple video
14 * formats with minimal code duplication. This section describes the interface
15 * common to all codecs (both encoders and decoders).
20 * \brief Describes the codec algorithm interface to applications.
22 * This file describes the interface between an application and a
23 * video codec algorithm.
25 * An application instantiates a specific codec instance by using
26 * vpx_codec_init() and a pointer to the algorithm's interface structure:
29 * extern vpx_codec_iface_t my_codec;
31 * vpx_codec_ctx_t algo;
32 * res = vpx_codec_init(&algo, &my_codec);
36 * Once initialized, the instance is manged using other functions from
37 * the vpx_codec_* family.
45 #include "vpx_integer.h"
46 #include "vpx_image.h"
48 /*!\brief Decorator indicating a function is deprecated */
50 #if defined(__GNUC__) && __GNUC__
51 #define DEPRECATED __attribute__ ((deprecated))
52 #define DECLSPEC_DEPRECATED /**< \copydoc #DEPRECATED */
53 #elif defined(_MSC_VER)
55 #define DECLSPEC_DEPRECATED __declspec(deprecated) /**< \copydoc #DEPRECATED */
58 #define DECLSPEC_DEPRECATED /**< \copydoc #DEPRECATED */
62 /*!\brief Decorator indicating a function is potentially unused */
65 #define UNUSED __attribute__ ((unused))
70 /*!\brief Current ABI version number
73 * If this file is altered in any way that changes the ABI, this value
74 * must be bumped. Examples include, but are not limited to, changing
75 * types, removing or reassigning enums, adding/removing/rearranging
76 * fields to structures
78 #define VPX_CODEC_ABI_VERSION (2 + VPX_IMAGE_ABI_VERSION) /**<\hideinitializer*/
80 /*!\brief Algorithm return codes */
82 /*!\brief Operation completed without error */
85 /*!\brief Unspecified error */
88 /*!\brief Memory operation failed */
91 /*!\brief ABI version mismatch */
92 VPX_CODEC_ABI_MISMATCH
,
94 /*!\brief Algorithm does not have required capability */
97 /*!\brief The given bitstream is not supported.
99 * The bitstream was unable to be parsed at the highest level. The decoder
100 * is unable to proceed. This error \ref SHOULD be treated as fatal to the
102 VPX_CODEC_UNSUP_BITSTREAM
,
104 /*!\brief Encoded bitstream uses an unsupported feature
106 * The decoder does not implement a feature required by the encoder. This
107 * return code should only be used for features that prevent future
108 * pictures from being properly decoded. This error \ref MAY be treated as
109 * fatal to the stream or \ref MAY be treated as fatal to the current GOP.
111 VPX_CODEC_UNSUP_FEATURE
,
113 /*!\brief The coded data for this stream is corrupt or incomplete
115 * There was a problem decoding the current frame. This return code
116 * should only be used for failures that prevent future pictures from
117 * being properly decoded. This error \ref MAY be treated as fatal to the
118 * stream or \ref MAY be treated as fatal to the current GOP. If decoding
119 * is continued for the current GOP, artifacts may be present.
121 VPX_CODEC_CORRUPT_FRAME
,
123 /*!\brief An application-supplied parameter is not valid.
126 VPX_CODEC_INVALID_PARAM
,
128 /*!\brief An iterator reached the end of list.
137 /*! \brief Codec capabilities bitfield
139 * Each codec advertises the capabilities it supports as part of its
140 * ::vpx_codec_iface_t interface structure. Capabilities are extra interfaces
141 * or functionality, and are not required to be supported.
143 * The available flags are specified by VPX_CODEC_CAP_* defines.
145 typedef long vpx_codec_caps_t
;
146 #define VPX_CODEC_CAP_DECODER 0x1 /**< Is a decoder */
147 #define VPX_CODEC_CAP_ENCODER 0x2 /**< Is an encoder */
148 #define VPX_CODEC_CAP_XMA 0x4 /**< Supports eXternal Memory Allocation */
151 /*! \brief Initialization-time Feature Enabling
153 * Certain codec features must be known at initialization time, to allow for
154 * proper memory allocation.
156 * The available flags are specified by VPX_CODEC_USE_* defines.
158 typedef long vpx_codec_flags_t
;
159 #define VPX_CODEC_USE_XMA 0x00000001 /**< Use eXternal Memory Allocation mode */
162 /*!\brief Codec interface structure.
164 * Contains function pointers and other data private to the codec
165 * implementation. This structure is opaque to the application.
167 typedef const struct vpx_codec_iface vpx_codec_iface_t
;
170 /*!\brief Codec private data structure.
172 * Contains data private to the codec implementation. This structure is opaque
173 * to the application.
175 typedef struct vpx_codec_priv vpx_codec_priv_t
;
180 * Opaque storage used for iterating over lists.
182 typedef const void *vpx_codec_iter_t
;
185 /*!\brief Codec context structure
187 * All codecs \ref MUST support this context structure fully. In general,
188 * this data should be considered private to the codec algorithm, and
189 * not be manipulated or examined by the calling application. Applications
190 * may reference the 'name' member to get a printable description of the
193 typedef struct vpx_codec_ctx
195 const char *name
; /**< Printable interface name */
196 vpx_codec_iface_t
*iface
; /**< Interface pointers */
197 vpx_codec_err_t err
; /**< Last returned error */
198 const char *err_detail
; /**< Detailed info, if available */
199 vpx_codec_flags_t init_flags
; /**< Flags passed at init time */
202 struct vpx_codec_dec_cfg
*dec
; /**< Decoder Configuration Pointer */
203 struct vpx_codec_enc_cfg
*enc
; /**< Encoder Configuration Pointer */
205 } config
; /**< Configuration pointer aliasing union */
206 vpx_codec_priv_t
*priv
; /**< Algorithm private storage */
211 * Library Version Number Interface
213 * For example, see the following sample return values:
214 * vpx_codec_version() (1<<16 | 2<<8 | 3)
215 * vpx_codec_version_str() "v1.2.3-rc1-16-gec6a1ba"
216 * vpx_codec_version_extra_str() "rc1-16-gec6a1ba"
219 /*!\brief Return the version information (as an integer)
221 * Returns a packed encoding of the library version number. This will only include
222 * the major.minor.patch component of the version number. Note that this encoded
223 * value should be accessed through the macros provided, as the encoding may change
227 int vpx_codec_version(void);
228 #define VPX_VERSION_MAJOR(v) ((v>>16)&0xff) /**< extract major from packed version */
229 #define VPX_VERSION_MINOR(v) ((v>>8)&0xff) /**< extract minor from packed version */
230 #define VPX_VERSION_PATCH(v) ((v>>0)&0xff) /**< extract patch from packed version */
232 /*!\brief Return the version major number */
233 #define vpx_codec_version_major() ((vpx_codec_version()>>16)&0xff)
235 /*!\brief Return the version minor number */
236 #define vpx_codec_version_minor() ((vpx_codec_version()>>8)&0xff)
238 /*!\brief Return the version patch number */
239 #define vpx_codec_version_patch() ((vpx_codec_version()>>0)&0xff)
242 /*!\brief Return the version information (as a string)
244 * Returns a printable string containing the full library version number. This may
245 * contain additional text following the three digit version number, as to indicate
246 * release candidates, prerelease versions, etc.
249 const char *vpx_codec_version_str(void);
252 /*!\brief Return the version information (as a string)
254 * Returns a printable "extra string". This is the component of the string returned
255 * by vpx_codec_version_str() following the three digit version number.
258 const char *vpx_codec_version_extra_str(void);
261 /*!\brief Return the build configuration
263 * Returns a printable string containing an encoded version of the build
264 * configuration. This may be useful to vpx support.
267 const char *vpx_codec_build_config(void);
270 /*!\brief Return the name for a given interface
272 * Returns a human readable string for name of the given codec interface.
274 * \param[in] iface Interface pointer
277 const char *vpx_codec_iface_name(vpx_codec_iface_t
*iface
);
280 /*!\brief Convert error number to printable string
282 * Returns a human readable string for the last error returned by the
283 * algorithm. The returned error will be one line and will not contain
284 * any newline characters.
287 * \param[in] err Error number.
290 const char *vpx_codec_err_to_string(vpx_codec_err_t err
);
293 /*!\brief Retrieve error synopsis for codec context
295 * Returns a human readable string for the last error returned by the
296 * algorithm. The returned error will be one line and will not contain
297 * any newline characters.
300 * \param[in] ctx Pointer to this instance's context.
303 const char *vpx_codec_error(vpx_codec_ctx_t
*ctx
);
306 /*!\brief Retrieve detailed error information for codec context
308 * Returns a human readable string providing detailed information about
311 * \param[in] ctx Pointer to this instance's context.
314 * No detailed information is available.
316 const char *vpx_codec_error_detail(vpx_codec_ctx_t
*ctx
);
319 /* REQUIRED FUNCTIONS
321 * The following functions are required to be implemented for all codecs.
322 * They represent the base case functionality expected of all codecs.
325 /*!\brief Destroy a codec instance
327 * Destroys a codec context, freeing any associated memory buffers.
329 * \param[in] ctx Pointer to this instance's context
331 * \retval #VPX_CODEC_OK
332 * The codec algorithm initialized.
333 * \retval #VPX_CODEC_MEM_ERROR
334 * Memory allocation failed.
336 vpx_codec_err_t
vpx_codec_destroy(vpx_codec_ctx_t
*ctx
);
339 /*!\brief Get the capabilities of an algorithm.
341 * Retrieves the capabilities bitfield from the algorithm's interface.
343 * \param[in] iface Pointer to the algorithm interface
346 vpx_codec_caps_t
vpx_codec_get_caps(vpx_codec_iface_t
*iface
);
349 /*!\brief Control algorithm
351 * This function is used to exchange algorithm specific data with the codec
352 * instance. This can be used to implement features specific to a particular
355 * This wrapper function dispatches the request to the helper function
356 * associated with the given ctrl_id. It tries to call this function
357 * transparently, but will return #VPX_CODEC_ERROR if the request could not
360 * Note that this function should not be used directly. Call the
361 * #vpx_codec_control wrapper macro instead.
363 * \param[in] ctx Pointer to this instance's context
364 * \param[in] ctrl_id Algorithm specific control identifier
366 * \retval #VPX_CODEC_OK
367 * The control request was processed.
368 * \retval #VPX_CODEC_ERROR
369 * The control request was not processed.
370 * \retval #VPX_CODEC_INVALID_PARAM
371 * The data was not valid.
373 vpx_codec_err_t
vpx_codec_control_(vpx_codec_ctx_t
*ctx
,
376 #if defined(VPX_DISABLE_CTRL_TYPECHECKS) && VPX_DISABLE_CTRL_TYPECHECKS
377 # define vpx_codec_control(ctx,id,data) vpx_codec_control_(ctx,id,data)
378 # define VPX_CTRL_USE_TYPE(id, typ)
379 # define VPX_CTRL_USE_TYPE_DEPRECATED(id, typ)
380 # define VPX_CTRL_VOID(id, typ)
383 /*!\brief vpx_codec_control wrapper macro
385 * This macro allows for type safe conversions across the variadic parameter
386 * to vpx_codec_control_().
389 * It works by dispatching the call to the control function through a wrapper
390 * function named with the id parameter.
392 # define vpx_codec_control(ctx,id,data) vpx_codec_control_##id(ctx,id,data)\
393 /**<\hideinitializer*/
396 /*!\brief vpx_codec_control type definition macro
398 * This macro allows for type safe conversions across the variadic parameter
399 * to vpx_codec_control_(). It defines the type of the argument for a given
400 * control identifier.
403 * It defines a static function with
404 * the correctly typed arguments as a wrapper to the type-unsafe internal
407 # define VPX_CTRL_USE_TYPE(id, typ) \
408 static vpx_codec_err_t \
409 vpx_codec_control_##id(vpx_codec_ctx_t*, int, typ) UNUSED;\
411 static vpx_codec_err_t \
412 vpx_codec_control_##id(vpx_codec_ctx_t *ctx, int ctrl_id, typ data) {\
413 return vpx_codec_control_(ctx, ctrl_id, data);\
414 } /**<\hideinitializer*/
417 /*!\brief vpx_codec_control deprecated type definition macro
419 * Like #VPX_CTRL_USE_TYPE, but indicates that the specified control is
420 * deprecated and should not be used. Consult the documentation for your
421 * codec for more information.
424 * It defines a static function with the correctly typed arguments as a
425 * wrapper to the type-unsafe internal function.
427 # define VPX_CTRL_USE_TYPE_DEPRECATED(id, typ) \
428 DECLSPEC_DEPRECATED static vpx_codec_err_t \
429 vpx_codec_control_##id(vpx_codec_ctx_t*, int, typ) DEPRECATED UNUSED;\
431 DECLSPEC_DEPRECATED static vpx_codec_err_t \
432 vpx_codec_control_##id(vpx_codec_ctx_t *ctx, int ctrl_id, typ data) {\
433 return vpx_codec_control_(ctx, ctrl_id, data);\
434 } /**<\hideinitializer*/
437 /*!\brief vpx_codec_control void type definition macro
439 * This macro allows for type safe conversions across the variadic parameter
440 * to vpx_codec_control_(). It indicates that a given control identifier takes
444 * It defines a static function without a data argument as a wrapper to the
445 * type-unsafe internal function.
447 # define VPX_CTRL_VOID(id) \
448 static vpx_codec_err_t \
449 vpx_codec_control_##id(vpx_codec_ctx_t*, int) UNUSED;\
451 static vpx_codec_err_t \
452 vpx_codec_control_##id(vpx_codec_ctx_t *ctx, int ctrl_id) {\
453 return vpx_codec_control_(ctx, ctrl_id);\
454 } /**<\hideinitializer*/
460 /*!\defgroup cap_xma External Memory Allocation Functions
462 * The following functions are required to be implemented for all codecs
463 * that advertise the VPX_CODEC_CAP_XMA capability. Calling these functions
464 * for codecs that don't advertise this capability will result in an error
465 * code being returned, usually VPX_CODEC_INCAPABLE
470 /*!\brief Memory Map Entry
472 * This structure is used to contain the properties of a memory segment. It
473 * is populated by the codec in the request phase, and by the calling
474 * application once the requested allocation has been performed.
476 typedef struct vpx_codec_mmap
479 * The following members are set by the codec when requesting a segment
481 unsigned int id
; /**< identifier for the segment's contents */
482 unsigned long sz
; /**< size of the segment, in bytes */
483 unsigned int align
; /**< required alignment of the segment, in bytes */
484 unsigned int flags
; /**< bitfield containing segment properties */
485 #define VPX_CODEC_MEM_ZERO 0x1 /**< Segment must be zeroed by allocation */
486 #define VPX_CODEC_MEM_WRONLY 0x2 /**< Segment need not be readable */
487 #define VPX_CODEC_MEM_FAST 0x4 /**< Place in fast memory, if available */
489 /* The following members are to be filled in by the allocation function */
490 void *base
; /**< pointer to the allocated segment */
491 void (*dtor
)(struct vpx_codec_mmap
*map
); /**< destructor to call */
492 void *priv
; /**< allocator private storage */
493 } vpx_codec_mmap_t
; /**< alias for struct vpx_codec_mmap */
496 /*!\brief Iterate over the list of segments to allocate.
498 * Iterates over a list of the segments to allocate. The iterator storage
499 * should be initialized to NULL to start the iteration. Iteration is complete
500 * when this function returns VPX_CODEC_LIST_END. The amount of memory needed to
501 * allocate is dependent upon the size of the encoded stream. In cases where the
502 * stream is not available at allocation time, a fixed size must be requested.
503 * The codec will not be able to operate on streams larger than the size used at
506 * \param[in] ctx Pointer to this instance's context.
507 * \param[out] mmap Pointer to the memory map entry to populate.
508 * \param[in,out] iter Iterator storage, initialized to NULL
510 * \retval #VPX_CODEC_OK
511 * The memory map entry was populated.
512 * \retval #VPX_CODEC_ERROR
513 * Codec does not support XMA mode.
514 * \retval #VPX_CODEC_MEM_ERROR
515 * Unable to determine segment size from stream info.
517 vpx_codec_err_t
vpx_codec_get_mem_map(vpx_codec_ctx_t
*ctx
,
518 vpx_codec_mmap_t
*mmap
,
519 vpx_codec_iter_t
*iter
);
522 /*!\brief Identify allocated segments to codec instance
524 * Stores a list of allocated segments in the codec. Segments \ref MUST be
525 * passed in the order they are read from vpx_codec_get_mem_map(), but may be
526 * passed in groups of any size. Segments \ref MUST be set only once. The
527 * allocation function \ref MUST ensure that the vpx_codec_mmap_t::base member
528 * is non-NULL. If the segment requires cleanup handling (e.g., calling free()
529 * or close()) then the vpx_codec_mmap_t::dtor member \ref MUST be populated.
531 * \param[in] ctx Pointer to this instance's context.
532 * \param[in] mmaps Pointer to the first memory map entry in the list.
533 * \param[in] num_maps Number of entries being set at this time
535 * \retval #VPX_CODEC_OK
536 * The segment was stored in the codec context.
537 * \retval #VPX_CODEC_INCAPABLE
538 * Codec does not support XMA mode.
539 * \retval #VPX_CODEC_MEM_ERROR
540 * Segment base address was not set, or segment was already stored.
543 vpx_codec_err_t
vpx_codec_set_mem_map(vpx_codec_ctx_t
*ctx
,
544 vpx_codec_mmap_t
*mmaps
,
545 unsigned int num_maps
);
547 /*!@} - end defgroup cap_xma*/
548 /*!@} - end defgroup codec*/