1 /*
2  * Copyright (c) 2016, Alliance for Open Media. All rights reserved
3  *
4  * This source code is subject to the terms of the BSD 2 Clause License and
5  * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6  * was not distributed with this source code in the LICENSE file, you can
7  * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8  * Media Patent License 1.0 was not distributed with this source code in the
9  * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10  */
11 
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).
16  * @{
17  */
18 
19 /*!\file
20  * \brief Describes the codec algorithm interface to applications.
21  *
22  * This file describes the interface between an application and a
23  * video codec algorithm.
24  *
25  * An application instantiates a specific codec instance by using
26  * aom_codec_init() and a pointer to the algorithm's interface structure:
27  *     <pre>
28  *     my_app.c:
29  *       extern aom_codec_iface_t my_codec;
30  *       {
31  *           aom_codec_ctx_t algo;
32  *           res = aom_codec_init(&algo, &my_codec);
33  *       }
34  *     </pre>
35  *
36  * Once initialized, the instance is managed using other functions from
37  * the aom_codec_* family.
38  */
39 #ifndef AOM_AOM_AOM_CODEC_H_
40 #define AOM_AOM_AOM_CODEC_H_
41 
42 #ifdef __cplusplus
43 extern "C" {
44 #endif
45 
46 #include "aom/aom_image.h"
47 #include "aom/aom_integer.h"
48 
49 /*!\brief Decorator indicating a function is deprecated */
50 #ifndef AOM_DEPRECATED
51 #if defined(__GNUC__) && __GNUC__
52 #define AOM_DEPRECATED __attribute__((deprecated))
53 #elif defined(_MSC_VER)
54 #define AOM_DEPRECATED
55 #else
56 #define AOM_DEPRECATED
57 #endif
58 #endif /* AOM_DEPRECATED */
59 
60 #ifndef AOM_DECLSPEC_DEPRECATED
61 #if defined(__GNUC__) && __GNUC__
62 #define AOM_DECLSPEC_DEPRECATED /**< \copydoc #AOM_DEPRECATED */
63 #elif defined(_MSC_VER)
64 /*!\brief \copydoc #AOM_DEPRECATED */
65 #define AOM_DECLSPEC_DEPRECATED __declspec(deprecated)
66 #else
67 #define AOM_DECLSPEC_DEPRECATED /**< \copydoc #AOM_DEPRECATED */
68 #endif
69 #endif /* AOM_DECLSPEC_DEPRECATED */
70 
71 /*!\brief Decorator indicating a function is potentially unused */
72 #ifdef AOM_UNUSED
73 #elif defined(__GNUC__) || defined(__clang__)
74 #define AOM_UNUSED __attribute__((unused))
75 #else
76 #define AOM_UNUSED
77 #endif
78 
79 /*!\brief Decorator indicating that given struct/union/enum is packed */
80 #ifndef ATTRIBUTE_PACKED
81 #if defined(__GNUC__) && __GNUC__
82 #define ATTRIBUTE_PACKED __attribute__((packed))
83 #elif defined(_MSC_VER)
84 #define ATTRIBUTE_PACKED
85 #else
86 #define ATTRIBUTE_PACKED
87 #endif
88 #endif /* ATTRIBUTE_PACKED */
89 
90 /*!\brief Current ABI version number
91  *
92  * \internal
93  * If this file is altered in any way that changes the ABI, this value
94  * must be bumped.  Examples include, but are not limited to, changing
95  * types, removing or reassigning enums, adding/removing/rearranging
96  * fields to structures
97  */
98 #define AOM_CODEC_ABI_VERSION (3 + AOM_IMAGE_ABI_VERSION) /**<\hideinitializer*/
99 
100 /*!\brief Algorithm return codes */
101 typedef enum {
102   /*!\brief Operation completed without error */
103   AOM_CODEC_OK,
104 
105   /*!\brief Unspecified error */
106   AOM_CODEC_ERROR,
107 
108   /*!\brief Memory operation failed */
109   AOM_CODEC_MEM_ERROR,
110 
111   /*!\brief ABI version mismatch */
112   AOM_CODEC_ABI_MISMATCH,
113 
114   /*!\brief Algorithm does not have required capability */
115   AOM_CODEC_INCAPABLE,
116 
117   /*!\brief The given bitstream is not supported.
118    *
119    * The bitstream was unable to be parsed at the highest level. The decoder
120    * is unable to proceed. This error \ref SHOULD be treated as fatal to the
121    * stream. */
122   AOM_CODEC_UNSUP_BITSTREAM,
123 
124   /*!\brief Encoded bitstream uses an unsupported feature
125    *
126    * The decoder does not implement a feature required by the encoder. This
127    * return code should only be used for features that prevent future
128    * pictures from being properly decoded. This error \ref MAY be treated as
129    * fatal to the stream or \ref MAY be treated as fatal to the current GOP.
130    */
131   AOM_CODEC_UNSUP_FEATURE,
132 
133   /*!\brief The coded data for this stream is corrupt or incomplete
134    *
135    * There was a problem decoding the current frame.  This return code
136    * should only be used for failures that prevent future pictures from
137    * being properly decoded. This error \ref MAY be treated as fatal to the
138    * stream or \ref MAY be treated as fatal to the current GOP. If decoding
139    * is continued for the current GOP, artifacts may be present.
140    */
141   AOM_CODEC_CORRUPT_FRAME,
142 
143   /*!\brief An application-supplied parameter is not valid.
144    *
145    */
146   AOM_CODEC_INVALID_PARAM,
147 
148   /*!\brief An iterator reached the end of list.
149    *
150    */
151   AOM_CODEC_LIST_END
152 
153 } aom_codec_err_t;
154 
155 /*! \brief Codec capabilities bitfield
156  *
157  *  Each codec advertises the capabilities it supports as part of its
158  *  ::aom_codec_iface_t interface structure. Capabilities are extra interfaces
159  *  or functionality, and are not required to be supported.
160  *
161  *  The available flags are specified by AOM_CODEC_CAP_* defines.
162  */
163 typedef long aom_codec_caps_t;
164 #define AOM_CODEC_CAP_DECODER 0x1 /**< Is a decoder */
165 #define AOM_CODEC_CAP_ENCODER 0x2 /**< Is an encoder */
166 
167 /*! \brief Initialization-time Feature Enabling
168  *
169  *  Certain codec features must be known at initialization time, to allow for
170  *  proper memory allocation.
171  *
172  *  The available flags are specified by AOM_CODEC_USE_* defines.
173  */
174 typedef long aom_codec_flags_t;
175 
176 /*!\brief Codec interface structure.
177  *
178  * Contains function pointers and other data private to the codec
179  * implementation. This structure is opaque to the application.
180  */
181 typedef const struct aom_codec_iface aom_codec_iface_t;
182 
183 /*!\brief Codec private data structure.
184  *
185  * Contains data private to the codec implementation. This structure is opaque
186  * to the application.
187  */
188 typedef struct aom_codec_priv aom_codec_priv_t;
189 
190 /*!\brief Iterator
191  *
192  * Opaque storage used for iterating over lists.
193  */
194 typedef const void *aom_codec_iter_t;
195 
196 /*!\brief Codec context structure
197  *
198  * All codecs \ref MUST support this context structure fully. In general,
199  * this data should be considered private to the codec algorithm, and
200  * not be manipulated or examined by the calling application. Applications
201  * may reference the 'name' member to get a printable description of the
202  * algorithm.
203  */
204 typedef struct aom_codec_ctx {
205   const char *name;             /**< Printable interface name */
206   aom_codec_iface_t *iface;     /**< Interface pointers */
207   aom_codec_err_t err;          /**< Last returned error */
208   const char *err_detail;       /**< Detailed info, if available */
209   aom_codec_flags_t init_flags; /**< Flags passed at init time */
210   union {
211     /**< Decoder Configuration Pointer */
212     const struct aom_codec_dec_cfg *dec;
213     /**< Encoder Configuration Pointer */
214     const struct aom_codec_enc_cfg *enc;
215     const void *raw;
216   } config;               /**< Configuration pointer aliasing union */
217   aom_codec_priv_t *priv; /**< Algorithm private storage */
218 } aom_codec_ctx_t;
219 
220 /*!\brief Bit depth for codec
221  * *
222  * This enumeration determines the bit depth of the codec.
223  */
224 typedef enum aom_bit_depth {
225   AOM_BITS_8 = 8,   /**<  8 bits */
226   AOM_BITS_10 = 10, /**< 10 bits */
227   AOM_BITS_12 = 12, /**< 12 bits */
228 } aom_bit_depth_t;
229 
230 /*!\brief Superblock size selection.
231  *
232  * Defines the superblock size used for encoding. The superblock size can
233  * either be fixed at 64x64 or 128x128 pixels, or it can be dynamically
234  * selected by the encoder for each frame.
235  */
236 typedef enum aom_superblock_size {
237   AOM_SUPERBLOCK_SIZE_64X64,   /**< Always use 64x64 superblocks. */
238   AOM_SUPERBLOCK_SIZE_128X128, /**< Always use 128x128 superblocks. */
239   AOM_SUPERBLOCK_SIZE_DYNAMIC  /**< Select superblock size dynamically. */
240 } aom_superblock_size_t;
241 
242 /*
243  * Library Version Number Interface
244  *
245  * For example, see the following sample return values:
246  *     aom_codec_version()           (1<<16 | 2<<8 | 3)
247  *     aom_codec_version_str()       "v1.2.3-rc1-16-gec6a1ba"
248  *     aom_codec_version_extra_str() "rc1-16-gec6a1ba"
249  */
250 
251 /*!\brief Return the version information (as an integer)
252  *
253  * Returns a packed encoding of the library version number. This will only
254  * include
255  * the major.minor.patch component of the version number. Note that this encoded
256  * value should be accessed through the macros provided, as the encoding may
257  * change
258  * in the future.
259  *
260  */
261 int aom_codec_version(void);
262 
263 /*!\brief Return the version major number */
264 #define aom_codec_version_major() ((aom_codec_version() >> 16) & 0xff)
265 
266 /*!\brief Return the version minor number */
267 #define aom_codec_version_minor() ((aom_codec_version() >> 8) & 0xff)
268 
269 /*!\brief Return the version patch number */
270 #define aom_codec_version_patch() ((aom_codec_version() >> 0) & 0xff)
271 
272 /*!\brief Return the version information (as a string)
273  *
274  * Returns a printable string containing the full library version number. This
275  * may
276  * contain additional text following the three digit version number, as to
277  * indicate
278  * release candidates, prerelease versions, etc.
279  *
280  */
281 const char *aom_codec_version_str(void);
282 
283 /*!\brief Return the version information (as a string)
284  *
285  * Returns a printable "extra string". This is the component of the string
286  * returned
287  * by aom_codec_version_str() following the three digit version number.
288  *
289  */
290 const char *aom_codec_version_extra_str(void);
291 
292 /*!\brief Return the build configuration
293  *
294  * Returns a printable string containing an encoded version of the build
295  * configuration. This may be useful to aom support.
296  *
297  */
298 const char *aom_codec_build_config(void);
299 
300 /*!\brief Return the name for a given interface
301  *
302  * Returns a human readable string for name of the given codec interface.
303  *
304  * \param[in]    iface     Interface pointer
305  *
306  */
307 const char *aom_codec_iface_name(aom_codec_iface_t *iface);
308 
309 /*!\brief Convert error number to printable string
310  *
311  * Returns a human readable string for the last error returned by the
312  * algorithm. The returned error will be one line and will not contain
313  * any newline characters.
314  *
315  *
316  * \param[in]    err     Error number.
317  *
318  */
319 const char *aom_codec_err_to_string(aom_codec_err_t err);
320 
321 /*!\brief Retrieve error synopsis for codec context
322  *
323  * Returns a human readable string for the last error returned by the
324  * algorithm. The returned error will be one line and will not contain
325  * any newline characters.
326  *
327  *
328  * \param[in]    ctx     Pointer to this instance's context.
329  *
330  */
331 const char *aom_codec_error(aom_codec_ctx_t *ctx);
332 
333 /*!\brief Retrieve detailed error information for codec context
334  *
335  * Returns a human readable string providing detailed information about
336  * the last error.
337  *
338  * \param[in]    ctx     Pointer to this instance's context.
339  *
340  * \retval NULL
341  *     No detailed information is available.
342  */
343 const char *aom_codec_error_detail(aom_codec_ctx_t *ctx);
344 
345 /* REQUIRED FUNCTIONS
346  *
347  * The following functions are required to be implemented for all codecs.
348  * They represent the base case functionality expected of all codecs.
349  */
350 
351 /*!\brief Destroy a codec instance
352  *
353  * Destroys a codec context, freeing any associated memory buffers.
354  *
355  * \param[in] ctx   Pointer to this instance's context
356  *
357  * \retval #AOM_CODEC_OK
358  *     The codec algorithm initialized.
359  * \retval #AOM_CODEC_MEM_ERROR
360  *     Memory allocation failed.
361  */
362 aom_codec_err_t aom_codec_destroy(aom_codec_ctx_t *ctx);
363 
364 /*!\brief Get the capabilities of an algorithm.
365  *
366  * Retrieves the capabilities bitfield from the algorithm's interface.
367  *
368  * \param[in] iface   Pointer to the algorithm interface
369  *
370  */
371 aom_codec_caps_t aom_codec_get_caps(aom_codec_iface_t *iface);
372 
373 /*!\brief Control algorithm
374  *
375  * This function is used to exchange algorithm specific data with the codec
376  * instance. This can be used to implement features specific to a particular
377  * algorithm.
378  *
379  * This wrapper function dispatches the request to the helper function
380  * associated with the given ctrl_id. It tries to call this function
381  * transparently, but will return #AOM_CODEC_ERROR if the request could not
382  * be dispatched.
383  *
384  * Note that this function should not be used directly. Call the
385  * #aom_codec_control wrapper macro instead.
386  *
387  * \param[in]     ctx              Pointer to this instance's context
388  * \param[in]     ctrl_id          Algorithm specific control identifier
389  *
390  * \retval #AOM_CODEC_OK
391  *     The control request was processed.
392  * \retval #AOM_CODEC_ERROR
393  *     The control request was not processed.
394  * \retval #AOM_CODEC_INVALID_PARAM
395  *     The data was not valid.
396  */
397 aom_codec_err_t aom_codec_control_(aom_codec_ctx_t *ctx, int ctrl_id, ...);
398 #if defined(AOM_DISABLE_CTRL_TYPECHECKS) && AOM_DISABLE_CTRL_TYPECHECKS
399 #define aom_codec_control(ctx, id, data) aom_codec_control_(ctx, id, data)
400 #define AOM_CTRL_USE_TYPE(id, typ)
401 #define AOM_CTRL_USE_TYPE_DEPRECATED(id, typ)
402 #define AOM_CTRL_VOID(id, typ)
403 
404 #else
405 /*!\brief aom_codec_control wrapper macro
406  *
407  * This macro allows for type safe conversions across the variadic parameter
408  * to aom_codec_control_().
409  *
410  * \internal
411  * It works by dispatching the call to the control function through a wrapper
412  * function named with the id parameter.
413  */
414 #define aom_codec_control(ctx, id, data) \
415   aom_codec_control_##id(ctx, id, data) /**<\hideinitializer*/
416 
417 /*!\brief aom_codec_control type definition macro
418  *
419  * This macro allows for type safe conversions across the variadic parameter
420  * to aom_codec_control_(). It defines the type of the argument for a given
421  * control identifier.
422  *
423  * \internal
424  * It defines a static function with
425  * the correctly typed arguments as a wrapper to the type-unsafe internal
426  * function.
427  */
428 #define AOM_CTRL_USE_TYPE(id, typ)                                           \
429   static aom_codec_err_t aom_codec_control_##id(aom_codec_ctx_t *, int, typ) \
430       AOM_UNUSED;                                                            \
431                                                                              \
432   static aom_codec_err_t aom_codec_control_##id(aom_codec_ctx_t *ctx,        \
433                                                 int ctrl_id, typ data) {     \
434     return aom_codec_control_(ctx, ctrl_id, data);                           \
435   } /**<\hideinitializer*/
436 
437 /*!\brief aom_codec_control deprecated type definition macro
438  *
439  * Like #AOM_CTRL_USE_TYPE, but indicates that the specified control is
440  * deprecated and should not be used. Consult the documentation for your
441  * codec for more information.
442  *
443  * \internal
444  * It defines a static function with the correctly typed arguments as a
445  * wrapper to the type-unsafe internal function.
446  */
447 #define AOM_CTRL_USE_TYPE_DEPRECATED(id, typ)                            \
448   AOM_DECLSPEC_DEPRECATED static aom_codec_err_t aom_codec_control_##id( \
449       aom_codec_ctx_t *, int, typ) AOM_DEPRECATED AOM_UNUSED;            \
450                                                                          \
451   AOM_DECLSPEC_DEPRECATED static aom_codec_err_t aom_codec_control_##id( \
452       aom_codec_ctx_t *ctx, int ctrl_id, typ data) {                     \
453     return aom_codec_control_(ctx, ctrl_id, data);                       \
454   } /**<\hideinitializer*/
455 
456 /*!\brief aom_codec_control void type definition macro
457  *
458  * This macro allows for type safe conversions across the variadic parameter
459  * to aom_codec_control_(). It indicates that a given control identifier takes
460  * no argument.
461  *
462  * \internal
463  * It defines a static function without a data argument as a wrapper to the
464  * type-unsafe internal function.
465  */
466 #define AOM_CTRL_VOID(id)                                               \
467   static aom_codec_err_t aom_codec_control_##id(aom_codec_ctx_t *, int) \
468       AOM_UNUSED;                                                       \
469                                                                         \
470   static aom_codec_err_t aom_codec_control_##id(aom_codec_ctx_t *ctx,   \
471                                                 int ctrl_id) {          \
472     return aom_codec_control_(ctx, ctrl_id);                            \
473   } /**<\hideinitializer*/
474 
475 #endif
476 
477 /*!\brief OBU types. */
478 typedef enum ATTRIBUTE_PACKED {
479   OBU_SEQUENCE_HEADER = 1,
480   OBU_TEMPORAL_DELIMITER = 2,
481   OBU_FRAME_HEADER = 3,
482   OBU_TILE_GROUP = 4,
483   OBU_METADATA = 5,
484   OBU_FRAME = 6,
485   OBU_REDUNDANT_FRAME_HEADER = 7,
486   OBU_TILE_LIST = 8,
487   OBU_PADDING = 15,
488 } OBU_TYPE;
489 
490 /*!\brief OBU metadata types. */
491 typedef enum {
492   OBU_METADATA_TYPE_AOM_RESERVED_0 = 0,
493   OBU_METADATA_TYPE_HDR_CLL = 1,
494   OBU_METADATA_TYPE_HDR_MDCV = 2,
495   OBU_METADATA_TYPE_SCALABILITY = 3,
496   OBU_METADATA_TYPE_ITUT_T35 = 4,
497   OBU_METADATA_TYPE_TIMECODE = 5,
498 } OBU_METADATA_TYPE;
499 
500 /*!\brief Returns string representation of OBU_TYPE.
501  *
502  * \param[in]     type            The OBU_TYPE to convert to string.
503  */
504 const char *aom_obu_type_to_string(OBU_TYPE type);
505 
506 /*!\brief Config Options
507  *
508  * This type allows to enumerate and control options defined for control
509  * via config file at runtime.
510  */
511 typedef struct cfg_options {
512   /*!\brief Reflects if ext_partition should be enabled
513    *
514    * If this value is non-zero it enabled the feature
515    */
516   unsigned int ext_partition;
517 } cfg_options_t;
518 
519 /*!@} - end defgroup codec*/
520 #ifdef __cplusplus
521 }
522 #endif
523 #endif  // AOM_AOM_AOM_CODEC_H_
524