libavutil/avutil.h
558b86a5
 /*
  * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
  *
  * This file is part of FFmpeg.
  *
  * FFmpeg is free software; you can redistribute it and/or
  * modify it under the terms of the GNU Lesser General Public
  * License as published by the Free Software Foundation; either
  * version 2.1 of the License, or (at your option) any later version.
  *
  * FFmpeg is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with FFmpeg; if not, write to the Free Software
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  */
 
98790382
 #ifndef AVUTIL_AVUTIL_H
 #define AVUTIL_AVUTIL_H
558b86a5
 
 /**
ba87f080
  * @file
7ce68923
  * external API header
558b86a5
  */
 
68fac5c2
 /*
757cd8d8
  * @mainpage
  *
  * @section libav_intro Introduction
  *
cfac648e
  * This document describes the usage of the different libraries
313d30c1
  * provided by FFmpeg.
757cd8d8
  *
e97e5a2e
  * @li @ref libavc "libavcodec" encoding/decoding library
757cd8d8
  * @li @subpage libavfilter graph based frame editing library
e361b508
  * @li @ref libavf "libavformat" I/O and muxing/demuxing library
1be32305
  * @li @ref lavd "libavdevice" special devices muxing/demuxing library
757cd8d8
  * @li @ref lavu "libavutil" common utility library
  * @li @subpage libpostproc post processing library
  * @li @subpage libswscale  color conversion and scaling library
  */
 
 /**
  * @defgroup lavu Common utility functions
  *
  * @brief
313d30c1
  * libavutil contains the code shared across all the other FFmpeg
757cd8d8
  * libraries
  *
  * @note In order to use the functions provided by avutil you must include
  * the specific header.
  *
  * @{
  *
  * @defgroup lavu_crypto Crypto and Hashing
  *
  * @{
  * @}
  *
  * @defgroup lavu_math Maths
  * @{
  *
  * @}
  *
  * @defgroup lavu_string String Manipulation
  *
  * @{
  *
  * @}
  *
  * @defgroup lavu_mem Memory Management
  *
  * @{
  *
  * @}
  *
  * @defgroup lavu_data Data Structures
  * @{
  *
  * @}
  *
  * @defgroup lavu_audio Audio related
  *
  * @{
  *
  * @}
  *
  * @defgroup lavu_error Error Codes
  *
  * @{
  *
  * @}
  *
  * @defgroup lavu_misc Other
  *
  * @{
  *
  * @defgroup lavu_internal Internal
  *
  * Not exported functions, for internal usage only
  *
  * @{
  *
  * @}
  */
 
 
 /**
  * @defgroup preproc_misc Preprocessor String Macros
  *
  * String manipulation macros
  *
  * @{
  */
558b86a5
 
 #define AV_STRINGIFY(s)         AV_TOSTRING(s)
 #define AV_TOSTRING(s) #s
87fec35d
 
 #define AV_GLUE(a, b) a ## b
 #define AV_JOIN(a, b) AV_GLUE(a, b)
 
d408b77a
 #define AV_PRAGMA(s) _Pragma(#s)
558b86a5
 
757cd8d8
 /**
  * @}
  */
 
 /**
  * @defgroup version_utils Library Version Macros
  *
  * Useful to check and match library version in order to maintain
  * backward compatibility.
  *
  * @{
  */
 
800c289a
 #define AV_VERSION_INT(a, b, c) (a<<16 | b<<8 | c)
 #define AV_VERSION_DOT(a, b, c) a ##.## b ##.## c
 #define AV_VERSION(a, b, c) AV_VERSION_DOT(a, b, c)
e97ac1e6
 
757cd8d8
 /**
  * @}
  *
  * @defgroup lavu_ver Version and Build diagnostics
  *
  * Macros and function useful to check at compiletime and at runtime
  * which version of libavutil is in use.
  *
  * @{
  */
 
139f3ac4
 #define LIBAVUTIL_VERSION_MAJOR 51
f2ee0656
 #define LIBAVUTIL_VERSION_MINOR 54
c28e7af7
 #define LIBAVUTIL_VERSION_MICRO 100
e97ac1e6
 
800c289a
 #define LIBAVUTIL_VERSION_INT   AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
                                                LIBAVUTIL_VERSION_MINOR, \
                                                LIBAVUTIL_VERSION_MICRO)
 #define LIBAVUTIL_VERSION       AV_VERSION(LIBAVUTIL_VERSION_MAJOR,     \
                                            LIBAVUTIL_VERSION_MINOR,     \
                                            LIBAVUTIL_VERSION_MICRO)
558b86a5
 #define LIBAVUTIL_BUILD         LIBAVUTIL_VERSION_INT
 
 #define LIBAVUTIL_IDENT         "Lavu" AV_STRINGIFY(LIBAVUTIL_VERSION)
 
7f0026dd
 /**
757cd8d8
  * @}
  *
  * @defgroup depr_guards Deprecation guards
d2af7205
  * Those FF_API_* defines are not part of public API.
  * They may change, break or disappear at any time.
757cd8d8
  *
  * They are used mostly internally to mark code that will be removed
  * on the next major version.
  *
  * @{
d2af7205
  */
 #ifndef FF_API_OLD_EVAL_NAMES
efb5fa79
 #define FF_API_OLD_EVAL_NAMES (LIBAVUTIL_VERSION_MAJOR < 52)
d2af7205
 #endif
a6703faa
 #ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
 #define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 52)
 #endif
dc59ec5e
 #ifndef FF_API_FIND_OPT
 #define FF_API_FIND_OPT                 (LIBAVUTIL_VERSION_MAJOR < 52)
 #endif
323b9306
 #ifndef FF_API_AV_FIFO_PEEK
 #define FF_API_AV_FIFO_PEEK             (LIBAVUTIL_VERSION_MAJOR < 52)
 #endif
79eff913
 #ifndef FF_API_OLD_AVOPTIONS
 #define FF_API_OLD_AVOPTIONS            (LIBAVUTIL_VERSION_MAJOR < 52)
 #endif
d2af7205
 
 /**
757cd8d8
  * @}
  */
 
 /**
  * @addtogroup lavu_ver
  * @{
  */
 
 /**
49bd8e4b
  * Return the LIBAVUTIL_VERSION_INT constant.
7f0026dd
  */
 unsigned avutil_version(void);
558b86a5
 
c1736936
 /**
49bd8e4b
  * Return the libavutil build-time configuration.
c1736936
  */
41600690
 const char *avutil_configuration(void);
c1736936
 
 /**
49bd8e4b
  * Return the libavutil license.
c1736936
  */
41600690
 const char *avutil_license(void);
c1736936
 
757cd8d8
 /**
  * @}
  */
 
 /**
  * @addtogroup lavu_media Media Type
  * @brief Media Type
  */
 
11491503
 enum AVMediaType {
757cd8d8
     AVMEDIA_TYPE_UNKNOWN = -1,  ///< Usually treated as AVMEDIA_TYPE_DATA
11491503
     AVMEDIA_TYPE_VIDEO,
     AVMEDIA_TYPE_AUDIO,
757cd8d8
     AVMEDIA_TYPE_DATA,          ///< Opaque data information usually continuous
11491503
     AVMEDIA_TYPE_SUBTITLE,
757cd8d8
     AVMEDIA_TYPE_ATTACHMENT,    ///< Opaque data information usually sparse
11491503
     AVMEDIA_TYPE_NB
 };
 
69e2c1a9
 /**
  * Return a string describing the media_type enum, NULL if media_type
  * is unknown.
  */
 const char *av_get_media_type_string(enum AVMediaType media_type);
 
0b9a69f2
 /**
757cd8d8
  * @defgroup lavu_const Constants
  * @{
  *
  * @defgroup lavu_enc Encoding specific
  *
  * @note those definition should move to avcodec
  * @{
  */
 
6ed04040
 #define FF_LAMBDA_SHIFT 7
 #define FF_LAMBDA_SCALE (1<<FF_LAMBDA_SHIFT)
 #define FF_QP2LAMBDA 118 ///< factor to convert from H.263 QP to lambda
 #define FF_LAMBDA_MAX (256*128-1)
 
 #define FF_QUALITY_SCALE FF_LAMBDA_SCALE //FIXME maybe remove
 
757cd8d8
 /**
  * @}
  * @defgroup lavu_time Timestamp specific
  *
313d30c1
  * FFmpeg internal timebase and timestamp definitions
757cd8d8
  *
  * @{
  */
 
 /**
  * @brief Undefined timestamp value
  *
  * Usually reported by demuxer that work on containers that do not provide
  * either pts or dts.
  */
 
7ffe76e5
 #define AV_NOPTS_VALUE          INT64_C(0x8000000000000000)
757cd8d8
 
 /**
  * Internal time base represented as integer
  */
 
7ffe76e5
 #define AV_TIME_BASE            1000000
757cd8d8
 
 /**
  * Internal time base represented as fractional value
  */
 
7ffe76e5
 #define AV_TIME_BASE_Q          (AVRational){1, AV_TIME_BASE}
 
757cd8d8
 /**
  * @}
  * @}
  * @defgroup lavu_picture Image related
  *
  * AVPicture types, pixel formats and basic image planes manipulation.
  *
  * @{
  */
 
bebe72f4
 enum AVPictureType {
51293367
     AV_PICTURE_TYPE_NONE = 0, ///< Undefined
     AV_PICTURE_TYPE_I,     ///< Intra
bebe72f4
     AV_PICTURE_TYPE_P,     ///< Predicted
     AV_PICTURE_TYPE_B,     ///< Bi-dir predicted
     AV_PICTURE_TYPE_S,     ///< S(GMC)-VOP MPEG4
     AV_PICTURE_TYPE_SI,    ///< Switching Intra
     AV_PICTURE_TYPE_SP,    ///< Switching Predicted
     AV_PICTURE_TYPE_BI,    ///< BI type
 };
 
 /**
  * Return a single letter to describe the given picture type
  * pict_type.
  *
  * @param[in] pict_type the picture type @return a single character
  * representing the picture type, '?' if pict_type is unknown
  */
 char av_get_picture_type_char(enum AVPictureType pict_type);
 
a70e7874
 /**
757cd8d8
  * @}
  */
 
558b86a5
 #include "common.h"
60c144f7
 #include "error.h"
558b86a5
 #include "mathematics.h"
96676e1a
 #include "rational.h"
 #include "intfloat_readwrite.h"
 #include "log.h"
 #include "pixfmt.h"
558b86a5
 
757cd8d8
 /**
757cb3b4
  * Return x default pointer in case p is NULL.
  */
 static inline void *av_x_if_null(const void *p, const void *x)
 {
     return (void *)(intptr_t)(p ? p : x);
 }
 
 /**
757cd8d8
  * @}
  * @}
  */
 
98790382
 #endif /* AVUTIL_AVUTIL_H */