├── README.md
├── ffmpeg
├── bin
│ ├── avcodec-55.dll
│ ├── avdevice-55.dll
│ ├── avformat-55.dll
│ ├── avutil-52.dll
│ └── swscale-2.dll
├── include
│ ├── inttypes.h
│ ├── libavcodec
│ │ ├── avcodec.h
│ │ ├── avfft.h
│ │ ├── dxva2.h
│ │ ├── old_codec_ids.h
│ │ ├── vaapi.h
│ │ ├── vda.h
│ │ ├── vdpau.h
│ │ ├── version.h
│ │ └── xvmc.h
│ ├── libavdevice
│ │ ├── avdevice.h
│ │ └── version.h
│ ├── libavfilter
│ │ ├── asrc_abuffer.h
│ │ ├── avcodec.h
│ │ ├── avfilter.h
│ │ ├── avfiltergraph.h
│ │ ├── buffersink.h
│ │ ├── buffersrc.h
│ │ └── version.h
│ ├── libavformat
│ │ ├── avformat.h
│ │ ├── avio.h
│ │ └── version.h
│ ├── libavutil
│ │ ├── adler32.h
│ │ ├── aes.h
│ │ ├── attributes.h
│ │ ├── audio_fifo.h
│ │ ├── audioconvert.h
│ │ ├── avassert.h
│ │ ├── avconfig.h
│ │ ├── avstring.h
│ │ ├── avutil.h
│ │ ├── base64.h
│ │ ├── blowfish.h
│ │ ├── bprint.h
│ │ ├── bswap.h
│ │ ├── buffer.h
│ │ ├── channel_layout.h
│ │ ├── common.h
│ │ ├── cpu.h
│ │ ├── crc.h
│ │ ├── dict.h
│ │ ├── error.h
│ │ ├── eval.h
│ │ ├── fifo.h
│ │ ├── file.h
│ │ ├── frame.h
│ │ ├── hmac.h
│ │ ├── imgutils.h
│ │ ├── intfloat.h
│ │ ├── intfloat_readwrite.h
│ │ ├── intreadwrite.h
│ │ ├── lfg.h
│ │ ├── log.h
│ │ ├── lzo.h
│ │ ├── mathematics.h
│ │ ├── md5.h
│ │ ├── mem.h
│ │ ├── old_pix_fmts.h
│ │ ├── opt.h
│ │ ├── parseutils.h
│ │ ├── pixdesc.h
│ │ ├── pixfmt.h
│ │ ├── random_seed.h
│ │ ├── rational.h
│ │ ├── samplefmt.h
│ │ ├── sha.h
│ │ ├── time.h
│ │ ├── timecode.h
│ │ ├── timestamp.h
│ │ ├── version.h
│ │ └── xtea.h
│ ├── libpostproc
│ │ ├── postprocess.h
│ │ └── version.h
│ ├── libswresample
│ │ ├── swresample.h
│ │ └── version.h
│ ├── libswscale
│ │ ├── swscale.h
│ │ └── version.h
│ └── stdint.h
└── lib
│ ├── avcodec.lib
│ ├── avdevice.lib
│ ├── avformat.lib
│ ├── avutil.lib
│ └── swscale.lib
├── ffmpegDecoder.sln
└── ffmpegDecoder
├── ffmpegDecode.cpp
├── ffmpegDecode.h
├── ffmpegDecoder.vcproj
├── ffmpegInclude.h
├── main.cpp
├── stdafx.cpp
├── stdafx.h
├── stdint.h
└── targetver.h
/README.md:
--------------------------------------------------------------------------------
1 | # FFMpeg-decode-example
2 |
3 | Example how to use ffmpeg to decode video file. Link to article about [decode with FFMpeg](http://unick-soft.ru/article.php?id=14). [Russian article](http://unick-soft.ru/article.php?id=10).
4 |
5 | Example shows you the basic FFmpeg functions. Sample program opens video file and stores to a disk first 50 frames. You can change descriptions to setup program:
6 |
7 |
8 | #define FILE_NAME "C:\\temp\\test.avi"
9 | #define OUTPUT_FILE_PREFIX "c:\\temp\\image%d.bmp"
10 | #define FRAME_COUNT 50
11 |
12 |
--------------------------------------------------------------------------------
/ffmpeg/bin/avcodec-55.dll:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/bin/avcodec-55.dll
--------------------------------------------------------------------------------
/ffmpeg/bin/avdevice-55.dll:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/bin/avdevice-55.dll
--------------------------------------------------------------------------------
/ffmpeg/bin/avformat-55.dll:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/bin/avformat-55.dll
--------------------------------------------------------------------------------
/ffmpeg/bin/avutil-52.dll:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/bin/avutil-52.dll
--------------------------------------------------------------------------------
/ffmpeg/bin/swscale-2.dll:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/bin/swscale-2.dll
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/avfft.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVCODEC_AVFFT_H
20 | #define AVCODEC_AVFFT_H
21 |
22 | /**
23 | * @file
24 | * @ingroup lavc_fft
25 | * FFT functions
26 | */
27 |
28 | /**
29 | * @defgroup lavc_fft FFT functions
30 | * @ingroup lavc_misc
31 | *
32 | * @{
33 | */
34 |
35 | typedef float FFTSample;
36 |
37 | typedef struct FFTComplex {
38 | FFTSample re, im;
39 | } FFTComplex;
40 |
41 | typedef struct FFTContext FFTContext;
42 |
43 | /**
44 | * Set up a complex FFT.
45 | * @param nbits log2 of the length of the input array
46 | * @param inverse if 0 perform the forward transform, if 1 perform the inverse
47 | */
48 | FFTContext *av_fft_init(int nbits, int inverse);
49 |
50 | /**
51 | * Do the permutation needed BEFORE calling ff_fft_calc().
52 | */
53 | void av_fft_permute(FFTContext *s, FFTComplex *z);
54 |
55 | /**
56 | * Do a complex FFT with the parameters defined in av_fft_init(). The
57 | * input data must be permuted before. No 1.0/sqrt(n) normalization is done.
58 | */
59 | void av_fft_calc(FFTContext *s, FFTComplex *z);
60 |
61 | void av_fft_end(FFTContext *s);
62 |
63 | FFTContext *av_mdct_init(int nbits, int inverse, double scale);
64 | void av_imdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
65 | void av_imdct_half(FFTContext *s, FFTSample *output, const FFTSample *input);
66 | void av_mdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
67 | void av_mdct_end(FFTContext *s);
68 |
69 | /* Real Discrete Fourier Transform */
70 |
71 | enum RDFTransformType {
72 | DFT_R2C,
73 | IDFT_C2R,
74 | IDFT_R2C,
75 | DFT_C2R,
76 | };
77 |
78 | typedef struct RDFTContext RDFTContext;
79 |
80 | /**
81 | * Set up a real FFT.
82 | * @param nbits log2 of the length of the input array
83 | * @param trans the type of transform
84 | */
85 | RDFTContext *av_rdft_init(int nbits, enum RDFTransformType trans);
86 | void av_rdft_calc(RDFTContext *s, FFTSample *data);
87 | void av_rdft_end(RDFTContext *s);
88 |
89 | /* Discrete Cosine Transform */
90 |
91 | typedef struct DCTContext DCTContext;
92 |
93 | enum DCTTransformType {
94 | DCT_II = 0,
95 | DCT_III,
96 | DCT_I,
97 | DST_I,
98 | };
99 |
100 | /**
101 | * Set up DCT.
102 | * @param nbits size of the input array:
103 | * (1 << nbits) for DCT-II, DCT-III and DST-I
104 | * (1 << nbits) + 1 for DCT-I
105 | *
106 | * @note the first element of the input of DST-I is ignored
107 | */
108 | DCTContext *av_dct_init(int nbits, enum DCTTransformType type);
109 | void av_dct_calc(DCTContext *s, FFTSample *data);
110 | void av_dct_end (DCTContext *s);
111 |
112 | /**
113 | * @}
114 | */
115 |
116 | #endif /* AVCODEC_AVFFT_H */
117 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/dxva2.h:
--------------------------------------------------------------------------------
1 | /*
2 | * DXVA2 HW acceleration
3 | *
4 | * copyright (c) 2009 Laurent Aimar
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_DXVA_H
24 | #define AVCODEC_DXVA_H
25 |
26 | /**
27 | * @file
28 | * @ingroup lavc_codec_hwaccel_dxva2
29 | * Public libavcodec DXVA2 header.
30 | */
31 |
32 | #if defined(_WIN32_WINNT) && _WIN32_WINNT < 0x0600
33 | #undef _WIN32_WINNT
34 | #endif
35 |
36 | #if !defined(_WIN32_WINNT)
37 | #define _WIN32_WINNT 0x0600
38 | #endif
39 |
40 | #include
41 | #include
42 | #include
43 |
44 | /**
45 | * @defgroup lavc_codec_hwaccel_dxva2 DXVA2
46 | * @ingroup lavc_codec_hwaccel
47 | *
48 | * @{
49 | */
50 |
51 | #define FF_DXVA2_WORKAROUND_SCALING_LIST_ZIGZAG 1 ///< Work around for DXVA2 and old UVD/UVD+ ATI video cards
52 |
53 | /**
54 | * This structure is used to provides the necessary configurations and data
55 | * to the DXVA2 FFmpeg HWAccel implementation.
56 | *
57 | * The application must make it available as AVCodecContext.hwaccel_context.
58 | */
59 | struct dxva_context {
60 | /**
61 | * DXVA2 decoder object
62 | */
63 | IDirectXVideoDecoder *decoder;
64 |
65 | /**
66 | * DXVA2 configuration used to create the decoder
67 | */
68 | const DXVA2_ConfigPictureDecode *cfg;
69 |
70 | /**
71 | * The number of surface in the surface array
72 | */
73 | unsigned surface_count;
74 |
75 | /**
76 | * The array of Direct3D surfaces used to create the decoder
77 | */
78 | LPDIRECT3DSURFACE9 *surface;
79 |
80 | /**
81 | * A bit field configuring the workarounds needed for using the decoder
82 | */
83 | uint64_t workaround;
84 |
85 | /**
86 | * Private to the FFmpeg AVHWAccel implementation
87 | */
88 | unsigned report_id;
89 | };
90 |
91 | /**
92 | * @}
93 | */
94 |
95 | #endif /* AVCODEC_DXVA_H */
96 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/vaapi.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Video Acceleration API (shared data between FFmpeg and the video player)
3 | * HW decode acceleration for MPEG-2, MPEG-4, H.264 and VC-1
4 | *
5 | * Copyright (C) 2008-2009 Splitted-Desktop Systems
6 | *
7 | * This file is part of FFmpeg.
8 | *
9 | * FFmpeg is free software; you can redistribute it and/or
10 | * modify it under the terms of the GNU Lesser General Public
11 | * License as published by the Free Software Foundation; either
12 | * version 2.1 of the License, or (at your option) any later version.
13 | *
14 | * FFmpeg is distributed in the hope that it will be useful,
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 | * Lesser General Public License for more details.
18 | *
19 | * You should have received a copy of the GNU Lesser General Public
20 | * License along with FFmpeg; if not, write to the Free Software
21 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 | */
23 |
24 | #ifndef AVCODEC_VAAPI_H
25 | #define AVCODEC_VAAPI_H
26 |
27 | /**
28 | * @file
29 | * @ingroup lavc_codec_hwaccel_vaapi
30 | * Public libavcodec VA API header.
31 | */
32 |
33 | #include
34 |
35 | /**
36 | * @defgroup lavc_codec_hwaccel_vaapi VA API Decoding
37 | * @ingroup lavc_codec_hwaccel
38 | * @{
39 | */
40 |
41 | /**
42 | * This structure is used to share data between the FFmpeg library and
43 | * the client video application.
44 | * This shall be zero-allocated and available as
45 | * AVCodecContext.hwaccel_context. All user members can be set once
46 | * during initialization or through each AVCodecContext.get_buffer()
47 | * function call. In any case, they must be valid prior to calling
48 | * decoding functions.
49 | */
50 | struct vaapi_context {
51 | /**
52 | * Window system dependent data
53 | *
54 | * - encoding: unused
55 | * - decoding: Set by user
56 | */
57 | void *display;
58 |
59 | /**
60 | * Configuration ID
61 | *
62 | * - encoding: unused
63 | * - decoding: Set by user
64 | */
65 | uint32_t config_id;
66 |
67 | /**
68 | * Context ID (video decode pipeline)
69 | *
70 | * - encoding: unused
71 | * - decoding: Set by user
72 | */
73 | uint32_t context_id;
74 |
75 | /**
76 | * VAPictureParameterBuffer ID
77 | *
78 | * - encoding: unused
79 | * - decoding: Set by libavcodec
80 | */
81 | uint32_t pic_param_buf_id;
82 |
83 | /**
84 | * VAIQMatrixBuffer ID
85 | *
86 | * - encoding: unused
87 | * - decoding: Set by libavcodec
88 | */
89 | uint32_t iq_matrix_buf_id;
90 |
91 | /**
92 | * VABitPlaneBuffer ID (for VC-1 decoding)
93 | *
94 | * - encoding: unused
95 | * - decoding: Set by libavcodec
96 | */
97 | uint32_t bitplane_buf_id;
98 |
99 | /**
100 | * Slice parameter/data buffer IDs
101 | *
102 | * - encoding: unused
103 | * - decoding: Set by libavcodec
104 | */
105 | uint32_t *slice_buf_ids;
106 |
107 | /**
108 | * Number of effective slice buffer IDs to send to the HW
109 | *
110 | * - encoding: unused
111 | * - decoding: Set by libavcodec
112 | */
113 | unsigned int n_slice_buf_ids;
114 |
115 | /**
116 | * Size of pre-allocated slice_buf_ids
117 | *
118 | * - encoding: unused
119 | * - decoding: Set by libavcodec
120 | */
121 | unsigned int slice_buf_ids_alloc;
122 |
123 | /**
124 | * Pointer to VASliceParameterBuffers
125 | *
126 | * - encoding: unused
127 | * - decoding: Set by libavcodec
128 | */
129 | void *slice_params;
130 |
131 | /**
132 | * Size of a VASliceParameterBuffer element
133 | *
134 | * - encoding: unused
135 | * - decoding: Set by libavcodec
136 | */
137 | unsigned int slice_param_size;
138 |
139 | /**
140 | * Size of pre-allocated slice_params
141 | *
142 | * - encoding: unused
143 | * - decoding: Set by libavcodec
144 | */
145 | unsigned int slice_params_alloc;
146 |
147 | /**
148 | * Number of slices currently filled in
149 | *
150 | * - encoding: unused
151 | * - decoding: Set by libavcodec
152 | */
153 | unsigned int slice_count;
154 |
155 | /**
156 | * Pointer to slice data buffer base
157 | * - encoding: unused
158 | * - decoding: Set by libavcodec
159 | */
160 | const uint8_t *slice_data;
161 |
162 | /**
163 | * Current size of slice data
164 | *
165 | * - encoding: unused
166 | * - decoding: Set by libavcodec
167 | */
168 | uint32_t slice_data_size;
169 | };
170 |
171 | /* @} */
172 |
173 | #endif /* AVCODEC_VAAPI_H */
174 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/vda.h:
--------------------------------------------------------------------------------
1 | /*
2 | * VDA HW acceleration
3 | *
4 | * copyright (c) 2011 Sebastien Zwickert
5 | *
6 | * This file is part of FFmpeg.
7 | *
8 | * FFmpeg is free software; you can redistribute it and/or
9 | * modify it under the terms of the GNU Lesser General Public
10 | * License as published by the Free Software Foundation; either
11 | * version 2.1 of the License, or (at your option) any later version.
12 | *
13 | * FFmpeg is distributed in the hope that it will be useful,
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 | * Lesser General Public License for more details.
17 | *
18 | * You should have received a copy of the GNU Lesser General Public
19 | * License along with FFmpeg; if not, write to the Free Software
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 | */
22 |
23 | #ifndef AVCODEC_VDA_H
24 | #define AVCODEC_VDA_H
25 |
26 | /**
27 | * @file
28 | * @ingroup lavc_codec_hwaccel_vda
29 | * Public libavcodec VDA header.
30 | */
31 |
32 | #include
33 |
34 | // emmintrin.h is unable to compile with -std=c99 -Werror=missing-prototypes
35 | // http://openradar.appspot.com/8026390
36 | #undef __GNUC_STDC_INLINE__
37 |
38 | #define Picture QuickdrawPicture
39 | #include
40 | #undef Picture
41 |
42 | #include "libavcodec/version.h"
43 |
44 | /**
45 | * @defgroup lavc_codec_hwaccel_vda VDA
46 | * @ingroup lavc_codec_hwaccel
47 | *
48 | * @{
49 | */
50 |
51 | /**
52 | * This structure is used to provide the necessary configurations and data
53 | * to the VDA FFmpeg HWAccel implementation.
54 | *
55 | * The application must make it available as AVCodecContext.hwaccel_context.
56 | */
57 | struct vda_context {
58 | /**
59 | * VDA decoder object.
60 | *
61 | * - encoding: unused
62 | * - decoding: Set/Unset by libavcodec.
63 | */
64 | VDADecoder decoder;
65 |
66 | /**
67 | * The Core Video pixel buffer that contains the current image data.
68 | *
69 | * encoding: unused
70 | * decoding: Set by libavcodec. Unset by user.
71 | */
72 | CVPixelBufferRef cv_buffer;
73 |
74 | /**
75 | * Use the hardware decoder in synchronous mode.
76 | *
77 | * encoding: unused
78 | * decoding: Set by user.
79 | */
80 | int use_sync_decoding;
81 |
82 | /**
83 | * The frame width.
84 | *
85 | * - encoding: unused
86 | * - decoding: Set/Unset by user.
87 | */
88 | int width;
89 |
90 | /**
91 | * The frame height.
92 | *
93 | * - encoding: unused
94 | * - decoding: Set/Unset by user.
95 | */
96 | int height;
97 |
98 | /**
99 | * The frame format.
100 | *
101 | * - encoding: unused
102 | * - decoding: Set/Unset by user.
103 | */
104 | int format;
105 |
106 | /**
107 | * The pixel format for output image buffers.
108 | *
109 | * - encoding: unused
110 | * - decoding: Set/Unset by user.
111 | */
112 | OSType cv_pix_fmt_type;
113 |
114 | /**
115 | * The current bitstream buffer.
116 | *
117 | * - encoding: unused
118 | * - decoding: Set/Unset by libavcodec.
119 | */
120 | uint8_t *priv_bitstream;
121 |
122 | /**
123 | * The current size of the bitstream.
124 | *
125 | * - encoding: unused
126 | * - decoding: Set/Unset by libavcodec.
127 | */
128 | int priv_bitstream_size;
129 |
130 | /**
131 | * The reference size used for fast reallocation.
132 | *
133 | * - encoding: unused
134 | * - decoding: Set/Unset by libavcodec.
135 | */
136 | int priv_allocated_size;
137 | };
138 |
139 | /** Create the video decoder. */
140 | int ff_vda_create_decoder(struct vda_context *vda_ctx,
141 | uint8_t *extradata,
142 | int extradata_size);
143 |
144 | /** Destroy the video decoder. */
145 | int ff_vda_destroy_decoder(struct vda_context *vda_ctx);
146 |
147 | /**
148 | * @}
149 | */
150 |
151 | #endif /* AVCODEC_VDA_H */
152 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/vdpau.h:
--------------------------------------------------------------------------------
1 | /*
2 | * The Video Decode and Presentation API for UNIX (VDPAU) is used for
3 | * hardware-accelerated decoding of MPEG-1/2, H.264 and VC-1.
4 | *
5 | * Copyright (C) 2008 NVIDIA
6 | *
7 | * This file is part of FFmpeg.
8 | *
9 | * FFmpeg is free software; you can redistribute it and/or
10 | * modify it under the terms of the GNU Lesser General Public
11 | * License as published by the Free Software Foundation; either
12 | * version 2.1 of the License, or (at your option) any later version.
13 | *
14 | * FFmpeg is distributed in the hope that it will be useful,
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 | * Lesser General Public License for more details.
18 | *
19 | * You should have received a copy of the GNU Lesser General Public
20 | * License along with FFmpeg; if not, write to the Free Software
21 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 | */
23 |
24 | #ifndef AVCODEC_VDPAU_H
25 | #define AVCODEC_VDPAU_H
26 |
27 | /**
28 | * @file
29 | * @ingroup lavc_codec_hwaccel_vdpau
30 | * Public libavcodec VDPAU header.
31 | */
32 |
33 |
34 | /**
35 | * @defgroup lavc_codec_hwaccel_vdpau VDPAU Decoder and Renderer
36 | * @ingroup lavc_codec_hwaccel
37 | *
38 | * VDPAU hardware acceleration has two modules
39 | * - VDPAU decoding
40 | * - VDPAU presentation
41 | *
42 | * The VDPAU decoding module parses all headers using FFmpeg
43 | * parsing mechanisms and uses VDPAU for the actual decoding.
44 | *
45 | * As per the current implementation, the actual decoding
46 | * and rendering (API calls) are done as part of the VDPAU
47 | * presentation (vo_vdpau.c) module.
48 | *
49 | * @{
50 | */
51 |
52 | #include
53 | #include
54 | #include "libavutil/avconfig.h"
55 |
56 | union FFVdpPictureInfo {
57 | VdpPictureInfoH264 h264;
58 | VdpPictureInfoMPEG1Or2 mpeg;
59 | VdpPictureInfoVC1 vc1;
60 | VdpPictureInfoMPEG4Part2 mpeg4;
61 | };
62 |
63 | /**
64 | * This structure is used to share data between the libavcodec library and
65 | * the client video application.
66 | * The user shall zero-allocate the structure and make it available as
67 | * AVCodecContext.hwaccel_context. Members can be set by the user once
68 | * during initialization or through each AVCodecContext.get_buffer()
69 | * function call. In any case, they must be valid prior to calling
70 | * decoding functions.
71 | */
72 | typedef struct AVVDPAUContext {
73 | /**
74 | * VDPAU decoder handle
75 | *
76 | * Set by user.
77 | */
78 | VdpDecoder decoder;
79 |
80 | /**
81 | * VDPAU decoder render callback
82 | *
83 | * Set by the user.
84 | */
85 | VdpDecoderRender *render;
86 |
87 | /**
88 | * VDPAU picture information
89 | *
90 | * Set by libavcodec.
91 | */
92 | union FFVdpPictureInfo info;
93 |
94 | /**
95 | * Allocated size of the bitstream_buffers table.
96 | *
97 | * Set by libavcodec.
98 | */
99 | int bitstream_buffers_allocated;
100 |
101 | /**
102 | * Useful bitstream buffers in the bitstream buffers table.
103 | *
104 | * Set by libavcodec.
105 | */
106 | int bitstream_buffers_used;
107 |
108 | /**
109 | * Table of bitstream buffers.
110 | * The user is responsible for freeing this buffer using av_freep().
111 | *
112 | * Set by libavcodec.
113 | */
114 | VdpBitstreamBuffer *bitstream_buffers;
115 | } AVVDPAUContext;
116 |
117 |
118 | /** @brief The videoSurface is used for rendering. */
119 | #define FF_VDPAU_STATE_USED_FOR_RENDER 1
120 |
121 | /**
122 | * @brief The videoSurface is needed for reference/prediction.
123 | * The codec manipulates this.
124 | */
125 | #define FF_VDPAU_STATE_USED_FOR_REFERENCE 2
126 |
127 | /**
128 | * @brief This structure is used as a callback between the FFmpeg
129 | * decoder (vd_) and presentation (vo_) module.
130 | * This is used for defining a video frame containing surface,
131 | * picture parameter, bitstream information etc which are passed
132 | * between the FFmpeg decoder and its clients.
133 | */
134 | struct vdpau_render_state {
135 | VdpVideoSurface surface; ///< Used as rendered surface, never changed.
136 |
137 | int state; ///< Holds FF_VDPAU_STATE_* values.
138 |
139 | #if AV_HAVE_INCOMPATIBLE_FORK_ABI
140 | /** picture parameter information for all supported codecs */
141 | union FFVdpPictureInfo info;
142 | #endif
143 |
144 | /** Describe size/location of the compressed video data.
145 | Set to 0 when freeing bitstream_buffers. */
146 | int bitstream_buffers_allocated;
147 | int bitstream_buffers_used;
148 | /** The user is responsible for freeing this buffer using av_freep(). */
149 | VdpBitstreamBuffer *bitstream_buffers;
150 |
151 | #if !AV_HAVE_INCOMPATIBLE_FORK_ABI
152 | /** picture parameter information for all supported codecs */
153 | union FFVdpPictureInfo info;
154 | #endif
155 | };
156 |
157 | /* @}*/
158 |
159 | #endif /* AVCODEC_VDPAU_H */
160 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | *
3 | * This file is part of FFmpeg.
4 | *
5 | * FFmpeg is free software; you can redistribute it and/or
6 | * modify it under the terms of the GNU Lesser General Public
7 | * License as published by the Free Software Foundation; either
8 | * version 2.1 of the License, or (at your option) any later version.
9 | *
10 | * FFmpeg is distributed in the hope that it will be useful,
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 | * Lesser General Public License for more details.
14 | *
15 | * You should have received a copy of the GNU Lesser General Public
16 | * License along with FFmpeg; if not, write to the Free Software
17 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18 | */
19 |
20 | #ifndef AVCODEC_VERSION_H
21 | #define AVCODEC_VERSION_H
22 |
23 | /**
24 | * @file
25 | * @ingroup libavc
26 | * Libavcodec version macros.
27 | */
28 |
29 | #include "libavutil/avutil.h"
30 |
31 | #define LIBAVCODEC_VERSION_MAJOR 55
32 | #define LIBAVCODEC_VERSION_MINOR 2
33 | #define LIBAVCODEC_VERSION_MICRO 100
34 |
35 | #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
36 | LIBAVCODEC_VERSION_MINOR, \
37 | LIBAVCODEC_VERSION_MICRO)
38 | #define LIBAVCODEC_VERSION AV_VERSION(LIBAVCODEC_VERSION_MAJOR, \
39 | LIBAVCODEC_VERSION_MINOR, \
40 | LIBAVCODEC_VERSION_MICRO)
41 | #define LIBAVCODEC_BUILD LIBAVCODEC_VERSION_INT
42 |
43 | #define LIBAVCODEC_IDENT "Lavc" AV_STRINGIFY(LIBAVCODEC_VERSION)
44 |
45 | /**
46 | * FF_API_* defines may be placed below to indicate public API that will be
47 | * dropped at a future version bump. The defines themselves are not part of
48 | * the public API and may change, break or disappear at any time.
49 | */
50 |
51 | #ifndef FF_API_REQUEST_CHANNELS
52 | #define FF_API_REQUEST_CHANNELS (LIBAVCODEC_VERSION_MAJOR < 56)
53 | #endif
54 | #ifndef FF_API_ALLOC_CONTEXT
55 | #define FF_API_ALLOC_CONTEXT (LIBAVCODEC_VERSION_MAJOR < 55)
56 | #endif
57 | #ifndef FF_API_AVCODEC_OPEN
58 | #define FF_API_AVCODEC_OPEN (LIBAVCODEC_VERSION_MAJOR < 55)
59 | #endif
60 | #ifndef FF_API_OLD_DECODE_AUDIO
61 | #define FF_API_OLD_DECODE_AUDIO (LIBAVCODEC_VERSION_MAJOR < 56)
62 | #endif
63 | #ifndef FF_API_OLD_TIMECODE
64 | #define FF_API_OLD_TIMECODE (LIBAVCODEC_VERSION_MAJOR < 55)
65 | #endif
66 |
67 | #ifndef FF_API_OLD_ENCODE_AUDIO
68 | #define FF_API_OLD_ENCODE_AUDIO (LIBAVCODEC_VERSION_MAJOR < 56)
69 | #endif
70 | #ifndef FF_API_OLD_ENCODE_VIDEO
71 | #define FF_API_OLD_ENCODE_VIDEO (LIBAVCODEC_VERSION_MAJOR < 56)
72 | #endif
73 | #ifndef FF_API_CODEC_ID
74 | #define FF_API_CODEC_ID (LIBAVCODEC_VERSION_MAJOR < 56)
75 | #endif
76 | #ifndef FF_API_AVCODEC_RESAMPLE
77 | #define FF_API_AVCODEC_RESAMPLE (LIBAVCODEC_VERSION_MAJOR < 56)
78 | #endif
79 | #ifndef FF_API_DEINTERLACE
80 | #define FF_API_DEINTERLACE (LIBAVCODEC_VERSION_MAJOR < 56)
81 | #endif
82 | #ifndef FF_API_DESTRUCT_PACKET
83 | #define FF_API_DESTRUCT_PACKET (LIBAVCODEC_VERSION_MAJOR < 56)
84 | #endif
85 | #ifndef FF_API_GET_BUFFER
86 | #define FF_API_GET_BUFFER (LIBAVCODEC_VERSION_MAJOR < 56)
87 | #endif
88 | #ifndef FF_API_MISSING_SAMPLE
89 | #define FF_API_MISSING_SAMPLE (LIBAVCODEC_VERSION_MAJOR < 56)
90 | #endif
91 |
92 | #endif /* AVCODEC_VERSION_H */
93 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavcodec/xvmc.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2003 Ivan Kalvachev
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVCODEC_XVMC_H
22 | #define AVCODEC_XVMC_H
23 |
24 | /**
25 | * @file
26 | * @ingroup lavc_codec_hwaccel_xvmc
27 | * Public libavcodec XvMC header.
28 | */
29 |
30 | #include
31 |
32 | #include "avcodec.h"
33 |
34 | /**
35 | * @defgroup lavc_codec_hwaccel_xvmc XvMC
36 | * @ingroup lavc_codec_hwaccel
37 | *
38 | * @{
39 | */
40 |
41 | #define AV_XVMC_ID 0x1DC711C0 /**< special value to ensure that regular pixel routines haven't corrupted the struct
42 | the number is 1337 speak for the letters IDCT MCo (motion compensation) */
43 |
44 | struct xvmc_pix_fmt {
45 | /** The field contains the special constant value AV_XVMC_ID.
46 | It is used as a test that the application correctly uses the API,
47 | and that there is no corruption caused by pixel routines.
48 | - application - set during initialization
49 | - libavcodec - unchanged
50 | */
51 | int xvmc_id;
52 |
53 | /** Pointer to the block array allocated by XvMCCreateBlocks().
54 | The array has to be freed by XvMCDestroyBlocks().
55 | Each group of 64 values represents one data block of differential
56 | pixel information (in MoCo mode) or coefficients for IDCT.
57 | - application - set the pointer during initialization
58 | - libavcodec - fills coefficients/pixel data into the array
59 | */
60 | short* data_blocks;
61 |
62 | /** Pointer to the macroblock description array allocated by
63 | XvMCCreateMacroBlocks() and freed by XvMCDestroyMacroBlocks().
64 | - application - set the pointer during initialization
65 | - libavcodec - fills description data into the array
66 | */
67 | XvMCMacroBlock* mv_blocks;
68 |
69 | /** Number of macroblock descriptions that can be stored in the mv_blocks
70 | array.
71 | - application - set during initialization
72 | - libavcodec - unchanged
73 | */
74 | int allocated_mv_blocks;
75 |
76 | /** Number of blocks that can be stored at once in the data_blocks array.
77 | - application - set during initialization
78 | - libavcodec - unchanged
79 | */
80 | int allocated_data_blocks;
81 |
82 | /** Indicate that the hardware would interpret data_blocks as IDCT
83 | coefficients and perform IDCT on them.
84 | - application - set during initialization
85 | - libavcodec - unchanged
86 | */
87 | int idct;
88 |
89 | /** In MoCo mode it indicates that intra macroblocks are assumed to be in
90 | unsigned format; same as the XVMC_INTRA_UNSIGNED flag.
91 | - application - set during initialization
92 | - libavcodec - unchanged
93 | */
94 | int unsigned_intra;
95 |
96 | /** Pointer to the surface allocated by XvMCCreateSurface().
97 | It has to be freed by XvMCDestroySurface() on application exit.
98 | It identifies the frame and its state on the video hardware.
99 | - application - set during initialization
100 | - libavcodec - unchanged
101 | */
102 | XvMCSurface* p_surface;
103 |
104 | /** Set by the decoder before calling ff_draw_horiz_band(),
105 | needed by the XvMCRenderSurface function. */
106 | //@{
107 | /** Pointer to the surface used as past reference
108 | - application - unchanged
109 | - libavcodec - set
110 | */
111 | XvMCSurface* p_past_surface;
112 |
113 | /** Pointer to the surface used as future reference
114 | - application - unchanged
115 | - libavcodec - set
116 | */
117 | XvMCSurface* p_future_surface;
118 |
119 | /** top/bottom field or frame
120 | - application - unchanged
121 | - libavcodec - set
122 | */
123 | unsigned int picture_structure;
124 |
125 | /** XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
126 | - application - unchanged
127 | - libavcodec - set
128 | */
129 | unsigned int flags;
130 | //}@
131 |
132 | /** Number of macroblock descriptions in the mv_blocks array
133 | that have already been passed to the hardware.
134 | - application - zeroes it on get_buffer().
135 | A successful ff_draw_horiz_band() may increment it
136 | with filled_mb_block_num or zero both.
137 | - libavcodec - unchanged
138 | */
139 | int start_mv_blocks_num;
140 |
141 | /** Number of new macroblock descriptions in the mv_blocks array (after
142 | start_mv_blocks_num) that are filled by libavcodec and have to be
143 | passed to the hardware.
144 | - application - zeroes it on get_buffer() or after successful
145 | ff_draw_horiz_band().
146 | - libavcodec - increment with one of each stored MB
147 | */
148 | int filled_mv_blocks_num;
149 |
150 | /** Number of the next free data block; one data block consists of
151 | 64 short values in the data_blocks array.
152 | All blocks before this one have already been claimed by placing their
153 | position into the corresponding block description structure field,
154 | that are part of the mv_blocks array.
155 | - application - zeroes it on get_buffer().
156 | A successful ff_draw_horiz_band() may zero it together
157 | with start_mb_blocks_num.
158 | - libavcodec - each decoded macroblock increases it by the number
159 | of coded blocks it contains.
160 | */
161 | int next_free_data_block_num;
162 | };
163 |
164 | /**
165 | * @}
166 | */
167 |
168 | #endif /* AVCODEC_XVMC_H */
169 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavdevice/avdevice.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVDEVICE_AVDEVICE_H
20 | #define AVDEVICE_AVDEVICE_H
21 |
22 | #include "version.h"
23 |
24 | /**
25 | * @file
26 | * @ingroup lavd
27 | * Main libavdevice API header
28 | */
29 |
30 | /**
31 | * @defgroup lavd Special devices muxing/demuxing library
32 | * @{
33 | * Libavdevice is a complementary library to @ref libavf "libavformat". It
34 | * provides various "special" platform-specific muxers and demuxers, e.g. for
35 | * grabbing devices, audio capture and playback etc. As a consequence, the
36 | * (de)muxers in libavdevice are of the AVFMT_NOFILE type (they use their own
37 | * I/O functions). The filename passed to avformat_open_input() often does not
38 | * refer to an actually existing file, but has some special device-specific
39 | * meaning - e.g. for x11grab it is the display name.
40 | *
41 | * To use libavdevice, simply call avdevice_register_all() to register all
42 | * compiled muxers and demuxers. They all use standard libavformat API.
43 | * @}
44 | */
45 |
46 | #include "libavformat/avformat.h"
47 |
48 | /**
49 | * Return the LIBAVDEVICE_VERSION_INT constant.
50 | */
51 | unsigned avdevice_version(void);
52 |
53 | /**
54 | * Return the libavdevice build-time configuration.
55 | */
56 | const char *avdevice_configuration(void);
57 |
58 | /**
59 | * Return the libavdevice license.
60 | */
61 | const char *avdevice_license(void);
62 |
63 | /**
64 | * Initialize libavdevice and register all the input and output devices.
65 | * @warning This function is not thread safe.
66 | */
67 | void avdevice_register_all(void);
68 |
69 | #endif /* AVDEVICE_AVDEVICE_H */
70 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavdevice/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVDEVICE_VERSION_H
20 | #define AVDEVICE_VERSION_H
21 |
22 | /**
23 | * @file
24 | * @ingroup lavd
25 | * Libavdevice version macros
26 | */
27 |
28 | #include "libavutil/avutil.h"
29 |
30 | #define LIBAVDEVICE_VERSION_MAJOR 55
31 | #define LIBAVDEVICE_VERSION_MINOR 0
32 | #define LIBAVDEVICE_VERSION_MICRO 100
33 |
34 | #define LIBAVDEVICE_VERSION_INT AV_VERSION_INT(LIBAVDEVICE_VERSION_MAJOR, \
35 | LIBAVDEVICE_VERSION_MINOR, \
36 | LIBAVDEVICE_VERSION_MICRO)
37 | #define LIBAVDEVICE_VERSION AV_VERSION(LIBAVDEVICE_VERSION_MAJOR, \
38 | LIBAVDEVICE_VERSION_MINOR, \
39 | LIBAVDEVICE_VERSION_MICRO)
40 | #define LIBAVDEVICE_BUILD LIBAVDEVICE_VERSION_INT
41 |
42 | #define LIBAVDEVICE_IDENT "Lavd" AV_STRINGIFY(LIBAVDEVICE_VERSION)
43 |
44 | /**
45 | * FF_API_* defines may be placed below to indicate public API that will be
46 | * dropped at a future version bump. The defines themselves are not part of
47 | * the public API and may change, break or disappear at any time.
48 | */
49 |
50 | #endif /* AVDEVICE_VERSION_H */
51 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavfilter/asrc_abuffer.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVFILTER_ASRC_ABUFFER_H
20 | #define AVFILTER_ASRC_ABUFFER_H
21 |
22 | #include "avfilter.h"
23 |
24 | /**
25 | * @file
26 | * memory buffer source for audio
27 | *
28 | * @deprecated use buffersrc.h instead.
29 | */
30 |
31 | /**
32 | * Queue an audio buffer to the audio buffer source.
33 | *
34 | * @param abuffersrc audio source buffer context
35 | * @param data pointers to the samples planes
36 | * @param linesize linesizes of each audio buffer plane
37 | * @param nb_samples number of samples per channel
38 | * @param sample_fmt sample format of the audio data
39 | * @param ch_layout channel layout of the audio data
40 | * @param planar flag to indicate if audio data is planar or packed
41 | * @param pts presentation timestamp of the audio buffer
42 | * @param flags unused
43 | *
44 | * @deprecated use av_buffersrc_add_ref() instead.
45 | */
46 | attribute_deprecated
47 | int av_asrc_buffer_add_samples(AVFilterContext *abuffersrc,
48 | uint8_t *data[8], int linesize[8],
49 | int nb_samples, int sample_rate,
50 | int sample_fmt, int64_t ch_layout, int planar,
51 | int64_t pts, int av_unused flags);
52 |
53 | /**
54 | * Queue an audio buffer to the audio buffer source.
55 | *
56 | * This is similar to av_asrc_buffer_add_samples(), but the samples
57 | * are stored in a buffer with known size.
58 | *
59 | * @param abuffersrc audio source buffer context
60 | * @param buf pointer to the samples data, packed is assumed
61 | * @param size the size in bytes of the buffer, it must contain an
62 | * integer number of samples
63 | * @param sample_fmt sample format of the audio data
64 | * @param ch_layout channel layout of the audio data
65 | * @param pts presentation timestamp of the audio buffer
66 | * @param flags unused
67 | *
68 | * @deprecated use av_buffersrc_add_ref() instead.
69 | */
70 | attribute_deprecated
71 | int av_asrc_buffer_add_buffer(AVFilterContext *abuffersrc,
72 | uint8_t *buf, int buf_size,
73 | int sample_rate,
74 | int sample_fmt, int64_t ch_layout, int planar,
75 | int64_t pts, int av_unused flags);
76 |
77 | /**
78 | * Queue an audio buffer to the audio buffer source.
79 | *
80 | * @param abuffersrc audio source buffer context
81 | * @param samplesref buffer ref to queue
82 | * @param flags unused
83 | *
84 | * @deprecated use av_buffersrc_add_ref() instead.
85 | */
86 | attribute_deprecated
87 | int av_asrc_buffer_add_audio_buffer_ref(AVFilterContext *abuffersrc,
88 | AVFilterBufferRef *samplesref,
89 | int av_unused flags);
90 |
91 | #endif /* AVFILTER_ASRC_ABUFFER_H */
92 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavfilter/avcodec.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVFILTER_AVCODEC_H
20 | #define AVFILTER_AVCODEC_H
21 |
22 | /**
23 | * @file
24 | * libavcodec/libavfilter gluing utilities
25 | *
26 | * This should be included in an application ONLY if the installed
27 | * libavfilter has been compiled with libavcodec support, otherwise
28 | * symbols defined below will not be available.
29 | */
30 |
31 | #include "avfilter.h"
32 |
33 | #if FF_API_AVFILTERBUFFER
34 | /**
35 | * Create and return a picref reference from the data and properties
36 | * contained in frame.
37 | *
38 | * @param perms permissions to assign to the new buffer reference
39 | * @deprecated avfilter APIs work natively with AVFrame instead.
40 | */
41 | attribute_deprecated
42 | AVFilterBufferRef *avfilter_get_video_buffer_ref_from_frame(const AVFrame *frame, int perms);
43 |
44 |
45 | /**
46 | * Create and return a picref reference from the data and properties
47 | * contained in frame.
48 | *
49 | * @param perms permissions to assign to the new buffer reference
50 | * @deprecated avfilter APIs work natively with AVFrame instead.
51 | */
52 | attribute_deprecated
53 | AVFilterBufferRef *avfilter_get_audio_buffer_ref_from_frame(const AVFrame *frame,
54 | int perms);
55 |
56 | /**
57 | * Create and return a buffer reference from the data and properties
58 | * contained in frame.
59 | *
60 | * @param perms permissions to assign to the new buffer reference
61 | * @deprecated avfilter APIs work natively with AVFrame instead.
62 | */
63 | attribute_deprecated
64 | AVFilterBufferRef *avfilter_get_buffer_ref_from_frame(enum AVMediaType type,
65 | const AVFrame *frame,
66 | int perms);
67 | #endif
68 |
69 | #if FF_API_FILL_FRAME
70 | /**
71 | * Fill an AVFrame with the information stored in samplesref.
72 | *
73 | * @param frame an already allocated AVFrame
74 | * @param samplesref an audio buffer reference
75 | * @return 0 in case of success, a negative AVERROR code in case of
76 | * failure
77 | * @deprecated Use avfilter_copy_buf_props() instead.
78 | */
79 | attribute_deprecated
80 | int avfilter_fill_frame_from_audio_buffer_ref(AVFrame *frame,
81 | const AVFilterBufferRef *samplesref);
82 |
83 | /**
84 | * Fill an AVFrame with the information stored in picref.
85 | *
86 | * @param frame an already allocated AVFrame
87 | * @param picref a video buffer reference
88 | * @return 0 in case of success, a negative AVERROR code in case of
89 | * failure
90 | * @deprecated Use avfilter_copy_buf_props() instead.
91 | */
92 | attribute_deprecated
93 | int avfilter_fill_frame_from_video_buffer_ref(AVFrame *frame,
94 | const AVFilterBufferRef *picref);
95 |
96 | /**
97 | * Fill an AVFrame with information stored in ref.
98 | *
99 | * @param frame an already allocated AVFrame
100 | * @param ref a video or audio buffer reference
101 | * @return 0 in case of success, a negative AVERROR code in case of
102 | * failure
103 | * @deprecated Use avfilter_copy_buf_props() instead.
104 | */
105 | attribute_deprecated
106 | int avfilter_fill_frame_from_buffer_ref(AVFrame *frame,
107 | const AVFilterBufferRef *ref);
108 | #endif
109 |
110 | #endif /* AVFILTER_AVCODEC_H */
111 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavfilter/buffersink.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVFILTER_BUFFERSINK_H
20 | #define AVFILTER_BUFFERSINK_H
21 |
22 | /**
23 | * @file
24 | * memory buffer sink API for audio and video
25 | */
26 |
27 | #include "avfilter.h"
28 |
29 | #if FF_API_AVFILTERBUFFER
30 | /**
31 | * Get an audio/video buffer data from buffer_sink and put it in bufref.
32 | *
33 | * This function works with both audio and video buffer sinks.
34 | *
35 | * @param buffer_sink pointer to a buffersink or abuffersink context
36 | * @param flags a combination of AV_BUFFERSINK_FLAG_* flags
37 | * @return >= 0 in case of success, a negative AVERROR code in case of
38 | * failure
39 | */
40 | attribute_deprecated
41 | int av_buffersink_get_buffer_ref(AVFilterContext *buffer_sink,
42 | AVFilterBufferRef **bufref, int flags);
43 |
44 | /**
45 | * Get the number of immediately available frames.
46 | */
47 | attribute_deprecated
48 | int av_buffersink_poll_frame(AVFilterContext *ctx);
49 |
50 | /**
51 | * Get a buffer with filtered data from sink and put it in buf.
52 | *
53 | * @param ctx pointer to a context of a buffersink or abuffersink AVFilter.
54 | * @param buf pointer to the buffer will be written here if buf is non-NULL. buf
55 | * must be freed by the caller using avfilter_unref_buffer().
56 | * Buf may also be NULL to query whether a buffer is ready to be
57 | * output.
58 | *
59 | * @return >= 0 in case of success, a negative AVERROR code in case of
60 | * failure.
61 | */
62 | attribute_deprecated
63 | int av_buffersink_read(AVFilterContext *ctx, AVFilterBufferRef **buf);
64 |
65 | /**
66 | * Same as av_buffersink_read, but with the ability to specify the number of
67 | * samples read. This function is less efficient than av_buffersink_read(),
68 | * because it copies the data around.
69 | *
70 | * @param ctx pointer to a context of the abuffersink AVFilter.
71 | * @param buf pointer to the buffer will be written here if buf is non-NULL. buf
72 | * must be freed by the caller using avfilter_unref_buffer(). buf
73 | * will contain exactly nb_samples audio samples, except at the end
74 | * of stream, when it can contain less than nb_samples.
75 | * Buf may also be NULL to query whether a buffer is ready to be
76 | * output.
77 | *
78 | * @warning do not mix this function with av_buffersink_read(). Use only one or
79 | * the other with a single sink, not both.
80 | */
81 | attribute_deprecated
82 | int av_buffersink_read_samples(AVFilterContext *ctx, AVFilterBufferRef **buf,
83 | int nb_samples);
84 | #endif
85 |
86 | /**
87 | * Get a frame with filtered data from sink and put it in frame.
88 | *
89 | * @param ctx pointer to a buffersink or abuffersink filter context.
90 | * @param frame pointer to an allocated frame that will be filled with data.
91 | * The data must be freed using av_frame_unref() / av_frame_free()
92 | * @param flags a combination of AV_BUFFERSINK_FLAG_* flags
93 | *
94 | * @return >= 0 in for success, a negative AVERROR code for failure.
95 | */
96 | int av_buffersink_get_frame_flags(AVFilterContext *ctx, AVFrame *frame, int flags);
97 |
98 | /**
99 | * Tell av_buffersink_get_buffer_ref() to read video/samples buffer
100 | * reference, but not remove it from the buffer. This is useful if you
101 | * need only to read a video/samples buffer, without to fetch it.
102 | */
103 | #define AV_BUFFERSINK_FLAG_PEEK 1
104 |
105 | /**
106 | * Tell av_buffersink_get_buffer_ref() not to request a frame from its input.
107 | * If a frame is already buffered, it is read (and removed from the buffer),
108 | * but if no frame is present, return AVERROR(EAGAIN).
109 | */
110 | #define AV_BUFFERSINK_FLAG_NO_REQUEST 2
111 |
112 | /**
113 | * Struct to use for initializing a buffersink context.
114 | */
115 | typedef struct {
116 | const enum AVPixelFormat *pixel_fmts; ///< list of allowed pixel formats, terminated by AV_PIX_FMT_NONE
117 | } AVBufferSinkParams;
118 |
119 | /**
120 | * Create an AVBufferSinkParams structure.
121 | *
122 | * Must be freed with av_free().
123 | */
124 | AVBufferSinkParams *av_buffersink_params_alloc(void);
125 |
126 | /**
127 | * Struct to use for initializing an abuffersink context.
128 | */
129 | typedef struct {
130 | const enum AVSampleFormat *sample_fmts; ///< list of allowed sample formats, terminated by AV_SAMPLE_FMT_NONE
131 | const int64_t *channel_layouts; ///< list of allowed channel layouts, terminated by -1
132 | const int *channel_counts; ///< list of allowed channel counts, terminated by -1
133 | int all_channel_counts; ///< if not 0, accept any channel count or layout
134 | int *sample_rates; ///< list of allowed sample rates, terminated by -1
135 | } AVABufferSinkParams;
136 |
137 | /**
138 | * Create an AVABufferSinkParams structure.
139 | *
140 | * Must be freed with av_free().
141 | */
142 | AVABufferSinkParams *av_abuffersink_params_alloc(void);
143 |
144 | /**
145 | * Set the frame size for an audio buffer sink.
146 | *
147 | * All calls to av_buffersink_get_buffer_ref will return a buffer with
148 | * exactly the specified number of samples, or AVERROR(EAGAIN) if there is
149 | * not enough. The last buffer at EOF will be padded with 0.
150 | */
151 | void av_buffersink_set_frame_size(AVFilterContext *ctx, unsigned frame_size);
152 |
153 | /**
154 | * Get the frame rate of the input.
155 | */
156 | AVRational av_buffersink_get_frame_rate(AVFilterContext *ctx);
157 |
158 | /**
159 | * Get a frame with filtered data from sink and put it in frame.
160 | *
161 | * @param ctx pointer to a context of a buffersink or abuffersink AVFilter.
162 | * @param frame pointer to an allocated frame that will be filled with data.
163 | * The data must be freed using av_frame_unref() / av_frame_free()
164 | *
165 | * @return >= 0 in case of success, a negative AVERROR code in case of
166 | * failure.
167 | */
168 | int av_buffersink_get_frame(AVFilterContext *ctx, AVFrame *frame);
169 |
170 | /**
171 | * Same as av_buffersink_get_frame(), but with the ability to specify the number
172 | * of samples read. This function is less efficient than
173 | * av_buffersink_get_frame(), because it copies the data around.
174 | *
175 | * @param ctx pointer to a context of the abuffersink AVFilter.
176 | * @param frame pointer to an allocated frame that will be filled with data.
177 | * The data must be freed using av_frame_unref() / av_frame_free()
178 | * frame will contain exactly nb_samples audio samples, except at
179 | * the end of stream, when it can contain less than nb_samples.
180 | *
181 | * @warning do not mix this function with av_buffersink_get_frame(). Use only one or
182 | * the other with a single sink, not both.
183 | */
184 | int av_buffersink_get_samples(AVFilterContext *ctx, AVFrame *frame, int nb_samples);
185 |
186 | #endif /* AVFILTER_BUFFERSINK_H */
187 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavfilter/buffersrc.h:
--------------------------------------------------------------------------------
1 | /*
2 | *
3 | * This file is part of Libav.
4 | *
5 | * Libav is free software; you can redistribute it and/or
6 | * modify it under the terms of the GNU Lesser General Public
7 | * License as published by the Free Software Foundation; either
8 | * version 2.1 of the License, or (at your option) any later version.
9 | *
10 | * Libav is distributed in the hope that it will be useful,
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 | * Lesser General Public License for more details.
14 | *
15 | * You should have received a copy of the GNU Lesser General Public
16 | * License along with Libav; if not, write to the Free Software
17 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18 | */
19 |
20 | #ifndef AVFILTER_BUFFERSRC_H
21 | #define AVFILTER_BUFFERSRC_H
22 |
23 | /**
24 | * @file
25 | * Memory buffer source API.
26 | */
27 |
28 | #include "libavcodec/avcodec.h"
29 | #include "avfilter.h"
30 |
31 | enum {
32 |
33 | /**
34 | * Do not check for format changes.
35 | */
36 | AV_BUFFERSRC_FLAG_NO_CHECK_FORMAT = 1,
37 |
38 | #if FF_API_AVFILTERBUFFER
39 | /**
40 | * Ignored
41 | */
42 | AV_BUFFERSRC_FLAG_NO_COPY = 2,
43 | #endif
44 |
45 | /**
46 | * Immediately push the frame to the output.
47 | */
48 | AV_BUFFERSRC_FLAG_PUSH = 4,
49 |
50 | /**
51 | * Keep a reference to the frame.
52 | * If the frame if reference-counted, create a new reference; otherwise
53 | * copy the frame data.
54 | */
55 | AV_BUFFERSRC_FLAG_KEEP_REF = 8,
56 |
57 | };
58 |
59 | /**
60 | * Add buffer data in picref to buffer_src.
61 | *
62 | * @param buffer_src pointer to a buffer source context
63 | * @param picref a buffer reference, or NULL to mark EOF
64 | * @param flags a combination of AV_BUFFERSRC_FLAG_*
65 | * @return >= 0 in case of success, a negative AVERROR code
66 | * in case of failure
67 | */
68 | int av_buffersrc_add_ref(AVFilterContext *buffer_src,
69 | AVFilterBufferRef *picref, int flags);
70 |
71 | /**
72 | * Get the number of failed requests.
73 | *
74 | * A failed request is when the request_frame method is called while no
75 | * frame is present in the buffer.
76 | * The number is reset when a frame is added.
77 | */
78 | unsigned av_buffersrc_get_nb_failed_requests(AVFilterContext *buffer_src);
79 |
80 | #if FF_API_AVFILTERBUFFER
81 | /**
82 | * Add a buffer to the filtergraph s.
83 | *
84 | * @param buf buffer containing frame data to be passed down the filtergraph.
85 | * This function will take ownership of buf, the user must not free it.
86 | * A NULL buf signals EOF -- i.e. no more frames will be sent to this filter.
87 | *
88 | * @deprecated use av_buffersrc_write_frame() or av_buffersrc_add_frame()
89 | */
90 | attribute_deprecated
91 | int av_buffersrc_buffer(AVFilterContext *s, AVFilterBufferRef *buf);
92 | #endif
93 |
94 | /**
95 | * Add a frame to the buffer source.
96 | *
97 | * @param s an instance of the buffersrc filter.
98 | * @param frame frame to be added. If the frame is reference counted, this
99 | * function will make a new reference to it. Otherwise the frame data will be
100 | * copied.
101 | *
102 | * @return 0 on success, a negative AVERROR on error
103 | *
104 | * This function is equivalent to av_buffersrc_add_frame_flags() with the
105 | * AV_BUFFERSRC_FLAG_KEEP_REF flag.
106 | */
107 | int av_buffersrc_write_frame(AVFilterContext *s, const AVFrame *frame);
108 |
109 | /**
110 | * Add a frame to the buffer source.
111 | *
112 | * @param s an instance of the buffersrc filter.
113 | * @param frame frame to be added. If the frame is reference counted, this
114 | * function will take ownership of the reference(s) and reset the frame.
115 | * Otherwise the frame data will be copied. If this function returns an error,
116 | * the input frame is not touched.
117 | *
118 | * @return 0 on success, a negative AVERROR on error.
119 | *
120 | * @note the difference between this function and av_buffersrc_write_frame() is
121 | * that av_buffersrc_write_frame() creates a new reference to the input frame,
122 | * while this function takes ownership of the reference passed to it.
123 | *
124 | * This function is equivalent to av_buffersrc_add_frame_flags() without the
125 | * AV_BUFFERSRC_FLAG_KEEP_REF flag.
126 | */
127 | int av_buffersrc_add_frame(AVFilterContext *ctx, AVFrame *frame);
128 |
129 | /**
130 | * Add a frame to the buffer source.
131 | *
132 | * By default, if the frame is reference-counted, this function will take
133 | * ownership of the reference(s) and reset the frame. This can be controled
134 | * using the flags.
135 | *
136 | * If this function returns an error, the input frame is not touched.
137 | *
138 | * @param buffer_src pointer to a buffer source context
139 | * @param frame a frame, or NULL to mark EOF
140 | * @param flags a combination of AV_BUFFERSRC_FLAG_*
141 | * @return >= 0 in case of success, a negative AVERROR code
142 | * in case of failure
143 | */
144 | int av_buffersrc_add_frame_flags(AVFilterContext *buffer_src,
145 | AVFrame *frame, int flags);
146 |
147 |
148 | #endif /* AVFILTER_BUFFERSRC_H */
149 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavfilter/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVFILTER_VERSION_H
22 | #define AVFILTER_VERSION_H
23 |
24 | /**
25 | * @file
26 | * Libavfilter version macros
27 | */
28 |
29 | #include "libavutil/avutil.h"
30 |
31 | #define LIBAVFILTER_VERSION_MAJOR 3
32 | #define LIBAVFILTER_VERSION_MINOR 48
33 | #define LIBAVFILTER_VERSION_MICRO 105
34 |
35 | #define LIBAVFILTER_VERSION_INT AV_VERSION_INT(LIBAVFILTER_VERSION_MAJOR, \
36 | LIBAVFILTER_VERSION_MINOR, \
37 | LIBAVFILTER_VERSION_MICRO)
38 | #define LIBAVFILTER_VERSION AV_VERSION(LIBAVFILTER_VERSION_MAJOR, \
39 | LIBAVFILTER_VERSION_MINOR, \
40 | LIBAVFILTER_VERSION_MICRO)
41 | #define LIBAVFILTER_BUILD LIBAVFILTER_VERSION_INT
42 |
43 | #define LIBAVFILTER_IDENT "Lavfi" AV_STRINGIFY(LIBAVFILTER_VERSION)
44 |
45 | /**
46 | * FF_API_* defines may be placed below to indicate public API that will be
47 | * dropped at a future version bump. The defines themselves are not part of
48 | * the public API and may change, break or disappear at any time.
49 | */
50 |
51 | #ifndef FF_API_AVFILTERPAD_PUBLIC
52 | #define FF_API_AVFILTERPAD_PUBLIC (LIBAVFILTER_VERSION_MAJOR < 4)
53 | #endif
54 | #ifndef FF_API_FOO_COUNT
55 | #define FF_API_FOO_COUNT (LIBAVFILTER_VERSION_MAJOR < 4)
56 | #endif
57 | #ifndef FF_API_FILL_FRAME
58 | #define FF_API_FILL_FRAME (LIBAVFILTER_VERSION_MAJOR < 4)
59 | #endif
60 | #ifndef FF_API_BUFFERSRC_BUFFER
61 | #define FF_API_BUFFERSRC_BUFFER (LIBAVFILTER_VERSION_MAJOR < 4)
62 | #endif
63 | #ifndef FF_API_AVFILTERBUFFER
64 | #define FF_API_AVFILTERBUFFER (LIBAVFILTER_VERSION_MAJOR < 4)
65 | #endif
66 |
67 | #endif /* AVFILTER_VERSION_H */
68 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavformat/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVFORMAT_VERSION_H
22 | #define AVFORMAT_VERSION_H
23 |
24 | /**
25 | * @file
26 | * @ingroup libavf
27 | * Libavformat version macros
28 | */
29 |
30 | #include "libavutil/avutil.h"
31 |
32 | #define LIBAVFORMAT_VERSION_MAJOR 55
33 | #define LIBAVFORMAT_VERSION_MINOR 1
34 | #define LIBAVFORMAT_VERSION_MICRO 100
35 |
36 | #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
37 | LIBAVFORMAT_VERSION_MINOR, \
38 | LIBAVFORMAT_VERSION_MICRO)
39 | #define LIBAVFORMAT_VERSION AV_VERSION(LIBAVFORMAT_VERSION_MAJOR, \
40 | LIBAVFORMAT_VERSION_MINOR, \
41 | LIBAVFORMAT_VERSION_MICRO)
42 | #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT
43 |
44 | #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION)
45 |
46 | /**
47 | * FF_API_* defines may be placed below to indicate public API that will be
48 | * dropped at a future version bump. The defines themselves are not part of
49 | * the public API and may change, break or disappear at any time.
50 | */
51 |
52 | #ifndef FF_API_OLD_AVIO
53 | #define FF_API_OLD_AVIO (LIBAVFORMAT_VERSION_MAJOR < 55)
54 | #endif
55 | #ifndef FF_API_PKT_DUMP
56 | #define FF_API_PKT_DUMP (LIBAVFORMAT_VERSION_MAJOR < 54)
57 | #endif
58 | #ifndef FF_API_ALLOC_OUTPUT_CONTEXT
59 | #define FF_API_ALLOC_OUTPUT_CONTEXT (LIBAVFORMAT_VERSION_MAJOR < 56)
60 | #endif
61 | #ifndef FF_API_FORMAT_PARAMETERS
62 | #define FF_API_FORMAT_PARAMETERS (LIBAVFORMAT_VERSION_MAJOR < 56)
63 | #endif
64 | #ifndef FF_API_NEW_STREAM
65 | #define FF_API_NEW_STREAM (LIBAVFORMAT_VERSION_MAJOR < 56)
66 | #endif
67 | #ifndef FF_API_SET_PTS_INFO
68 | #define FF_API_SET_PTS_INFO (LIBAVFORMAT_VERSION_MAJOR < 56)
69 | #endif
70 | #ifndef FF_API_CLOSE_INPUT_FILE
71 | #define FF_API_CLOSE_INPUT_FILE (LIBAVFORMAT_VERSION_MAJOR < 56)
72 | #endif
73 | #ifndef FF_API_READ_PACKET
74 | #define FF_API_READ_PACKET (LIBAVFORMAT_VERSION_MAJOR < 56)
75 | #endif
76 | #ifndef FF_API_R_FRAME_RATE
77 | #define FF_API_R_FRAME_RATE 1
78 | #endif
79 | #endif /* AVFORMAT_VERSION_H */
80 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/adler32.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Mans Rullgard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_ADLER32_H
22 | #define AVUTIL_ADLER32_H
23 |
24 | #include
25 | #include "attributes.h"
26 |
27 | /**
28 | * @ingroup lavu_crypto
29 | * Calculate the Adler32 checksum of a buffer.
30 | *
31 | * Passing the return value to a subsequent av_adler32_update() call
32 | * allows the checksum of multiple buffers to be calculated as though
33 | * they were concatenated.
34 | *
35 | * @param adler initial checksum value
36 | * @param buf pointer to input buffer
37 | * @param len size of input buffer
38 | * @return updated checksum
39 | */
40 | unsigned long av_adler32_update(unsigned long adler, const uint8_t *buf,
41 | unsigned int len) av_pure;
42 |
43 | #endif /* AVUTIL_ADLER32_H */
44 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/aes.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2007 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_AES_H
22 | #define AVUTIL_AES_H
23 |
24 | #include
25 |
26 | #include "attributes.h"
27 | #include "version.h"
28 |
29 | /**
30 | * @defgroup lavu_aes AES
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | extern const int av_aes_size;
36 |
37 | struct AVAES;
38 |
39 | /**
40 | * Allocate an AVAES context.
41 | */
42 | struct AVAES *av_aes_alloc(void);
43 |
44 | /**
45 | * Initialize an AVAES context.
46 | * @param key_bits 128, 192 or 256
47 | * @param decrypt 0 for encryption, 1 for decryption
48 | */
49 | int av_aes_init(struct AVAES *a, const uint8_t *key, int key_bits, int decrypt);
50 |
51 | /**
52 | * Encrypt or decrypt a buffer using a previously initialized context.
53 | * @param count number of 16 byte blocks
54 | * @param dst destination array, can be equal to src
55 | * @param src source array, can be equal to dst
56 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
57 | * @param decrypt 0 for encryption, 1 for decryption
58 | */
59 | void av_aes_crypt(struct AVAES *a, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
60 |
61 | /**
62 | * @}
63 | */
64 |
65 | #endif /* AVUTIL_AES_H */
66 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/attributes.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * Macro definitions for various function/variable attributes
24 | */
25 |
26 | #ifndef AVUTIL_ATTRIBUTES_H
27 | #define AVUTIL_ATTRIBUTES_H
28 |
29 | #ifdef __GNUC__
30 | # define AV_GCC_VERSION_AT_LEAST(x,y) (__GNUC__ > x || __GNUC__ == x && __GNUC_MINOR__ >= y)
31 | #else
32 | # define AV_GCC_VERSION_AT_LEAST(x,y) 0
33 | #endif
34 |
35 | #ifndef av_always_inline
36 | #if AV_GCC_VERSION_AT_LEAST(3,1)
37 | # define av_always_inline __attribute__((always_inline)) inline
38 | #elif defined(_MSC_VER)
39 | # define av_always_inline __forceinline
40 | #else
41 | # define av_always_inline inline
42 | #endif
43 | #endif
44 |
45 | #ifndef av_extern_inline
46 | #if defined(__ICL) && __ICL >= 1210 || defined(__GNUC_STDC_INLINE__)
47 | # define av_extern_inline extern inline
48 | #else
49 | # define av_extern_inline inline
50 | #endif
51 | #endif
52 |
53 | #if AV_GCC_VERSION_AT_LEAST(3,1)
54 | # define av_noinline __attribute__((noinline))
55 | #else
56 | # define av_noinline
57 | #endif
58 |
59 | #if AV_GCC_VERSION_AT_LEAST(3,1)
60 | # define av_pure __attribute__((pure))
61 | #else
62 | # define av_pure
63 | #endif
64 |
65 | #ifndef av_restrict
66 | #define av_restrict restrict
67 | #endif
68 |
69 | #if AV_GCC_VERSION_AT_LEAST(2,6)
70 | # define av_const __attribute__((const))
71 | #else
72 | # define av_const
73 | #endif
74 |
75 | #if AV_GCC_VERSION_AT_LEAST(4,3)
76 | # define av_cold __attribute__((cold))
77 | #else
78 | # define av_cold
79 | #endif
80 |
81 | #if AV_GCC_VERSION_AT_LEAST(4,1)
82 | # define av_flatten __attribute__((flatten))
83 | #else
84 | # define av_flatten
85 | #endif
86 |
87 | #if AV_GCC_VERSION_AT_LEAST(3,1)
88 | # define attribute_deprecated __attribute__((deprecated))
89 | #else
90 | # define attribute_deprecated
91 | #endif
92 |
93 | /**
94 | * Disable warnings about deprecated features
95 | * This is useful for sections of code kept for backward compatibility and
96 | * scheduled for removal.
97 | */
98 | #ifndef AV_NOWARN_DEPRECATED
99 | #if AV_GCC_VERSION_AT_LEAST(4,6)
100 | # define AV_NOWARN_DEPRECATED(code) \
101 | _Pragma("GCC diagnostic push") \
102 | _Pragma("GCC diagnostic ignored \"-Wdeprecated-declarations\"") \
103 | code \
104 | _Pragma("GCC diagnostic pop")
105 | #else
106 | # define AV_NOWARN_DEPRECATED(code) code
107 | #endif
108 | #endif
109 |
110 |
111 | #if defined(__GNUC__)
112 | # define av_unused __attribute__((unused))
113 | #else
114 | # define av_unused
115 | #endif
116 |
117 | /**
118 | * Mark a variable as used and prevent the compiler from optimizing it
119 | * away. This is useful for variables accessed only from inline
120 | * assembler without the compiler being aware.
121 | */
122 | #if AV_GCC_VERSION_AT_LEAST(3,1)
123 | # define av_used __attribute__((used))
124 | #else
125 | # define av_used
126 | #endif
127 |
128 | #if AV_GCC_VERSION_AT_LEAST(3,3)
129 | # define av_alias __attribute__((may_alias))
130 | #else
131 | # define av_alias
132 | #endif
133 |
134 | #if defined(__GNUC__) && !defined(__INTEL_COMPILER) && !defined(__clang__)
135 | # define av_uninit(x) x=x
136 | #else
137 | # define av_uninit(x) x
138 | #endif
139 |
140 | #ifdef __GNUC__
141 | # define av_builtin_constant_p __builtin_constant_p
142 | # define av_printf_format(fmtpos, attrpos) __attribute__((__format__(__printf__, fmtpos, attrpos)))
143 | #else
144 | # define av_builtin_constant_p(x) 0
145 | # define av_printf_format(fmtpos, attrpos)
146 | #endif
147 |
148 | #if AV_GCC_VERSION_AT_LEAST(2,5)
149 | # define av_noreturn __attribute__((noreturn))
150 | #else
151 | # define av_noreturn
152 | #endif
153 |
154 | #endif /* AVUTIL_ATTRIBUTES_H */
155 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/audio_fifo.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Audio FIFO
3 | * Copyright (c) 2012 Justin Ruggles
4 | *
5 | * This file is part of Libav.
6 | *
7 | * Libav is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * Libav is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with Libav; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | /**
23 | * @file
24 | * Audio FIFO Buffer
25 | */
26 |
27 | #ifndef AVUTIL_AUDIO_FIFO_H
28 | #define AVUTIL_AUDIO_FIFO_H
29 |
30 | #include "avutil.h"
31 | #include "fifo.h"
32 | #include "samplefmt.h"
33 |
34 | /**
35 | * @addtogroup lavu_audio
36 | * @{
37 | */
38 |
39 | /**
40 | * Context for an Audio FIFO Buffer.
41 | *
42 | * - Operates at the sample level rather than the byte level.
43 | * - Supports multiple channels with either planar or packed sample format.
44 | * - Automatic reallocation when writing to a full buffer.
45 | */
46 | typedef struct AVAudioFifo AVAudioFifo;
47 |
48 | /**
49 | * Free an AVAudioFifo.
50 | *
51 | * @param af AVAudioFifo to free
52 | */
53 | void av_audio_fifo_free(AVAudioFifo *af);
54 |
55 | /**
56 | * Allocate an AVAudioFifo.
57 | *
58 | * @param sample_fmt sample format
59 | * @param channels number of channels
60 | * @param nb_samples initial allocation size, in samples
61 | * @return newly allocated AVAudioFifo, or NULL on error
62 | */
63 | AVAudioFifo *av_audio_fifo_alloc(enum AVSampleFormat sample_fmt, int channels,
64 | int nb_samples);
65 |
66 | /**
67 | * Reallocate an AVAudioFifo.
68 | *
69 | * @param af AVAudioFifo to reallocate
70 | * @param nb_samples new allocation size, in samples
71 | * @return 0 if OK, or negative AVERROR code on failure
72 | */
73 | int av_audio_fifo_realloc(AVAudioFifo *af, int nb_samples);
74 |
75 | /**
76 | * Write data to an AVAudioFifo.
77 | *
78 | * The AVAudioFifo will be reallocated automatically if the available space
79 | * is less than nb_samples.
80 | *
81 | * @see enum AVSampleFormat
82 | * The documentation for AVSampleFormat describes the data layout.
83 | *
84 | * @param af AVAudioFifo to write to
85 | * @param data audio data plane pointers
86 | * @param nb_samples number of samples to write
87 | * @return number of samples actually written, or negative AVERROR
88 | * code on failure. If successful, the number of samples
89 | * actually written will always be nb_samples.
90 | */
91 | int av_audio_fifo_write(AVAudioFifo *af, void **data, int nb_samples);
92 |
93 | /**
94 | * Read data from an AVAudioFifo.
95 | *
96 | * @see enum AVSampleFormat
97 | * The documentation for AVSampleFormat describes the data layout.
98 | *
99 | * @param af AVAudioFifo to read from
100 | * @param data audio data plane pointers
101 | * @param nb_samples number of samples to read
102 | * @return number of samples actually read, or negative AVERROR code
103 | * on failure. The number of samples actually read will not
104 | * be greater than nb_samples, and will only be less than
105 | * nb_samples if av_audio_fifo_size is less than nb_samples.
106 | */
107 | int av_audio_fifo_read(AVAudioFifo *af, void **data, int nb_samples);
108 |
109 | /**
110 | * Drain data from an AVAudioFifo.
111 | *
112 | * Removes the data without reading it.
113 | *
114 | * @param af AVAudioFifo to drain
115 | * @param nb_samples number of samples to drain
116 | * @return 0 if OK, or negative AVERROR code on failure
117 | */
118 | int av_audio_fifo_drain(AVAudioFifo *af, int nb_samples);
119 |
120 | /**
121 | * Reset the AVAudioFifo buffer.
122 | *
123 | * This empties all data in the buffer.
124 | *
125 | * @param af AVAudioFifo to reset
126 | */
127 | void av_audio_fifo_reset(AVAudioFifo *af);
128 |
129 | /**
130 | * Get the current number of samples in the AVAudioFifo available for reading.
131 | *
132 | * @param af the AVAudioFifo to query
133 | * @return number of samples available for reading
134 | */
135 | int av_audio_fifo_size(AVAudioFifo *af);
136 |
137 | /**
138 | * Get the current number of samples in the AVAudioFifo available for writing.
139 | *
140 | * @param af the AVAudioFifo to query
141 | * @return number of samples available for writing
142 | */
143 | int av_audio_fifo_space(AVAudioFifo *af);
144 |
145 | /**
146 | * @}
147 | */
148 |
149 | #endif /* AVUTIL_AUDIO_FIFO_H */
150 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/audioconvert.h:
--------------------------------------------------------------------------------
1 |
2 | #include "version.h"
3 |
4 | #if FF_API_AUDIOCONVERT
5 | #include "channel_layout.h"
6 | #endif
7 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/avassert.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2010 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * simple assert() macros that are a bit more flexible than ISO C assert().
24 | * @author Michael Niedermayer
25 | */
26 |
27 | #ifndef AVUTIL_AVASSERT_H
28 | #define AVUTIL_AVASSERT_H
29 |
30 | #include
31 | #include "avutil.h"
32 | #include "log.h"
33 |
34 | /**
35 | * assert() equivalent, that is always enabled.
36 | */
37 | #define av_assert0(cond) do { \
38 | if (!(cond)) { \
39 | av_log(NULL, AV_LOG_PANIC, "Assertion %s failed at %s:%d\n", \
40 | AV_STRINGIFY(cond), __FILE__, __LINE__); \
41 | abort(); \
42 | } \
43 | } while (0)
44 |
45 |
46 | /**
47 | * assert() equivalent, that does not lie in speed critical code.
48 | * These asserts() thus can be enabled without fearing speedloss.
49 | */
50 | #if defined(ASSERT_LEVEL) && ASSERT_LEVEL > 0
51 | #define av_assert1(cond) av_assert0(cond)
52 | #else
53 | #define av_assert1(cond) ((void)0)
54 | #endif
55 |
56 |
57 | /**
58 | * assert() equivalent, that does lie in speed critical code.
59 | */
60 | #if defined(ASSERT_LEVEL) && ASSERT_LEVEL > 1
61 | #define av_assert2(cond) av_assert0(cond)
62 | #else
63 | #define av_assert2(cond) ((void)0)
64 | #endif
65 |
66 | #endif /* AVUTIL_AVASSERT_H */
67 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/avconfig.h:
--------------------------------------------------------------------------------
1 | /* Generated by ffconf */
2 | #ifndef AVUTIL_AVCONFIG_H
3 | #define AVUTIL_AVCONFIG_H
4 | #define AV_HAVE_BIGENDIAN 0
5 | #define AV_HAVE_FAST_UNALIGNED 1
6 | #define AV_HAVE_INCOMPATIBLE_FORK_ABI 0
7 | #endif /* AVUTIL_AVCONFIG_H */
8 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/avutil.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_AVUTIL_H
22 | #define AVUTIL_AVUTIL_H
23 |
24 | /**
25 | * @file
26 | * external API header
27 | */
28 |
29 | /**
30 | * @mainpage
31 | *
32 | * @section ffmpeg_intro Introduction
33 | *
34 | * This document describes the usage of the different libraries
35 | * provided by FFmpeg.
36 | *
37 | * @li @ref libavc "libavcodec" encoding/decoding library
38 | * @li @ref lavfi "libavfilter" graph based frame editing library
39 | * @li @ref libavf "libavformat" I/O and muxing/demuxing library
40 | * @li @ref lavd "libavdevice" special devices muxing/demuxing library
41 | * @li @ref lavu "libavutil" common utility library
42 | * @li @ref lswr "libswresample" audio resampling, format conversion and mixing
43 | * @li @ref lpp "libpostproc" post processing library
44 | * @li @ref lsws "libswscale" color conversion and scaling library
45 | */
46 |
47 | /**
48 | * @defgroup lavu Common utility functions
49 | *
50 | * @brief
51 | * libavutil contains the code shared across all the other FFmpeg
52 | * libraries
53 | *
54 | * @note In order to use the functions provided by avutil you must include
55 | * the specific header.
56 | *
57 | * @{
58 | *
59 | * @defgroup lavu_crypto Crypto and Hashing
60 | *
61 | * @{
62 | * @}
63 | *
64 | * @defgroup lavu_math Maths
65 | * @{
66 | *
67 | * @}
68 | *
69 | * @defgroup lavu_string String Manipulation
70 | *
71 | * @{
72 | *
73 | * @}
74 | *
75 | * @defgroup lavu_mem Memory Management
76 | *
77 | * @{
78 | *
79 | * @}
80 | *
81 | * @defgroup lavu_data Data Structures
82 | * @{
83 | *
84 | * @}
85 | *
86 | * @defgroup lavu_audio Audio related
87 | *
88 | * @{
89 | *
90 | * @}
91 | *
92 | * @defgroup lavu_error Error Codes
93 | *
94 | * @{
95 | *
96 | * @}
97 | *
98 | * @defgroup lavu_misc Other
99 | *
100 | * @{
101 | *
102 | * @defgroup lavu_internal Internal
103 | *
104 | * Not exported functions, for internal usage only
105 | *
106 | * @{
107 | *
108 | * @}
109 | */
110 |
111 |
112 | /**
113 | * @addtogroup lavu_ver
114 | * @{
115 | */
116 |
117 | /**
118 | * Return the LIBAVUTIL_VERSION_INT constant.
119 | */
120 | unsigned avutil_version(void);
121 |
122 | /**
123 | * Return the libavutil build-time configuration.
124 | */
125 | const char *avutil_configuration(void);
126 |
127 | /**
128 | * Return the libavutil license.
129 | */
130 | const char *avutil_license(void);
131 |
132 | /**
133 | * @}
134 | */
135 |
136 | /**
137 | * @addtogroup lavu_media Media Type
138 | * @brief Media Type
139 | */
140 |
141 | enum AVMediaType {
142 | AVMEDIA_TYPE_UNKNOWN = -1, ///< Usually treated as AVMEDIA_TYPE_DATA
143 | AVMEDIA_TYPE_VIDEO,
144 | AVMEDIA_TYPE_AUDIO,
145 | AVMEDIA_TYPE_DATA, ///< Opaque data information usually continuous
146 | AVMEDIA_TYPE_SUBTITLE,
147 | AVMEDIA_TYPE_ATTACHMENT, ///< Opaque data information usually sparse
148 | AVMEDIA_TYPE_NB
149 | };
150 |
151 | /**
152 | * Return a string describing the media_type enum, NULL if media_type
153 | * is unknown.
154 | */
155 | const char *av_get_media_type_string(enum AVMediaType media_type);
156 |
157 | /**
158 | * @defgroup lavu_const Constants
159 | * @{
160 | *
161 | * @defgroup lavu_enc Encoding specific
162 | *
163 | * @note those definition should move to avcodec
164 | * @{
165 | */
166 |
167 | #define FF_LAMBDA_SHIFT 7
168 | #define FF_LAMBDA_SCALE (1<
25 |
26 | /**
27 | * @defgroup lavu_base64 Base64
28 | * @ingroup lavu_crypto
29 | * @{
30 | */
31 |
32 |
33 | /**
34 | * Decode a base64-encoded string.
35 | *
36 | * @param out buffer for decoded data
37 | * @param in null-terminated input string
38 | * @param out_size size in bytes of the out buffer, must be at
39 | * least 3/4 of the length of in
40 | * @return number of bytes written, or a negative value in case of
41 | * invalid input
42 | */
43 | int av_base64_decode(uint8_t *out, const char *in, int out_size);
44 |
45 | /**
46 | * Encode data to base64 and null-terminate.
47 | *
48 | * @param out buffer for encoded data
49 | * @param out_size size in bytes of the out buffer (including the
50 | * null terminator), must be at least AV_BASE64_SIZE(in_size)
51 | * @param in input buffer containing the data to encode
52 | * @param in_size size in bytes of the in buffer
53 | * @return out or NULL in case of error
54 | */
55 | char *av_base64_encode(char *out, int out_size, const uint8_t *in, int in_size);
56 |
57 | /**
58 | * Calculate the output size needed to base64-encode x bytes to a
59 | * null-terminated string.
60 | */
61 | #define AV_BASE64_SIZE(x) (((x)+2) / 3 * 4 + 1)
62 |
63 | /**
64 | * @}
65 | */
66 |
67 | #endif /* AVUTIL_BASE64_H */
68 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/blowfish.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Blowfish algorithm
3 | * Copyright (c) 2012 Samuel Pitoiset
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_BLOWFISH_H
23 | #define AVUTIL_BLOWFISH_H
24 |
25 | #include
26 |
27 | /**
28 | * @defgroup lavu_blowfish Blowfish
29 | * @ingroup lavu_crypto
30 | * @{
31 | */
32 |
33 | #define AV_BF_ROUNDS 16
34 |
35 | typedef struct AVBlowfish {
36 | uint32_t p[AV_BF_ROUNDS + 2];
37 | uint32_t s[4][256];
38 | } AVBlowfish;
39 |
40 | /**
41 | * Initialize an AVBlowfish context.
42 | *
43 | * @param ctx an AVBlowfish context
44 | * @param key a key
45 | * @param key_len length of the key
46 | */
47 | void av_blowfish_init(struct AVBlowfish *ctx, const uint8_t *key, int key_len);
48 |
49 | /**
50 | * Encrypt or decrypt a buffer using a previously initialized context.
51 | *
52 | * @param ctx an AVBlowfish context
53 | * @param xl left four bytes halves of input to be encrypted
54 | * @param xr right four bytes halves of input to be encrypted
55 | * @param decrypt 0 for encryption, 1 for decryption
56 | */
57 | void av_blowfish_crypt_ecb(struct AVBlowfish *ctx, uint32_t *xl, uint32_t *xr,
58 | int decrypt);
59 |
60 | /**
61 | * Encrypt or decrypt a buffer using a previously initialized context.
62 | *
63 | * @param ctx an AVBlowfish context
64 | * @param dst destination array, can be equal to src
65 | * @param src source array, can be equal to dst
66 | * @param count number of 8 byte blocks
67 | * @param iv initialization vector for CBC mode, if NULL ECB will be used
68 | * @param decrypt 0 for encryption, 1 for decryption
69 | */
70 | void av_blowfish_crypt(struct AVBlowfish *ctx, uint8_t *dst, const uint8_t *src,
71 | int count, uint8_t *iv, int decrypt);
72 |
73 | /**
74 | * @}
75 | */
76 |
77 | #endif /* AVUTIL_BLOWFISH_H */
78 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/bswap.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * byte swapping routines
24 | */
25 |
26 | #ifndef AVUTIL_BSWAP_H
27 | #define AVUTIL_BSWAP_H
28 |
29 | #include
30 | #include "libavutil/avconfig.h"
31 | #include "attributes.h"
32 |
33 | #ifdef HAVE_AV_CONFIG_H
34 |
35 | #include "config.h"
36 |
37 | #if ARCH_ARM
38 | # include "arm/bswap.h"
39 | #elif ARCH_AVR32
40 | # include "avr32/bswap.h"
41 | #elif ARCH_BFIN
42 | # include "bfin/bswap.h"
43 | #elif ARCH_SH4
44 | # include "sh4/bswap.h"
45 | #elif ARCH_X86
46 | # include "x86/bswap.h"
47 | #endif
48 |
49 | #endif /* HAVE_AV_CONFIG_H */
50 |
51 | #define AV_BSWAP16C(x) (((x) << 8 & 0xff00) | ((x) >> 8 & 0x00ff))
52 | #define AV_BSWAP32C(x) (AV_BSWAP16C(x) << 16 | AV_BSWAP16C((x) >> 16))
53 | #define AV_BSWAP64C(x) (AV_BSWAP32C(x) << 32 | AV_BSWAP32C((x) >> 32))
54 |
55 | #define AV_BSWAPC(s, x) AV_BSWAP##s##C(x)
56 |
57 | #ifndef av_bswap16
58 | static av_always_inline av_const uint16_t av_bswap16(uint16_t x)
59 | {
60 | x= (x>>8) | (x<<8);
61 | return x;
62 | }
63 | #endif
64 |
65 | #ifndef av_bswap32
66 | static av_always_inline av_const uint32_t av_bswap32(uint32_t x)
67 | {
68 | return AV_BSWAP32C(x);
69 | }
70 | #endif
71 |
72 | #ifndef av_bswap64
73 | static inline uint64_t av_const av_bswap64(uint64_t x)
74 | {
75 | return (uint64_t)av_bswap32(x) << 32 | av_bswap32(x >> 32);
76 | }
77 | #endif
78 |
79 | // be2ne ... big-endian to native-endian
80 | // le2ne ... little-endian to native-endian
81 |
82 | #if AV_HAVE_BIGENDIAN
83 | #define av_be2ne16(x) (x)
84 | #define av_be2ne32(x) (x)
85 | #define av_be2ne64(x) (x)
86 | #define av_le2ne16(x) av_bswap16(x)
87 | #define av_le2ne32(x) av_bswap32(x)
88 | #define av_le2ne64(x) av_bswap64(x)
89 | #define AV_BE2NEC(s, x) (x)
90 | #define AV_LE2NEC(s, x) AV_BSWAPC(s, x)
91 | #else
92 | #define av_be2ne16(x) av_bswap16(x)
93 | #define av_be2ne32(x) av_bswap32(x)
94 | #define av_be2ne64(x) av_bswap64(x)
95 | #define av_le2ne16(x) (x)
96 | #define av_le2ne32(x) (x)
97 | #define av_le2ne64(x) (x)
98 | #define AV_BE2NEC(s, x) AV_BSWAPC(s, x)
99 | #define AV_LE2NEC(s, x) (x)
100 | #endif
101 |
102 | #define AV_BE2NE16C(x) AV_BE2NEC(16, x)
103 | #define AV_BE2NE32C(x) AV_BE2NEC(32, x)
104 | #define AV_BE2NE64C(x) AV_BE2NEC(64, x)
105 | #define AV_LE2NE16C(x) AV_LE2NEC(16, x)
106 | #define AV_LE2NE32C(x) AV_LE2NEC(32, x)
107 | #define AV_LE2NE64C(x) AV_LE2NEC(64, x)
108 |
109 | #endif /* AVUTIL_BSWAP_H */
110 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/cpu.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_CPU_H
22 | #define AVUTIL_CPU_H
23 |
24 | #include "attributes.h"
25 |
26 | #define AV_CPU_FLAG_FORCE 0x80000000 /* force usage of selected flags (OR) */
27 |
28 | /* lower 16 bits - CPU features */
29 | #define AV_CPU_FLAG_MMX 0x0001 ///< standard MMX
30 | #define AV_CPU_FLAG_MMXEXT 0x0002 ///< SSE integer functions or AMD MMX ext
31 | #define AV_CPU_FLAG_MMX2 0x0002 ///< SSE integer functions or AMD MMX ext
32 | #define AV_CPU_FLAG_3DNOW 0x0004 ///< AMD 3DNOW
33 | #define AV_CPU_FLAG_SSE 0x0008 ///< SSE functions
34 | #define AV_CPU_FLAG_SSE2 0x0010 ///< PIV SSE2 functions
35 | #define AV_CPU_FLAG_SSE2SLOW 0x40000000 ///< SSE2 supported, but usually not faster
36 | #define AV_CPU_FLAG_3DNOWEXT 0x0020 ///< AMD 3DNowExt
37 | #define AV_CPU_FLAG_SSE3 0x0040 ///< Prescott SSE3 functions
38 | #define AV_CPU_FLAG_SSE3SLOW 0x20000000 ///< SSE3 supported, but usually not faster
39 | #define AV_CPU_FLAG_SSSE3 0x0080 ///< Conroe SSSE3 functions
40 | #define AV_CPU_FLAG_ATOM 0x10000000 ///< Atom processor, some SSSE3 instructions are slower
41 | #define AV_CPU_FLAG_SSE4 0x0100 ///< Penryn SSE4.1 functions
42 | #define AV_CPU_FLAG_SSE42 0x0200 ///< Nehalem SSE4.2 functions
43 | #define AV_CPU_FLAG_AVX 0x4000 ///< AVX functions: requires OS support even if YMM registers aren't used
44 | #define AV_CPU_FLAG_XOP 0x0400 ///< Bulldozer XOP functions
45 | #define AV_CPU_FLAG_FMA4 0x0800 ///< Bulldozer FMA4 functions
46 | // #if LIBAVUTIL_VERSION_MAJOR <52
47 | #define AV_CPU_FLAG_CMOV 0x1001000 ///< supports cmov instruction
48 | // #else
49 | // #define AV_CPU_FLAG_CMOV 0x1000 ///< supports cmov instruction
50 | // #endif
51 |
52 | #define AV_CPU_FLAG_ALTIVEC 0x0001 ///< standard
53 |
54 | #define AV_CPU_FLAG_ARMV5TE (1 << 0)
55 | #define AV_CPU_FLAG_ARMV6 (1 << 1)
56 | #define AV_CPU_FLAG_ARMV6T2 (1 << 2)
57 | #define AV_CPU_FLAG_VFP (1 << 3)
58 | #define AV_CPU_FLAG_VFPV3 (1 << 4)
59 | #define AV_CPU_FLAG_NEON (1 << 5)
60 |
61 | /**
62 | * Return the flags which specify extensions supported by the CPU.
63 | * The returned value is affected by av_force_cpu_flags() if that was used
64 | * before. So av_get_cpu_flags() can easily be used in a application to
65 | * detect the enabled cpu flags.
66 | */
67 | int av_get_cpu_flags(void);
68 |
69 | /**
70 | * Disables cpu detection and forces the specified flags.
71 | * -1 is a special case that disables forcing of specific flags.
72 | */
73 | void av_force_cpu_flags(int flags);
74 |
75 | /**
76 | * Set a mask on flags returned by av_get_cpu_flags().
77 | * This function is mainly useful for testing.
78 | * Please use av_force_cpu_flags() and av_get_cpu_flags() instead which are more flexible
79 | *
80 | * @warning this function is not thread safe.
81 | */
82 | attribute_deprecated void av_set_cpu_flags_mask(int mask);
83 |
84 | /**
85 | * Parse CPU flags from a string.
86 | *
87 | * The returned flags contain the specified flags as well as related unspecified flags.
88 | *
89 | * This function exists only for compatibility with libav.
90 | * Please use av_parse_cpu_caps() when possible.
91 | * @return a combination of AV_CPU_* flags, negative on error.
92 | */
93 | attribute_deprecated
94 | int av_parse_cpu_flags(const char *s);
95 |
96 | /**
97 | * Parse CPU caps from a string and update the given AV_CPU_* flags based on that.
98 | *
99 | * @return negative on error.
100 | */
101 | int av_parse_cpu_caps(unsigned *flags, const char *s);
102 |
103 | /* The following CPU-specific functions shall not be called directly. */
104 | int ff_get_cpu_flags_arm(void);
105 | int ff_get_cpu_flags_ppc(void);
106 | int ff_get_cpu_flags_x86(void);
107 |
108 | #endif /* AVUTIL_CPU_H */
109 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/crc.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_CRC_H
22 | #define AVUTIL_CRC_H
23 |
24 | #include
25 | #include
26 | #include "attributes.h"
27 |
28 | typedef uint32_t AVCRC;
29 |
30 | typedef enum {
31 | AV_CRC_8_ATM,
32 | AV_CRC_16_ANSI,
33 | AV_CRC_16_CCITT,
34 | AV_CRC_32_IEEE,
35 | AV_CRC_32_IEEE_LE, /*< reversed bitorder version of AV_CRC_32_IEEE */
36 | AV_CRC_MAX, /*< Not part of public API! Do not use outside libavutil. */
37 | }AVCRCId;
38 |
39 | /**
40 | * Initialize a CRC table.
41 | * @param ctx must be an array of size sizeof(AVCRC)*257 or sizeof(AVCRC)*1024
42 | * @param le If 1, the lowest bit represents the coefficient for the highest
43 | * exponent of the corresponding polynomial (both for poly and
44 | * actual CRC).
45 | * If 0, you must swap the CRC parameter and the result of av_crc
46 | * if you need the standard representation (can be simplified in
47 | * most cases to e.g. bswap16):
48 | * av_bswap32(crc << (32-bits))
49 | * @param bits number of bits for the CRC
50 | * @param poly generator polynomial without the x**bits coefficient, in the
51 | * representation as specified by le
52 | * @param ctx_size size of ctx in bytes
53 | * @return <0 on failure
54 | */
55 | int av_crc_init(AVCRC *ctx, int le, int bits, uint32_t poly, int ctx_size);
56 |
57 | /**
58 | * Get an initialized standard CRC table.
59 | * @param crc_id ID of a standard CRC
60 | * @return a pointer to the CRC table or NULL on failure
61 | */
62 | const AVCRC *av_crc_get_table(AVCRCId crc_id);
63 |
64 | /**
65 | * Calculate the CRC of a block.
66 | * @param crc CRC of previous blocks if any or initial value for CRC
67 | * @return CRC updated with the data from the given block
68 | *
69 | * @see av_crc_init() "le" parameter
70 | */
71 | uint32_t av_crc(const AVCRC *ctx, uint32_t crc,
72 | const uint8_t *buffer, size_t length) av_pure;
73 |
74 | #endif /* AVUTIL_CRC_H */
75 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/dict.h:
--------------------------------------------------------------------------------
1 | /*
2 | *
3 | * This file is part of FFmpeg.
4 | *
5 | * FFmpeg is free software; you can redistribute it and/or
6 | * modify it under the terms of the GNU Lesser General Public
7 | * License as published by the Free Software Foundation; either
8 | * version 2.1 of the License, or (at your option) any later version.
9 | *
10 | * FFmpeg is distributed in the hope that it will be useful,
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 | * Lesser General Public License for more details.
14 | *
15 | * You should have received a copy of the GNU Lesser General Public
16 | * License along with FFmpeg; if not, write to the Free Software
17 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18 | */
19 |
20 | /**
21 | * @file
22 | * Public dictionary API.
23 | * @deprecated
24 | * AVDictionary is provided for compatibility with libav. It is both in
25 | * implementation as well as API inefficient. It does not scale and is
26 | * extremely slow with large dictionaries.
27 | * It is recommended that new code uses our tree container from tree.c/h
28 | * where applicable, which uses AVL trees to achieve O(log n) performance.
29 | */
30 |
31 | #ifndef AVUTIL_DICT_H
32 | #define AVUTIL_DICT_H
33 |
34 | /**
35 | * @addtogroup lavu_dict AVDictionary
36 | * @ingroup lavu_data
37 | *
38 | * @brief Simple key:value store
39 | *
40 | * @{
41 | * Dictionaries are used for storing key:value pairs. To create
42 | * an AVDictionary, simply pass an address of a NULL pointer to
43 | * av_dict_set(). NULL can be used as an empty dictionary wherever
44 | * a pointer to an AVDictionary is required.
45 | * Use av_dict_get() to retrieve an entry or iterate over all
46 | * entries and finally av_dict_free() to free the dictionary
47 | * and all its contents.
48 | *
49 | * @code
50 | * AVDictionary *d = NULL; // "create" an empty dictionary
51 | * av_dict_set(&d, "foo", "bar", 0); // add an entry
52 | *
53 | * char *k = av_strdup("key"); // if your strings are already allocated,
54 | * char *v = av_strdup("value"); // you can avoid copying them like this
55 | * av_dict_set(&d, k, v, AV_DICT_DONT_STRDUP_KEY | AV_DICT_DONT_STRDUP_VAL);
56 | *
57 | * AVDictionaryEntry *t = NULL;
58 | * while (t = av_dict_get(d, "", t, AV_DICT_IGNORE_SUFFIX)) {
59 | * <....> // iterate over all entries in d
60 | * }
61 | *
62 | * av_dict_free(&d);
63 | * @endcode
64 | *
65 | */
66 |
67 | #define AV_DICT_MATCH_CASE 1
68 | #define AV_DICT_IGNORE_SUFFIX 2
69 | #define AV_DICT_DONT_STRDUP_KEY 4 /**< Take ownership of a key that's been
70 | allocated with av_malloc() and children. */
71 | #define AV_DICT_DONT_STRDUP_VAL 8 /**< Take ownership of a value that's been
72 | allocated with av_malloc() and chilren. */
73 | #define AV_DICT_DONT_OVERWRITE 16 ///< Don't overwrite existing entries.
74 | #define AV_DICT_APPEND 32 /**< If the entry already exists, append to it. Note that no
75 | delimiter is added, the strings are simply concatenated. */
76 |
77 | typedef struct AVDictionaryEntry {
78 | char *key;
79 | char *value;
80 | } AVDictionaryEntry;
81 |
82 | typedef struct AVDictionary AVDictionary;
83 |
84 | /**
85 | * Get a dictionary entry with matching key.
86 | *
87 | * @param prev Set to the previous matching element to find the next.
88 | * If set to NULL the first matching element is returned.
89 | * @param flags Allows case as well as suffix-insensitive comparisons.
90 | * @return Found entry or NULL, changing key or value leads to undefined behavior.
91 | */
92 | AVDictionaryEntry *
93 | av_dict_get(AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags);
94 |
95 | /**
96 | * Get number of entries in dictionary.
97 | *
98 | * @param m dictionary
99 | * @return number of entries in dictionary
100 | */
101 | int av_dict_count(const AVDictionary *m);
102 |
103 | /**
104 | * Set the given entry in *pm, overwriting an existing entry.
105 | *
106 | * @param pm pointer to a pointer to a dictionary struct. If *pm is NULL
107 | * a dictionary struct is allocated and put in *pm.
108 | * @param key entry key to add to *pm (will be av_strduped depending on flags)
109 | * @param value entry value to add to *pm (will be av_strduped depending on flags).
110 | * Passing a NULL value will cause an existing entry to be deleted.
111 | * @return >= 0 on success otherwise an error code <0
112 | */
113 | int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags);
114 |
115 | /**
116 | * Parse the key/value pairs list and add to a dictionary.
117 | *
118 | * @param key_val_sep a 0-terminated list of characters used to separate
119 | * key from value
120 | * @param pairs_sep a 0-terminated list of characters used to separate
121 | * two pairs from each other
122 | * @param flags flags to use when adding to dictionary.
123 | * AV_DICT_DONT_STRDUP_KEY and AV_DICT_DONT_STRDUP_VAL
124 | * are ignored since the key/value tokens will always
125 | * be duplicated.
126 | * @return 0 on success, negative AVERROR code on failure
127 | */
128 | int av_dict_parse_string(AVDictionary **pm, const char *str,
129 | const char *key_val_sep, const char *pairs_sep,
130 | int flags);
131 |
132 | /**
133 | * Copy entries from one AVDictionary struct into another.
134 | * @param dst pointer to a pointer to a AVDictionary struct. If *dst is NULL,
135 | * this function will allocate a struct for you and put it in *dst
136 | * @param src pointer to source AVDictionary struct
137 | * @param flags flags to use when setting entries in *dst
138 | * @note metadata is read using the AV_DICT_IGNORE_SUFFIX flag
139 | */
140 | void av_dict_copy(AVDictionary **dst, AVDictionary *src, int flags);
141 |
142 | /**
143 | * Free all the memory allocated for an AVDictionary struct
144 | * and all keys and values.
145 | */
146 | void av_dict_free(AVDictionary **m);
147 |
148 | /**
149 | * @}
150 | */
151 |
152 | #endif /* AVUTIL_DICT_H */
153 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/error.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * error code definitions
22 | */
23 |
24 | #ifndef AVUTIL_ERROR_H
25 | #define AVUTIL_ERROR_H
26 |
27 | #include
28 | #include
29 |
30 | /**
31 | * @addtogroup lavu_error
32 | *
33 | * @{
34 | */
35 |
36 |
37 | /* error handling */
38 | #if EDOM > 0
39 | #define AVERROR(e) (-(e)) ///< Returns a negative error code from a POSIX error code, to return from library functions.
40 | #define AVUNERROR(e) (-(e)) ///< Returns a POSIX error code from a library function error return value.
41 | #else
42 | /* Some platforms have E* and errno already negated. */
43 | #define AVERROR(e) (e)
44 | #define AVUNERROR(e) (e)
45 | #endif
46 |
47 | #define FFERRTAG(a, b, c, d) (-(int)MKTAG(a, b, c, d))
48 |
49 | #define AVERROR_BSF_NOT_FOUND FFERRTAG(0xF8,'B','S','F') ///< Bitstream filter not found
50 | #define AVERROR_BUG FFERRTAG( 'B','U','G','!') ///< Internal bug, also see AVERROR_BUG2
51 | #define AVERROR_BUFFER_TOO_SMALL FFERRTAG( 'B','U','F','S') ///< Buffer too small
52 | #define AVERROR_DECODER_NOT_FOUND FFERRTAG(0xF8,'D','E','C') ///< Decoder not found
53 | #define AVERROR_DEMUXER_NOT_FOUND FFERRTAG(0xF8,'D','E','M') ///< Demuxer not found
54 | #define AVERROR_ENCODER_NOT_FOUND FFERRTAG(0xF8,'E','N','C') ///< Encoder not found
55 | #define AVERROR_EOF FFERRTAG( 'E','O','F',' ') ///< End of file
56 | #define AVERROR_EXIT FFERRTAG( 'E','X','I','T') ///< Immediate exit was requested; the called function should not be restarted
57 | #define AVERROR_EXTERNAL FFERRTAG( 'E','X','T',' ') ///< Generic error in an external library
58 | #define AVERROR_FILTER_NOT_FOUND FFERRTAG(0xF8,'F','I','L') ///< Filter not found
59 | #define AVERROR_INVALIDDATA FFERRTAG( 'I','N','D','A') ///< Invalid data found when processing input
60 | #define AVERROR_MUXER_NOT_FOUND FFERRTAG(0xF8,'M','U','X') ///< Muxer not found
61 | #define AVERROR_OPTION_NOT_FOUND FFERRTAG(0xF8,'O','P','T') ///< Option not found
62 | #define AVERROR_PATCHWELCOME FFERRTAG( 'P','A','W','E') ///< Not yet implemented in FFmpeg, patches welcome
63 | #define AVERROR_PROTOCOL_NOT_FOUND FFERRTAG(0xF8,'P','R','O') ///< Protocol not found
64 |
65 | #define AVERROR_STREAM_NOT_FOUND FFERRTAG(0xF8,'S','T','R') ///< Stream not found
66 | /**
67 | * This is semantically identical to AVERROR_BUG
68 | * it has been introduced in Libav after our AVERROR_BUG and with a modified value.
69 | */
70 | #define AVERROR_BUG2 FFERRTAG( 'B','U','G',' ')
71 | #define AVERROR_UNKNOWN FFERRTAG( 'U','N','K','N') ///< Unknown error, typically from an external library
72 | #define AVERROR_EXPERIMENTAL (-0x2bb2afa8) ///< Requested feature is flagged experimental. Set strict_std_compliance if you really want to use it.
73 |
74 | #define AV_ERROR_MAX_STRING_SIZE 64
75 |
76 | /**
77 | * Put a description of the AVERROR code errnum in errbuf.
78 | * In case of failure the global variable errno is set to indicate the
79 | * error. Even in case of failure av_strerror() will print a generic
80 | * error message indicating the errnum provided to errbuf.
81 | *
82 | * @param errnum error code to describe
83 | * @param errbuf buffer to which description is written
84 | * @param errbuf_size the size in bytes of errbuf
85 | * @return 0 on success, a negative value if a description for errnum
86 | * cannot be found
87 | */
88 | int av_strerror(int errnum, char *errbuf, size_t errbuf_size);
89 |
90 | /**
91 | * Fill the provided buffer with a string containing an error string
92 | * corresponding to the AVERROR code errnum.
93 | *
94 | * @param errbuf a buffer
95 | * @param errbuf_size size in bytes of errbuf
96 | * @param errnum error code to describe
97 | * @return the buffer in input, filled with the error description
98 | * @see av_strerror()
99 | */
100 | static inline char *av_make_error_string(char *errbuf, size_t errbuf_size, int errnum)
101 | {
102 | av_strerror(errnum, errbuf, errbuf_size);
103 | return errbuf;
104 | }
105 |
106 | /**
107 | * Convenience macro, the return value should be used only directly in
108 | * function arguments but never stand-alone.
109 | */
110 | #define av_err2str(errnum) \
111 | av_make_error_string((char[AV_ERROR_MAX_STRING_SIZE]){0}, AV_ERROR_MAX_STRING_SIZE, errnum)
112 |
113 | /**
114 | * @}
115 | */
116 |
117 | #endif /* AVUTIL_ERROR_H */
118 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/eval.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2002 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | /**
22 | * @file
23 | * simple arithmetic expression evaluator
24 | */
25 |
26 | #ifndef AVUTIL_EVAL_H
27 | #define AVUTIL_EVAL_H
28 |
29 | #include "avutil.h"
30 |
31 | typedef struct AVExpr AVExpr;
32 |
33 | /**
34 | * Parse and evaluate an expression.
35 | * Note, this is significantly slower than av_expr_eval().
36 | *
37 | * @param res a pointer to a double where is put the result value of
38 | * the expression, or NAN in case of error
39 | * @param s expression as a zero terminated string, for example "1+2^3+5*5+sin(2/3)"
40 | * @param const_names NULL terminated array of zero terminated strings of constant identifiers, for example {"PI", "E", 0}
41 | * @param const_values a zero terminated array of values for the identifiers from const_names
42 | * @param func1_names NULL terminated array of zero terminated strings of funcs1 identifiers
43 | * @param funcs1 NULL terminated array of function pointers for functions which take 1 argument
44 | * @param func2_names NULL terminated array of zero terminated strings of funcs2 identifiers
45 | * @param funcs2 NULL terminated array of function pointers for functions which take 2 arguments
46 | * @param opaque a pointer which will be passed to all functions from funcs1 and funcs2
47 | * @param log_ctx parent logging context
48 | * @return 0 in case of success, a negative value corresponding to an
49 | * AVERROR code otherwise
50 | */
51 | int av_expr_parse_and_eval(double *res, const char *s,
52 | const char * const *const_names, const double *const_values,
53 | const char * const *func1_names, double (* const *funcs1)(void *, double),
54 | const char * const *func2_names, double (* const *funcs2)(void *, double, double),
55 | void *opaque, int log_offset, void *log_ctx);
56 |
57 | /**
58 | * Parse an expression.
59 | *
60 | * @param expr a pointer where is put an AVExpr containing the parsed
61 | * value in case of successful parsing, or NULL otherwise.
62 | * The pointed to AVExpr must be freed with av_expr_free() by the user
63 | * when it is not needed anymore.
64 | * @param s expression as a zero terminated string, for example "1+2^3+5*5+sin(2/3)"
65 | * @param const_names NULL terminated array of zero terminated strings of constant identifiers, for example {"PI", "E", 0}
66 | * @param func1_names NULL terminated array of zero terminated strings of funcs1 identifiers
67 | * @param funcs1 NULL terminated array of function pointers for functions which take 1 argument
68 | * @param func2_names NULL terminated array of zero terminated strings of funcs2 identifiers
69 | * @param funcs2 NULL terminated array of function pointers for functions which take 2 arguments
70 | * @param log_ctx parent logging context
71 | * @return 0 in case of success, a negative value corresponding to an
72 | * AVERROR code otherwise
73 | */
74 | int av_expr_parse(AVExpr **expr, const char *s,
75 | const char * const *const_names,
76 | const char * const *func1_names, double (* const *funcs1)(void *, double),
77 | const char * const *func2_names, double (* const *funcs2)(void *, double, double),
78 | int log_offset, void *log_ctx);
79 |
80 | /**
81 | * Evaluate a previously parsed expression.
82 | *
83 | * @param const_values a zero terminated array of values for the identifiers from av_expr_parse() const_names
84 | * @param opaque a pointer which will be passed to all functions from funcs1 and funcs2
85 | * @return the value of the expression
86 | */
87 | double av_expr_eval(AVExpr *e, const double *const_values, void *opaque);
88 |
89 | /**
90 | * Free a parsed expression previously created with av_expr_parse().
91 | */
92 | void av_expr_free(AVExpr *e);
93 |
94 | /**
95 | * Parse the string in numstr and return its value as a double. If
96 | * the string is empty, contains only whitespaces, or does not contain
97 | * an initial substring that has the expected syntax for a
98 | * floating-point number, no conversion is performed. In this case,
99 | * returns a value of zero and the value returned in tail is the value
100 | * of numstr.
101 | *
102 | * @param numstr a string representing a number, may contain one of
103 | * the International System number postfixes, for example 'K', 'M',
104 | * 'G'. If 'i' is appended after the postfix, powers of 2 are used
105 | * instead of powers of 10. The 'B' postfix multiplies the value for
106 | * 8, and can be appended after another postfix or used alone. This
107 | * allows using for example 'KB', 'MiB', 'G' and 'B' as postfix.
108 | * @param tail if non-NULL puts here the pointer to the char next
109 | * after the last parsed character
110 | */
111 | double av_strtod(const char *numstr, char **tail);
112 |
113 | #endif /* AVUTIL_EVAL_H */
114 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/fifo.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * a very simple circular buffer FIFO implementation
22 | */
23 |
24 | #ifndef AVUTIL_FIFO_H
25 | #define AVUTIL_FIFO_H
26 |
27 | #include
28 | #include "avutil.h"
29 | #include "attributes.h"
30 |
31 | typedef struct AVFifoBuffer {
32 | uint8_t *buffer;
33 | uint8_t *rptr, *wptr, *end;
34 | uint32_t rndx, wndx;
35 | } AVFifoBuffer;
36 |
37 | /**
38 | * Initialize an AVFifoBuffer.
39 | * @param size of FIFO
40 | * @return AVFifoBuffer or NULL in case of memory allocation failure
41 | */
42 | AVFifoBuffer *av_fifo_alloc(unsigned int size);
43 |
44 | /**
45 | * Free an AVFifoBuffer.
46 | * @param f AVFifoBuffer to free
47 | */
48 | void av_fifo_free(AVFifoBuffer *f);
49 |
50 | /**
51 | * Reset the AVFifoBuffer to the state right after av_fifo_alloc, in particular it is emptied.
52 | * @param f AVFifoBuffer to reset
53 | */
54 | void av_fifo_reset(AVFifoBuffer *f);
55 |
56 | /**
57 | * Return the amount of data in bytes in the AVFifoBuffer, that is the
58 | * amount of data you can read from it.
59 | * @param f AVFifoBuffer to read from
60 | * @return size
61 | */
62 | int av_fifo_size(AVFifoBuffer *f);
63 |
64 | /**
65 | * Return the amount of space in bytes in the AVFifoBuffer, that is the
66 | * amount of data you can write into it.
67 | * @param f AVFifoBuffer to write into
68 | * @return size
69 | */
70 | int av_fifo_space(AVFifoBuffer *f);
71 |
72 | /**
73 | * Feed data from an AVFifoBuffer to a user-supplied callback.
74 | * @param f AVFifoBuffer to read from
75 | * @param buf_size number of bytes to read
76 | * @param func generic read function
77 | * @param dest data destination
78 | */
79 | int av_fifo_generic_read(AVFifoBuffer *f, void *dest, int buf_size, void (*func)(void*, void*, int));
80 |
81 | /**
82 | * Feed data from a user-supplied callback to an AVFifoBuffer.
83 | * @param f AVFifoBuffer to write to
84 | * @param src data source; non-const since it may be used as a
85 | * modifiable context by the function defined in func
86 | * @param size number of bytes to write
87 | * @param func generic write function; the first parameter is src,
88 | * the second is dest_buf, the third is dest_buf_size.
89 | * func must return the number of bytes written to dest_buf, or <= 0 to
90 | * indicate no more data available to write.
91 | * If func is NULL, src is interpreted as a simple byte array for source data.
92 | * @return the number of bytes written to the FIFO
93 | */
94 | int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, int (*func)(void*, void*, int));
95 |
96 | /**
97 | * Resize an AVFifoBuffer.
98 | * In case of reallocation failure, the old FIFO is kept unchanged.
99 | *
100 | * @param f AVFifoBuffer to resize
101 | * @param size new AVFifoBuffer size in bytes
102 | * @return <0 for failure, >=0 otherwise
103 | */
104 | int av_fifo_realloc2(AVFifoBuffer *f, unsigned int size);
105 |
106 | /**
107 | * Enlarge an AVFifoBuffer.
108 | * In case of reallocation failure, the old FIFO is kept unchanged.
109 | * The new fifo size may be larger than the requested size.
110 | *
111 | * @param f AVFifoBuffer to resize
112 | * @param additional_space the amount of space in bytes to allocate in addition to av_fifo_size()
113 | * @return <0 for failure, >=0 otherwise
114 | */
115 | int av_fifo_grow(AVFifoBuffer *f, unsigned int additional_space);
116 |
117 | /**
118 | * Read and discard the specified amount of data from an AVFifoBuffer.
119 | * @param f AVFifoBuffer to read from
120 | * @param size amount of data to read in bytes
121 | */
122 | void av_fifo_drain(AVFifoBuffer *f, int size);
123 |
124 | /**
125 | * Return a pointer to the data stored in a FIFO buffer at a certain offset.
126 | * The FIFO buffer is not modified.
127 | *
128 | * @param f AVFifoBuffer to peek at, f must be non-NULL
129 | * @param offs an offset in bytes, its absolute value must be less
130 | * than the used buffer size or the returned pointer will
131 | * point outside to the buffer data.
132 | * The used buffer size can be checked with av_fifo_size().
133 | */
134 | static inline uint8_t *av_fifo_peek2(const AVFifoBuffer *f, int offs)
135 | {
136 | uint8_t *ptr = f->rptr + offs;
137 | if (ptr >= f->end)
138 | ptr = f->buffer + (ptr - f->end);
139 | else if (ptr < f->buffer)
140 | ptr = f->end - (f->buffer - ptr);
141 | return ptr;
142 | }
143 |
144 | #endif /* AVUTIL_FIFO_H */
145 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/file.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_FILE_H
20 | #define AVUTIL_FILE_H
21 |
22 | #include
23 |
24 | #include "avutil.h"
25 |
26 | /**
27 | * @file
28 | * Misc file utilities.
29 | */
30 |
31 | /**
32 | * Read the file with name filename, and put its content in a newly
33 | * allocated buffer or map it with mmap() when available.
34 | * In case of success set *bufptr to the read or mmapped buffer, and
35 | * *size to the size in bytes of the buffer in *bufptr.
36 | * The returned buffer must be released with av_file_unmap().
37 | *
38 | * @param log_offset loglevel offset used for logging
39 | * @param log_ctx context used for logging
40 | * @return a non negative number in case of success, a negative value
41 | * corresponding to an AVERROR error code in case of failure
42 | */
43 | int av_file_map(const char *filename, uint8_t **bufptr, size_t *size,
44 | int log_offset, void *log_ctx);
45 |
46 | /**
47 | * Unmap or free the buffer bufptr created by av_file_map().
48 | *
49 | * @param size size in bytes of bufptr, must be the same as returned
50 | * by av_file_map()
51 | */
52 | void av_file_unmap(uint8_t *bufptr, size_t size);
53 |
54 | /**
55 | * Wrapper to work around the lack of mkstemp() on mingw.
56 | * Also, tries to create file in /tmp first, if possible.
57 | * *prefix can be a character constant; *filename will be allocated internally.
58 | * @return file descriptor of opened file (or -1 on error)
59 | * and opened file name in **filename.
60 | * @note On very old libcs it is necessary to set a secure umask before
61 | * calling this, av_tempfile() cant call umask itself as it is used in
62 | * libraries and could interfere with the calling application.
63 | */
64 | int av_tempfile(const char *prefix, char **filename, int log_offset, void *log_ctx);
65 |
66 | #endif /* AVUTIL_FILE_H */
67 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/hmac.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2012 Martin Storsjo
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_HMAC_H
22 | #define AVUTIL_HMAC_H
23 |
24 | #include
25 |
26 | /**
27 | * @defgroup lavu_hmac HMAC
28 | * @ingroup lavu_crypto
29 | * @{
30 | */
31 |
32 | enum AVHMACType {
33 | AV_HMAC_MD5,
34 | AV_HMAC_SHA1,
35 | };
36 |
37 | typedef struct AVHMAC AVHMAC;
38 |
39 | /**
40 | * Allocate an AVHMAC context.
41 | * @param type The hash function used for the HMAC.
42 | */
43 | AVHMAC *av_hmac_alloc(enum AVHMACType type);
44 |
45 | /**
46 | * Free an AVHMAC context.
47 | * @param ctx The context to free, may be NULL
48 | */
49 | void av_hmac_free(AVHMAC *ctx);
50 |
51 | /**
52 | * Initialize an AVHMAC context with an authentication key.
53 | * @param ctx The HMAC context
54 | * @param key The authentication key
55 | * @param keylen The length of the key, in bytes
56 | */
57 | void av_hmac_init(AVHMAC *ctx, const uint8_t *key, unsigned int keylen);
58 |
59 | /**
60 | * Hash data with the HMAC.
61 | * @param ctx The HMAC context
62 | * @param data The data to hash
63 | * @param len The length of the data, in bytes
64 | */
65 | void av_hmac_update(AVHMAC *ctx, const uint8_t *data, unsigned int len);
66 |
67 | /**
68 | * Finish hashing and output the HMAC digest.
69 | * @param ctx The HMAC context
70 | * @param out The output buffer to write the digest into
71 | * @param outlen The length of the out buffer, in bytes
72 | * @return The number of bytes written to out, or a negative error code.
73 | */
74 | int av_hmac_final(AVHMAC *ctx, uint8_t *out, unsigned int outlen);
75 |
76 | /**
77 | * Hash an array of data with a key.
78 | * @param ctx The HMAC context
79 | * @param data The data to hash
80 | * @param len The length of the data, in bytes
81 | * @param key The authentication key
82 | * @param keylen The length of the key, in bytes
83 | * @param out The output buffer to write the digest into
84 | * @param outlen The length of the out buffer, in bytes
85 | * @return The number of bytes written to out, or a negative error code.
86 | */
87 | int av_hmac_calc(AVHMAC *ctx, const uint8_t *data, unsigned int len,
88 | const uint8_t *key, unsigned int keylen,
89 | uint8_t *out, unsigned int outlen);
90 |
91 | /**
92 | * @}
93 | */
94 |
95 | #endif /* AVUTIL_HMAC_H */
96 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/intfloat.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2011 Mans Rullgard
3 | *
4 | * This file is part of Libav.
5 | *
6 | * Libav is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * Libav is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with Libav; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_INTFLOAT_H
22 | #define AVUTIL_INTFLOAT_H
23 |
24 | #include
25 | #include "attributes.h"
26 |
27 | union av_intfloat32 {
28 | uint32_t i;
29 | float f;
30 | };
31 |
32 | union av_intfloat64 {
33 | uint64_t i;
34 | double f;
35 | };
36 |
37 | /**
38 | * Reinterpret a 32-bit integer as a float.
39 | */
40 | static av_always_inline float av_int2float(uint32_t i)
41 | {
42 | union av_intfloat32 v;
43 | v.i = i;
44 | return v.f;
45 | }
46 |
47 | /**
48 | * Reinterpret a float as a 32-bit integer.
49 | */
50 | static av_always_inline uint32_t av_float2int(float f)
51 | {
52 | union av_intfloat32 v;
53 | v.f = f;
54 | return v.i;
55 | }
56 |
57 | /**
58 | * Reinterpret a 64-bit integer as a double.
59 | */
60 | static av_always_inline double av_int2double(uint64_t i)
61 | {
62 | union av_intfloat64 v;
63 | v.i = i;
64 | return v.f;
65 | }
66 |
67 | /**
68 | * Reinterpret a double as a 64-bit integer.
69 | */
70 | static av_always_inline uint64_t av_double2int(double f)
71 | {
72 | union av_intfloat64 v;
73 | v.f = f;
74 | return v.i;
75 | }
76 |
77 | #endif /* AVUTIL_INTFLOAT_H */
78 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/intfloat_readwrite.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2005 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_INTFLOAT_READWRITE_H
22 | #define AVUTIL_INTFLOAT_READWRITE_H
23 |
24 | #include
25 | #include "attributes.h"
26 |
27 | /* IEEE 80 bits extended float */
28 | typedef struct AVExtFloat {
29 | uint8_t exponent[2];
30 | uint8_t mantissa[8];
31 | } AVExtFloat;
32 |
33 | attribute_deprecated double av_int2dbl(int64_t v) av_const;
34 | attribute_deprecated float av_int2flt(int32_t v) av_const;
35 | attribute_deprecated double av_ext2dbl(const AVExtFloat ext) av_const;
36 | attribute_deprecated int64_t av_dbl2int(double d) av_const;
37 | attribute_deprecated int32_t av_flt2int(float d) av_const;
38 | attribute_deprecated AVExtFloat av_dbl2ext(double d) av_const;
39 |
40 | #endif /* AVUTIL_INTFLOAT_READWRITE_H */
41 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/lfg.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Lagged Fibonacci PRNG
3 | * Copyright (c) 2008 Michael Niedermayer
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_LFG_H
23 | #define AVUTIL_LFG_H
24 |
25 | typedef struct AVLFG {
26 | unsigned int state[64];
27 | int index;
28 | } AVLFG;
29 |
30 | void av_lfg_init(AVLFG *c, unsigned int seed);
31 |
32 | /**
33 | * Get the next random unsigned 32-bit number using an ALFG.
34 | *
35 | * Please also consider a simple LCG like state= state*1664525+1013904223,
36 | * it may be good enough and faster for your specific use case.
37 | */
38 | static inline unsigned int av_lfg_get(AVLFG *c){
39 | c->state[c->index & 63] = c->state[(c->index-24) & 63] + c->state[(c->index-55) & 63];
40 | return c->state[c->index++ & 63];
41 | }
42 |
43 | /**
44 | * Get the next random unsigned 32-bit number using a MLFG.
45 | *
46 | * Please also consider av_lfg_get() above, it is faster.
47 | */
48 | static inline unsigned int av_mlfg_get(AVLFG *c){
49 | unsigned int a= c->state[(c->index-55) & 63];
50 | unsigned int b= c->state[(c->index-24) & 63];
51 | return c->state[c->index++ & 63] = 2*a*b+a+b;
52 | }
53 |
54 | /**
55 | * Get the next two numbers generated by a Box-Muller Gaussian
56 | * generator using the random numbers issued by lfg.
57 | *
58 | * @param out array where the two generated numbers are placed
59 | */
60 | void av_bmg_get(AVLFG *lfg, double out[2]);
61 |
62 | #endif /* AVUTIL_LFG_H */
63 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/log.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_LOG_H
22 | #define AVUTIL_LOG_H
23 |
24 | #include
25 | #include "avutil.h"
26 | #include "attributes.h"
27 |
28 | typedef enum {
29 | AV_CLASS_CATEGORY_NA = 0,
30 | AV_CLASS_CATEGORY_INPUT,
31 | AV_CLASS_CATEGORY_OUTPUT,
32 | AV_CLASS_CATEGORY_MUXER,
33 | AV_CLASS_CATEGORY_DEMUXER,
34 | AV_CLASS_CATEGORY_ENCODER,
35 | AV_CLASS_CATEGORY_DECODER,
36 | AV_CLASS_CATEGORY_FILTER,
37 | AV_CLASS_CATEGORY_BITSTREAM_FILTER,
38 | AV_CLASS_CATEGORY_SWSCALER,
39 | AV_CLASS_CATEGORY_SWRESAMPLER,
40 | AV_CLASS_CATEGORY_NB, ///< not part of ABI/API
41 | }AVClassCategory;
42 |
43 | struct AVOptionRanges;
44 |
45 | /**
46 | * Describe the class of an AVClass context structure. That is an
47 | * arbitrary struct of which the first field is a pointer to an
48 | * AVClass struct (e.g. AVCodecContext, AVFormatContext etc.).
49 | */
50 | typedef struct AVClass {
51 | /**
52 | * The name of the class; usually it is the same name as the
53 | * context structure type to which the AVClass is associated.
54 | */
55 | const char* class_name;
56 |
57 | /**
58 | * A pointer to a function which returns the name of a context
59 | * instance ctx associated with the class.
60 | */
61 | const char* (*item_name)(void* ctx);
62 |
63 | /**
64 | * a pointer to the first option specified in the class if any or NULL
65 | *
66 | * @see av_set_default_options()
67 | */
68 | const struct AVOption *option;
69 |
70 | /**
71 | * LIBAVUTIL_VERSION with which this structure was created.
72 | * This is used to allow fields to be added without requiring major
73 | * version bumps everywhere.
74 | */
75 |
76 | int version;
77 |
78 | /**
79 | * Offset in the structure where log_level_offset is stored.
80 | * 0 means there is no such variable
81 | */
82 | int log_level_offset_offset;
83 |
84 | /**
85 | * Offset in the structure where a pointer to the parent context for
86 | * logging is stored. For example a decoder could pass its AVCodecContext
87 | * to eval as such a parent context, which an av_log() implementation
88 | * could then leverage to display the parent context.
89 | * The offset can be NULL.
90 | */
91 | int parent_log_context_offset;
92 |
93 | /**
94 | * Return next AVOptions-enabled child or NULL
95 | */
96 | void* (*child_next)(void *obj, void *prev);
97 |
98 | /**
99 | * Return an AVClass corresponding to the next potential
100 | * AVOptions-enabled child.
101 | *
102 | * The difference between child_next and this is that
103 | * child_next iterates over _already existing_ objects, while
104 | * child_class_next iterates over _all possible_ children.
105 | */
106 | const struct AVClass* (*child_class_next)(const struct AVClass *prev);
107 |
108 | /**
109 | * Category used for visualization (like color)
110 | * This is only set if the category is equal for all objects using this class.
111 | * available since version (51 << 16 | 56 << 8 | 100)
112 | */
113 | AVClassCategory category;
114 |
115 | /**
116 | * Callback to return the category.
117 | * available since version (51 << 16 | 59 << 8 | 100)
118 | */
119 | AVClassCategory (*get_category)(void* ctx);
120 |
121 | /**
122 | * Callback to return the supported/allowed ranges.
123 | * available since version (52.12)
124 | */
125 | int (*query_ranges)(struct AVOptionRanges **, void *obj, const char *key, int flags);
126 | } AVClass;
127 |
128 | /* av_log API */
129 |
130 | #define AV_LOG_QUIET -8
131 |
132 | /**
133 | * Something went really wrong and we will crash now.
134 | */
135 | #define AV_LOG_PANIC 0
136 |
137 | /**
138 | * Something went wrong and recovery is not possible.
139 | * For example, no header was found for a format which depends
140 | * on headers or an illegal combination of parameters is used.
141 | */
142 | #define AV_LOG_FATAL 8
143 |
144 | /**
145 | * Something went wrong and cannot losslessly be recovered.
146 | * However, not all future data is affected.
147 | */
148 | #define AV_LOG_ERROR 16
149 |
150 | /**
151 | * Something somehow does not look correct. This may or may not
152 | * lead to problems. An example would be the use of '-vstrict -2'.
153 | */
154 | #define AV_LOG_WARNING 24
155 |
156 | #define AV_LOG_INFO 32
157 | #define AV_LOG_VERBOSE 40
158 |
159 | /**
160 | * Stuff which is only useful for libav* developers.
161 | */
162 | #define AV_LOG_DEBUG 48
163 |
164 | #define AV_LOG_MAX_OFFSET (AV_LOG_DEBUG - AV_LOG_QUIET)
165 |
166 | /**
167 | * Send the specified message to the log if the level is less than or equal
168 | * to the current av_log_level. By default, all logging messages are sent to
169 | * stderr. This behavior can be altered by setting a different av_vlog callback
170 | * function.
171 | *
172 | * @param avcl A pointer to an arbitrary struct of which the first field is a
173 | * pointer to an AVClass struct.
174 | * @param level The importance level of the message, lower values signifying
175 | * higher importance.
176 | * @param fmt The format string (printf-compatible) that specifies how
177 | * subsequent arguments are converted to output.
178 | * @see av_vlog
179 | */
180 | void av_log(void *avcl, int level, const char *fmt, ...) av_printf_format(3, 4);
181 |
182 | void av_vlog(void *avcl, int level, const char *fmt, va_list);
183 | int av_log_get_level(void);
184 | void av_log_set_level(int);
185 | void av_log_set_callback(void (*)(void*, int, const char*, va_list));
186 | void av_log_default_callback(void* ptr, int level, const char* fmt, va_list vl);
187 | const char* av_default_item_name(void* ctx);
188 | AVClassCategory av_default_get_category(void *ptr);
189 |
190 | /**
191 | * Format a line of log the same way as the default callback.
192 | * @param line buffer to receive the formated line
193 | * @param line_size size of the buffer
194 | * @param print_prefix used to store whether the prefix must be printed;
195 | * must point to a persistent integer initially set to 1
196 | */
197 | void av_log_format_line(void *ptr, int level, const char *fmt, va_list vl,
198 | char *line, int line_size, int *print_prefix);
199 |
200 | /**
201 | * av_dlog macros
202 | * Useful to print debug messages that shouldn't get compiled in normally.
203 | */
204 |
205 | #ifdef DEBUG
206 | # define av_dlog(pctx, ...) av_log(pctx, AV_LOG_DEBUG, __VA_ARGS__)
207 | #else
208 | # define av_dlog(pctx, ...) do { if (0) av_log(pctx, AV_LOG_DEBUG, __VA_ARGS__); } while (0)
209 | #endif
210 |
211 | /**
212 | * Skip repeated messages, this requires the user app to use av_log() instead of
213 | * (f)printf as the 2 would otherwise interfere and lead to
214 | * "Last message repeated x times" messages below (f)printf messages with some
215 | * bad luck.
216 | * Also to receive the last, "last repeated" line if any, the user app must
217 | * call av_log(NULL, AV_LOG_QUIET, "%s", ""); at the end
218 | */
219 | #define AV_LOG_SKIP_REPEATED 1
220 | void av_log_set_flags(int arg);
221 |
222 | #endif /* AVUTIL_LOG_H */
223 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/lzo.h:
--------------------------------------------------------------------------------
1 | /*
2 | * LZO 1x decompression
3 | * copyright (c) 2006 Reimar Doeffinger
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_LZO_H
23 | #define AVUTIL_LZO_H
24 |
25 | /**
26 | * @defgroup lavu_lzo LZO
27 | * @ingroup lavu_crypto
28 | *
29 | * @{
30 | */
31 |
32 | #include
33 |
34 | /** @name Error flags returned by av_lzo1x_decode
35 | * @{ */
36 | /// end of the input buffer reached before decoding finished
37 | #define AV_LZO_INPUT_DEPLETED 1
38 | /// decoded data did not fit into output buffer
39 | #define AV_LZO_OUTPUT_FULL 2
40 | /// a reference to previously decoded data was wrong
41 | #define AV_LZO_INVALID_BACKPTR 4
42 | /// a non-specific error in the compressed bitstream
43 | #define AV_LZO_ERROR 8
44 | /** @} */
45 |
46 | #define AV_LZO_INPUT_PADDING 8
47 | #define AV_LZO_OUTPUT_PADDING 12
48 |
49 | /**
50 | * @brief Decodes LZO 1x compressed data.
51 | * @param out output buffer
52 | * @param outlen size of output buffer, number of bytes left are returned here
53 | * @param in input buffer
54 | * @param inlen size of input buffer, number of bytes left are returned here
55 | * @return 0 on success, otherwise a combination of the error flags above
56 | *
57 | * Make sure all buffers are appropriately padded, in must provide
58 | * AV_LZO_INPUT_PADDING, out must provide AV_LZO_OUTPUT_PADDING additional bytes.
59 | */
60 | int av_lzo1x_decode(void *out, int *outlen, const void *in, int *inlen);
61 |
62 | /**
63 | * @}
64 | */
65 |
66 | #endif /* AVUTIL_LZO_H */
67 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/mathematics.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2005-2012 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_MATHEMATICS_H
22 | #define AVUTIL_MATHEMATICS_H
23 |
24 | #include
25 | #include
26 | #include "attributes.h"
27 | #include "rational.h"
28 | #include "intfloat.h"
29 |
30 | #ifndef M_E
31 | #define M_E 2.7182818284590452354 /* e */
32 | #endif
33 | #ifndef M_LN2
34 | #define M_LN2 0.69314718055994530942 /* log_e 2 */
35 | #endif
36 | #ifndef M_LN10
37 | #define M_LN10 2.30258509299404568402 /* log_e 10 */
38 | #endif
39 | #ifndef M_LOG2_10
40 | #define M_LOG2_10 3.32192809488736234787 /* log_2 10 */
41 | #endif
42 | #ifndef M_PHI
43 | #define M_PHI 1.61803398874989484820 /* phi / golden ratio */
44 | #endif
45 | #ifndef M_PI
46 | #define M_PI 3.14159265358979323846 /* pi */
47 | #endif
48 | #ifndef M_SQRT1_2
49 | #define M_SQRT1_2 0.70710678118654752440 /* 1/sqrt(2) */
50 | #endif
51 | #ifndef M_SQRT2
52 | #define M_SQRT2 1.41421356237309504880 /* sqrt(2) */
53 | #endif
54 | #ifndef NAN
55 | #define NAN av_int2float(0x7fc00000)
56 | #endif
57 | #ifndef INFINITY
58 | #define INFINITY av_int2float(0x7f800000)
59 | #endif
60 |
61 | /**
62 | * @addtogroup lavu_math
63 | * @{
64 | */
65 |
66 |
67 | enum AVRounding {
68 | AV_ROUND_ZERO = 0, ///< Round toward zero.
69 | AV_ROUND_INF = 1, ///< Round away from zero.
70 | AV_ROUND_DOWN = 2, ///< Round toward -infinity.
71 | AV_ROUND_UP = 3, ///< Round toward +infinity.
72 | AV_ROUND_NEAR_INF = 5, ///< Round to nearest and halfway cases away from zero.
73 | AV_ROUND_PASS_MINMAX = 8192, ///< Flag to pass INT64_MIN/MAX through instead of rescaling, this avoids special cases for AV_NOPTS_VALUE
74 | };
75 |
76 | /**
77 | * Return the greatest common divisor of a and b.
78 | * If both a and b are 0 or either or both are <0 then behavior is
79 | * undefined.
80 | */
81 | int64_t av_const av_gcd(int64_t a, int64_t b);
82 |
83 | /**
84 | * Rescale a 64-bit integer with rounding to nearest.
85 | * A simple a*b/c isn't possible as it can overflow.
86 | */
87 | int64_t av_rescale(int64_t a, int64_t b, int64_t c) av_const;
88 |
89 | /**
90 | * Rescale a 64-bit integer with specified rounding.
91 | * A simple a*b/c isn't possible as it can overflow.
92 | *
93 | * @return rescaled value a, or if AV_ROUND_PASS_MINMAX is set and a is
94 | * INT64_MIN or INT64_MAX then a is passed through unchanged.
95 | */
96 | int64_t av_rescale_rnd(int64_t a, int64_t b, int64_t c, enum AVRounding) av_const;
97 |
98 | /**
99 | * Rescale a 64-bit integer by 2 rational numbers.
100 | */
101 | int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq) av_const;
102 |
103 | /**
104 | * Rescale a 64-bit integer by 2 rational numbers with specified rounding.
105 | *
106 | * @return rescaled value a, or if AV_ROUND_PASS_MINMAX is set and a is
107 | * INT64_MIN or INT64_MAX then a is passed through unchanged.
108 | */
109 | int64_t av_rescale_q_rnd(int64_t a, AVRational bq, AVRational cq,
110 | enum AVRounding) av_const;
111 |
112 | /**
113 | * Compare 2 timestamps each in its own timebases.
114 | * The result of the function is undefined if one of the timestamps
115 | * is outside the int64_t range when represented in the others timebase.
116 | * @return -1 if ts_a is before ts_b, 1 if ts_a is after ts_b or 0 if they represent the same position
117 | */
118 | int av_compare_ts(int64_t ts_a, AVRational tb_a, int64_t ts_b, AVRational tb_b);
119 |
120 | /**
121 | * Compare 2 integers modulo mod.
122 | * That is we compare integers a and b for which only the least
123 | * significant log2(mod) bits are known.
124 | *
125 | * @param mod must be a power of 2
126 | * @return a negative value if a is smaller than b
127 | * a positive value if a is greater than b
128 | * 0 if a equals b
129 | */
130 | int64_t av_compare_mod(uint64_t a, uint64_t b, uint64_t mod);
131 |
132 | /**
133 | * Rescale a timestamp while preserving known durations.
134 | *
135 | * @param in_ts Input timestamp
136 | * @param in_tb Input timesbase
137 | * @param fs_tb Duration and *last timebase
138 | * @param duration duration till the next call
139 | * @param out_tb Output timesbase
140 | */
141 | int64_t av_rescale_delta(AVRational in_tb, int64_t in_ts, AVRational fs_tb, int duration, int64_t *last, AVRational out_tb);
142 |
143 | /**
144 | * @}
145 | */
146 |
147 | #endif /* AVUTIL_MATHEMATICS_H */
148 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/md5.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2006 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_MD5_H
22 | #define AVUTIL_MD5_H
23 |
24 | #include
25 |
26 | #include "attributes.h"
27 | #include "version.h"
28 |
29 | /**
30 | * @defgroup lavu_md5 MD5
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | extern const int av_md5_size;
36 |
37 | struct AVMD5;
38 |
39 | struct AVMD5 *av_md5_alloc(void);
40 | void av_md5_init(struct AVMD5 *ctx);
41 | void av_md5_update(struct AVMD5 *ctx, const uint8_t *src, const int len);
42 | void av_md5_final(struct AVMD5 *ctx, uint8_t *dst);
43 | void av_md5_sum(uint8_t *dst, const uint8_t *src, const int len);
44 |
45 | /**
46 | * @}
47 | */
48 |
49 | #endif /* AVUTIL_MD5_H */
50 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/parseutils.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef AVUTIL_PARSEUTILS_H
20 | #define AVUTIL_PARSEUTILS_H
21 |
22 | #include
23 |
24 | #include "rational.h"
25 |
26 | /**
27 | * @file
28 | * misc parsing utilities
29 | */
30 |
31 | /**
32 | * Parse str and store the parsed ratio in q.
33 | *
34 | * Note that a ratio with infinite (1/0) or negative value is
35 | * considered valid, so you should check on the returned value if you
36 | * want to exclude those values.
37 | *
38 | * The undefined value can be expressed using the "0:0" string.
39 | *
40 | * @param[in,out] q pointer to the AVRational which will contain the ratio
41 | * @param[in] str the string to parse: it has to be a string in the format
42 | * num:den, a float number or an expression
43 | * @param[in] max the maximum allowed numerator and denominator
44 | * @param[in] log_offset log level offset which is applied to the log
45 | * level of log_ctx
46 | * @param[in] log_ctx parent logging context
47 | * @return >= 0 on success, a negative error code otherwise
48 | */
49 | int av_parse_ratio(AVRational *q, const char *str, int max,
50 | int log_offset, void *log_ctx);
51 |
52 | #define av_parse_ratio_quiet(rate, str, max) \
53 | av_parse_ratio(rate, str, max, AV_LOG_MAX_OFFSET, NULL)
54 |
55 | /**
56 | * Parse str and put in width_ptr and height_ptr the detected values.
57 | *
58 | * @param[in,out] width_ptr pointer to the variable which will contain the detected
59 | * width value
60 | * @param[in,out] height_ptr pointer to the variable which will contain the detected
61 | * height value
62 | * @param[in] str the string to parse: it has to be a string in the format
63 | * width x height or a valid video size abbreviation.
64 | * @return >= 0 on success, a negative error code otherwise
65 | */
66 | int av_parse_video_size(int *width_ptr, int *height_ptr, const char *str);
67 |
68 | /**
69 | * Parse str and store the detected values in *rate.
70 | *
71 | * @param[in,out] rate pointer to the AVRational which will contain the detected
72 | * frame rate
73 | * @param[in] str the string to parse: it has to be a string in the format
74 | * rate_num / rate_den, a float number or a valid video rate abbreviation
75 | * @return >= 0 on success, a negative error code otherwise
76 | */
77 | int av_parse_video_rate(AVRational *rate, const char *str);
78 |
79 | /**
80 | * Put the RGBA values that correspond to color_string in rgba_color.
81 | *
82 | * @param color_string a string specifying a color. It can be the name of
83 | * a color (case insensitive match) or a [0x|#]RRGGBB[AA] sequence,
84 | * possibly followed by "@" and a string representing the alpha
85 | * component.
86 | * The alpha component may be a string composed by "0x" followed by an
87 | * hexadecimal number or a decimal number between 0.0 and 1.0, which
88 | * represents the opacity value (0x00/0.0 means completely transparent,
89 | * 0xff/1.0 completely opaque).
90 | * If the alpha component is not specified then 0xff is assumed.
91 | * The string "random" will result in a random color.
92 | * @param slen length of the initial part of color_string containing the
93 | * color. It can be set to -1 if color_string is a null terminated string
94 | * containing nothing else than the color.
95 | * @return >= 0 in case of success, a negative value in case of
96 | * failure (for example if color_string cannot be parsed).
97 | */
98 | int av_parse_color(uint8_t *rgba_color, const char *color_string, int slen,
99 | void *log_ctx);
100 |
101 | /**
102 | * Parse timestr and return in *time a corresponding number of
103 | * microseconds.
104 | *
105 | * @param timeval puts here the number of microseconds corresponding
106 | * to the string in timestr. If the string represents a duration, it
107 | * is the number of microseconds contained in the time interval. If
108 | * the string is a date, is the number of microseconds since 1st of
109 | * January, 1970 up to the time of the parsed date. If timestr cannot
110 | * be successfully parsed, set *time to INT64_MIN.
111 |
112 | * @param timestr a string representing a date or a duration.
113 | * - If a date the syntax is:
114 | * @code
115 | * [{YYYY-MM-DD|YYYYMMDD}[T|t| ]]{{HH:MM:SS[.m...]]]}|{HHMMSS[.m...]]]}}[Z]
116 | * now
117 | * @endcode
118 | * If the value is "now" it takes the current time.
119 | * Time is local time unless Z is appended, in which case it is
120 | * interpreted as UTC.
121 | * If the year-month-day part is not specified it takes the current
122 | * year-month-day.
123 | * - If a duration the syntax is:
124 | * @code
125 | * [-][HH:]MM:SS[.m...]
126 | * [-]S+[.m...]
127 | * @endcode
128 | * @param duration flag which tells how to interpret timestr, if not
129 | * zero timestr is interpreted as a duration, otherwise as a date
130 | * @return 0 in case of success, a negative value corresponding to an
131 | * AVERROR code otherwise
132 | */
133 | int av_parse_time(int64_t *timeval, const char *timestr, int duration);
134 |
135 | /**
136 | * Parse the input string p according to the format string fmt and
137 | * store its results in the structure dt.
138 | * This implementation supports only a subset of the formats supported
139 | * by the standard strptime().
140 | *
141 | * In particular it actually supports the parameters:
142 | * - %H: the hour as a decimal number, using a 24-hour clock, in the
143 | * range '00' through '23'
144 | * - %J: hours as a decimal number, in the range '0' through INT_MAX
145 | * - %M: the minute as a decimal number, using a 24-hour clock, in the
146 | * range '00' through '59'
147 | * - %S: the second as a decimal number, using a 24-hour clock, in the
148 | * range '00' through '59'
149 | * - %Y: the year as a decimal number, using the Gregorian calendar
150 | * - %m: the month as a decimal number, in the range '1' through '12'
151 | * - %d: the day of the month as a decimal number, in the range '1'
152 | * through '31'
153 | * - %%: a literal '%'
154 | *
155 | * @return a pointer to the first character not processed in this
156 | * function call, or NULL in case the function fails to match all of
157 | * the fmt string and therefore an error occurred
158 | */
159 | char *av_small_strptime(const char *p, const char *fmt, struct tm *dt);
160 |
161 | /**
162 | * Attempt to find a specific tag in a URL.
163 | *
164 | * syntax: '?tag1=val1&tag2=val2...'. Little URL decoding is done.
165 | * Return 1 if found.
166 | */
167 | int av_find_info_tag(char *arg, int arg_size, const char *tag1, const char *info);
168 |
169 | /**
170 | * Convert the decomposed UTC time in tm to a time_t value.
171 | */
172 | time_t av_timegm(struct tm *tm);
173 |
174 | #endif /* AVUTIL_PARSEUTILS_H */
175 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/random_seed.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2009 Baptiste Coudurier
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_RANDOM_SEED_H
22 | #define AVUTIL_RANDOM_SEED_H
23 |
24 | #include
25 | /**
26 | * @addtogroup lavu_crypto
27 | * @{
28 | */
29 |
30 | /**
31 | * Get a seed to use in conjunction with random functions.
32 | * This function tries to provide a good seed at a best effort bases.
33 | * Its possible to call this function multiple times if more bits are needed.
34 | * It can be quite slow, which is why it should only be used as seed for a faster
35 | * PRNG. The quality of the seed depends on the platform.
36 | */
37 | uint32_t av_get_random_seed(void);
38 |
39 | /**
40 | * @}
41 | */
42 |
43 | #endif /* AVUTIL_RANDOM_SEED_H */
44 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/rational.h:
--------------------------------------------------------------------------------
1 | /*
2 | * rational numbers
3 | * Copyright (c) 2003 Michael Niedermayer
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | /**
23 | * @file
24 | * rational numbers
25 | * @author Michael Niedermayer
26 | */
27 |
28 | #ifndef AVUTIL_RATIONAL_H
29 | #define AVUTIL_RATIONAL_H
30 |
31 | #include
32 | #include
33 | #include "attributes.h"
34 |
35 | /**
36 | * @addtogroup lavu_math
37 | * @{
38 | */
39 |
40 | /**
41 | * rational number numerator/denominator
42 | */
43 | typedef struct AVRational{
44 | int num; ///< numerator
45 | int den; ///< denominator
46 | } AVRational;
47 |
48 | /**
49 | * Compare two rationals.
50 | * @param a first rational
51 | * @param b second rational
52 | * @return 0 if a==b, 1 if a>b, -1 if a>63)|1;
59 | else if(b.den && a.den) return 0;
60 | else if(a.num && b.num) return (a.num>>31) - (b.num>>31);
61 | else return INT_MIN;
62 | }
63 |
64 | /**
65 | * Convert rational to double.
66 | * @param a rational to convert
67 | * @return (double) a
68 | */
69 | static inline double av_q2d(AVRational a){
70 | return a.num / (double) a.den;
71 | }
72 |
73 | /**
74 | * Reduce a fraction.
75 | * This is useful for framerate calculations.
76 | * @param dst_num destination numerator
77 | * @param dst_den destination denominator
78 | * @param num source numerator
79 | * @param den source denominator
80 | * @param max the maximum allowed for dst_num & dst_den
81 | * @return 1 if exact, 0 otherwise
82 | */
83 | int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max);
84 |
85 | /**
86 | * Multiply two rationals.
87 | * @param b first rational
88 | * @param c second rational
89 | * @return b*c
90 | */
91 | AVRational av_mul_q(AVRational b, AVRational c) av_const;
92 |
93 | /**
94 | * Divide one rational by another.
95 | * @param b first rational
96 | * @param c second rational
97 | * @return b/c
98 | */
99 | AVRational av_div_q(AVRational b, AVRational c) av_const;
100 |
101 | /**
102 | * Add two rationals.
103 | * @param b first rational
104 | * @param c second rational
105 | * @return b+c
106 | */
107 | AVRational av_add_q(AVRational b, AVRational c) av_const;
108 |
109 | /**
110 | * Subtract one rational from another.
111 | * @param b first rational
112 | * @param c second rational
113 | * @return b-c
114 | */
115 | AVRational av_sub_q(AVRational b, AVRational c) av_const;
116 |
117 | /**
118 | * Invert a rational.
119 | * @param q value
120 | * @return 1 / q
121 | */
122 | static av_always_inline AVRational av_inv_q(AVRational q)
123 | {
124 | AVRational r = { q.den, q.num };
125 | return r;
126 | }
127 |
128 | /**
129 | * Convert a double precision floating point number to a rational.
130 | * inf is expressed as {1,0} or {-1,0} depending on the sign.
131 | *
132 | * @param d double to convert
133 | * @param max the maximum allowed numerator and denominator
134 | * @return (AVRational) d
135 | */
136 | AVRational av_d2q(double d, int max) av_const;
137 |
138 | /**
139 | * @return 1 if q1 is nearer to q than q2, -1 if q2 is nearer
140 | * than q1, 0 if they have the same distance.
141 | */
142 | int av_nearer_q(AVRational q, AVRational q1, AVRational q2);
143 |
144 | /**
145 | * Find the nearest value in q_list to q.
146 | * @param q_list an array of rationals terminated by {0, 0}
147 | * @return the index of the nearest value found in the array
148 | */
149 | int av_find_nearest_q_idx(AVRational q, const AVRational* q_list);
150 |
151 | /**
152 | * @}
153 | */
154 |
155 | #endif /* AVUTIL_RATIONAL_H */
156 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/sha.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2007 Michael Niedermayer
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_SHA_H
22 | #define AVUTIL_SHA_H
23 |
24 | #include
25 |
26 | #include "attributes.h"
27 | #include "version.h"
28 |
29 | /**
30 | * @defgroup lavu_sha SHA
31 | * @ingroup lavu_crypto
32 | * @{
33 | */
34 |
35 | extern const int av_sha_size;
36 |
37 | struct AVSHA;
38 |
39 | /**
40 | * Allocate an AVSHA context.
41 | */
42 | struct AVSHA *av_sha_alloc(void);
43 |
44 | /**
45 | * Initialize SHA-1 or SHA-2 hashing.
46 | *
47 | * @param context pointer to the function context (of size av_sha_size)
48 | * @param bits number of bits in digest (SHA-1 - 160 bits, SHA-2 224 or 256 bits)
49 | * @return zero if initialization succeeded, -1 otherwise
50 | */
51 | int av_sha_init(struct AVSHA* context, int bits);
52 |
53 | /**
54 | * Update hash value.
55 | *
56 | * @param context hash function context
57 | * @param data input data to update hash with
58 | * @param len input data length
59 | */
60 | void av_sha_update(struct AVSHA* context, const uint8_t* data, unsigned int len);
61 |
62 | /**
63 | * Finish hashing and output digest value.
64 | *
65 | * @param context hash function context
66 | * @param digest buffer where output digest value is stored
67 | */
68 | void av_sha_final(struct AVSHA* context, uint8_t *digest);
69 |
70 | /**
71 | * @}
72 | */
73 |
74 | #endif /* AVUTIL_SHA_H */
75 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/time.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2000-2003 Fabrice Bellard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_TIME_H
22 | #define AVUTIL_TIME_H
23 |
24 | #include
25 |
26 | /**
27 | * Get the current time in microseconds.
28 | */
29 | int64_t av_gettime(void);
30 |
31 | /**
32 | * Sleep for a period of time. Although the duration is expressed in
33 | * microseconds, the actual delay may be rounded to the precision of the
34 | * system timer.
35 | *
36 | * @param usec Number of microseconds to sleep.
37 | * @return zero on success or (negative) error code.
38 | */
39 | int av_usleep(unsigned usec);
40 |
41 | #endif /* AVUTIL_TIME_H */
42 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/timecode.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (c) 2006 Smartjog S.A.S, Baptiste Coudurier
3 | * Copyright (c) 2011-2012 Smartjog S.A.S, Clément Bœsch
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | /**
23 | * @file
24 | * Timecode helpers header
25 | */
26 |
27 | #ifndef AVUTIL_TIMECODE_H
28 | #define AVUTIL_TIMECODE_H
29 |
30 | #include
31 | #include "rational.h"
32 |
33 | #define AV_TIMECODE_STR_SIZE 16
34 |
35 | enum AVTimecodeFlag {
36 | AV_TIMECODE_FLAG_DROPFRAME = 1<<0, ///< timecode is drop frame
37 | AV_TIMECODE_FLAG_24HOURSMAX = 1<<1, ///< timecode wraps after 24 hours
38 | AV_TIMECODE_FLAG_ALLOWNEGATIVE = 1<<2, ///< negative time values are allowed
39 | };
40 |
41 | typedef struct {
42 | int start; ///< timecode frame start (first base frame number)
43 | uint32_t flags; ///< flags such as drop frame, +24 hours support, ...
44 | AVRational rate; ///< frame rate in rational form
45 | unsigned fps; ///< frame per second; must be consistent with the rate field
46 | } AVTimecode;
47 |
48 | /**
49 | * Adjust frame number for NTSC drop frame time code.
50 | *
51 | * @param framenum frame number to adjust
52 | * @param fps frame per second, 30 or 60
53 | * @return adjusted frame number
54 | * @warning adjustment is only valid in NTSC 29.97 and 59.94
55 | */
56 | int av_timecode_adjust_ntsc_framenum2(int framenum, int fps);
57 |
58 | /**
59 | * Convert frame number to SMPTE 12M binary representation.
60 | *
61 | * @param tc timecode data correctly initialized
62 | * @param framenum frame number
63 | * @return the SMPTE binary representation
64 | *
65 | * @note Frame number adjustment is automatically done in case of drop timecode,
66 | * you do NOT have to call av_timecode_adjust_ntsc_framenum2().
67 | * @note The frame number is relative to tc->start.
68 | * @note Color frame (CF), binary group flags (BGF) and biphase mark polarity
69 | * correction (PC) bits are set to zero.
70 | */
71 | uint32_t av_timecode_get_smpte_from_framenum(const AVTimecode *tc, int framenum);
72 |
73 | /**
74 | * Load timecode string in buf.
75 | *
76 | * @param buf destination buffer, must be at least AV_TIMECODE_STR_SIZE long
77 | * @param tc timecode data correctly initialized
78 | * @param framenum frame number
79 | * @return the buf parameter
80 | *
81 | * @note Timecode representation can be a negative timecode and have more than
82 | * 24 hours, but will only be honored if the flags are correctly set.
83 | * @note The frame number is relative to tc->start.
84 | */
85 | char *av_timecode_make_string(const AVTimecode *tc, char *buf, int framenum);
86 |
87 | /**
88 | * Get the timecode string from the SMPTE timecode format.
89 | *
90 | * @param buf destination buffer, must be at least AV_TIMECODE_STR_SIZE long
91 | * @param tcsmpte the 32-bit SMPTE timecode
92 | * @param prevent_df prevent the use of a drop flag when it is known the DF bit
93 | * is arbitrary
94 | * @return the buf parameter
95 | */
96 | char *av_timecode_make_smpte_tc_string(char *buf, uint32_t tcsmpte, int prevent_df);
97 |
98 | /**
99 | * Get the timecode string from the 25-bit timecode format (MPEG GOP format).
100 | *
101 | * @param buf destination buffer, must be at least AV_TIMECODE_STR_SIZE long
102 | * @param tc25bit the 25-bits timecode
103 | * @return the buf parameter
104 | */
105 | char *av_timecode_make_mpeg_tc_string(char *buf, uint32_t tc25bit);
106 |
107 | /**
108 | * Init a timecode struct with the passed parameters.
109 | *
110 | * @param log_ctx a pointer to an arbitrary struct of which the first field
111 | * is a pointer to an AVClass struct (used for av_log)
112 | * @param tc pointer to an allocated AVTimecode
113 | * @param rate frame rate in rational form
114 | * @param flags miscellaneous flags such as drop frame, +24 hours, ...
115 | * (see AVTimecodeFlag)
116 | * @param frame_start the first frame number
117 | * @return 0 on success, AVERROR otherwise
118 | */
119 | int av_timecode_init(AVTimecode *tc, AVRational rate, int flags, int frame_start, void *log_ctx);
120 |
121 | /**
122 | * Parse timecode representation (hh:mm:ss[:;.]ff).
123 | *
124 | * @param log_ctx a pointer to an arbitrary struct of which the first field is a
125 | * pointer to an AVClass struct (used for av_log).
126 | * @param tc pointer to an allocated AVTimecode
127 | * @param rate frame rate in rational form
128 | * @param str timecode string which will determine the frame start
129 | * @return 0 on success, AVERROR otherwise
130 | */
131 | int av_timecode_init_from_string(AVTimecode *tc, AVRational rate, const char *str, void *log_ctx);
132 |
133 | /**
134 | * Check if the timecode feature is available for the given frame rate
135 | *
136 | * @return 0 if supported, <0 otherwise
137 | */
138 | int av_timecode_check_frame_rate(AVRational rate);
139 |
140 | #endif /* AVUTIL_TIMECODE_H */
141 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/timestamp.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | /**
20 | * @file
21 | * timestamp utils, mostly useful for debugging/logging purposes
22 | */
23 |
24 | #ifndef AVUTIL_TIMESTAMP_H
25 | #define AVUTIL_TIMESTAMP_H
26 |
27 | #include "common.h"
28 |
29 | #define AV_TS_MAX_STRING_SIZE 32
30 |
31 | /**
32 | * Fill the provided buffer with a string containing a timestamp
33 | * representation.
34 | *
35 | * @param buf a buffer with size in bytes of at least AV_TS_MAX_STRING_SIZE
36 | * @param ts the timestamp to represent
37 | * @return the buffer in input
38 | */
39 | static inline char *av_ts_make_string(char *buf, int64_t ts)
40 | {
41 | if (ts == AV_NOPTS_VALUE) snprintf(buf, AV_TS_MAX_STRING_SIZE, "NOPTS");
42 | else snprintf(buf, AV_TS_MAX_STRING_SIZE, "%"PRId64"", ts);
43 | return buf;
44 | }
45 |
46 | /**
47 | * Convenience macro, the return value should be used only directly in
48 | * function arguments but never stand-alone.
49 | */
50 | #define av_ts2str(ts) av_ts_make_string((char[AV_TS_MAX_STRING_SIZE]){0}, ts)
51 |
52 | /**
53 | * Fill the provided buffer with a string containing a timestamp time
54 | * representation.
55 | *
56 | * @param buf a buffer with size in bytes of at least AV_TS_MAX_STRING_SIZE
57 | * @param ts the timestamp to represent
58 | * @param tb the timebase of the timestamp
59 | * @return the buffer in input
60 | */
61 | static inline char *av_ts_make_time_string(char *buf, int64_t ts, AVRational *tb)
62 | {
63 | if (ts == AV_NOPTS_VALUE) snprintf(buf, AV_TS_MAX_STRING_SIZE, "NOPTS");
64 | else snprintf(buf, AV_TS_MAX_STRING_SIZE, "%.6g", av_q2d(*tb) * ts);
65 | return buf;
66 | }
67 |
68 | /**
69 | * Convenience macro, the return value should be used only directly in
70 | * function arguments but never stand-alone.
71 | */
72 | #define av_ts2timestr(ts, tb) av_ts_make_time_string((char[AV_TS_MAX_STRING_SIZE]){0}, ts, tb)
73 |
74 | #endif /* AVUTIL_TIMESTAMP_H */
75 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * copyright (c) 2003 Fabrice Bellard
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef AVUTIL_VERSION_H
22 | #define AVUTIL_VERSION_H
23 |
24 | /**
25 | * @defgroup preproc_misc Preprocessor String Macros
26 | *
27 | * String manipulation macros
28 | *
29 | * @{
30 | */
31 |
32 | #define AV_STRINGIFY(s) AV_TOSTRING(s)
33 | #define AV_TOSTRING(s) #s
34 |
35 | #define AV_GLUE(a, b) a ## b
36 | #define AV_JOIN(a, b) AV_GLUE(a, b)
37 |
38 | #define AV_PRAGMA(s) _Pragma(#s)
39 |
40 | /**
41 | * @}
42 | */
43 |
44 | /**
45 | * @defgroup version_utils Library Version Macros
46 | *
47 | * Useful to check and match library version in order to maintain
48 | * backward compatibility.
49 | *
50 | * @{
51 | */
52 |
53 | #define AV_VERSION_INT(a, b, c) (a<<16 | b<<8 | c)
54 | #define AV_VERSION_DOT(a, b, c) a ##.## b ##.## c
55 | #define AV_VERSION(a, b, c) AV_VERSION_DOT(a, b, c)
56 |
57 | /**
58 | * @}
59 | */
60 |
61 |
62 | /**
63 | * @file
64 | * @ingroup lavu
65 | * Libavutil version macros
66 | */
67 |
68 | /**
69 | * @defgroup lavu_ver Version and Build diagnostics
70 | *
71 | * Macros and function useful to check at compiletime and at runtime
72 | * which version of libavutil is in use.
73 | *
74 | * @{
75 | */
76 |
77 | #define LIBAVUTIL_VERSION_MAJOR 52
78 | #define LIBAVUTIL_VERSION_MINOR 24
79 | #define LIBAVUTIL_VERSION_MICRO 100
80 |
81 | #define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
82 | LIBAVUTIL_VERSION_MINOR, \
83 | LIBAVUTIL_VERSION_MICRO)
84 | #define LIBAVUTIL_VERSION AV_VERSION(LIBAVUTIL_VERSION_MAJOR, \
85 | LIBAVUTIL_VERSION_MINOR, \
86 | LIBAVUTIL_VERSION_MICRO)
87 | #define LIBAVUTIL_BUILD LIBAVUTIL_VERSION_INT
88 |
89 | #define LIBAVUTIL_IDENT "Lavu" AV_STRINGIFY(LIBAVUTIL_VERSION)
90 |
91 | /**
92 | * @}
93 | *
94 | * @defgroup depr_guards Deprecation guards
95 | * FF_API_* defines may be placed below to indicate public API that will be
96 | * dropped at a future version bump. The defines themselves are not part of
97 | * the public API and may change, break or disappear at any time.
98 | *
99 | * @{
100 | */
101 |
102 | #ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
103 | #define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 53)
104 | #endif
105 | #ifndef FF_API_FIND_OPT
106 | #define FF_API_FIND_OPT (LIBAVUTIL_VERSION_MAJOR < 53)
107 | #endif
108 | #ifndef FF_API_OLD_AVOPTIONS
109 | #define FF_API_OLD_AVOPTIONS (LIBAVUTIL_VERSION_MAJOR < 53)
110 | #endif
111 | #ifndef FF_API_PIX_FMT
112 | #define FF_API_PIX_FMT (LIBAVUTIL_VERSION_MAJOR < 53)
113 | #endif
114 | #ifndef FF_API_CONTEXT_SIZE
115 | #define FF_API_CONTEXT_SIZE (LIBAVUTIL_VERSION_MAJOR < 53)
116 | #endif
117 | #ifndef FF_API_PIX_FMT_DESC
118 | #define FF_API_PIX_FMT_DESC (LIBAVUTIL_VERSION_MAJOR < 53)
119 | #endif
120 | #ifndef FF_API_AV_REVERSE
121 | #define FF_API_AV_REVERSE (LIBAVUTIL_VERSION_MAJOR < 53)
122 | #endif
123 | #ifndef FF_API_AUDIOCONVERT
124 | #define FF_API_AUDIOCONVERT (LIBAVUTIL_VERSION_MAJOR < 53)
125 | #endif
126 | #ifndef FF_API_CPU_FLAG_MMX2
127 | #define FF_API_CPU_FLAG_MMX2 (LIBAVUTIL_VERSION_MAJOR < 53)
128 | #endif
129 | #ifndef FF_API_SAMPLES_UTILS_RETURN_ZERO
130 | #define FF_API_SAMPLES_UTILS_RETURN_ZERO (LIBAVUTIL_VERSION_MAJOR < 53)
131 | #endif
132 | #ifndef FF_API_LLS_PRIVATE
133 | #define FF_API_LLS_PRIVATE (LIBAVUTIL_VERSION_MAJOR < 53)
134 | #endif
135 | #ifndef FF_API_AVFRAME_LAVC
136 | #define FF_API_AVFRAME_LAVC (LIBAVUTIL_VERSION_MAJOR < 53)
137 | #endif
138 |
139 | /**
140 | * @}
141 | */
142 |
143 | #endif /* AVUTIL_VERSION_H */
144 |
145 |
--------------------------------------------------------------------------------
/ffmpeg/include/libavutil/xtea.h:
--------------------------------------------------------------------------------
1 | /*
2 | * A 32-bit implementation of the XTEA algorithm
3 | * Copyright (c) 2012 Samuel Pitoiset
4 | *
5 | * This file is part of FFmpeg.
6 | *
7 | * FFmpeg is free software; you can redistribute it and/or
8 | * modify it under the terms of the GNU Lesser General Public
9 | * License as published by the Free Software Foundation; either
10 | * version 2.1 of the License, or (at your option) any later version.
11 | *
12 | * FFmpeg is distributed in the hope that it will be useful,
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 | * Lesser General Public License for more details.
16 | *
17 | * You should have received a copy of the GNU Lesser General Public
18 | * License along with FFmpeg; if not, write to the Free Software
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 | */
21 |
22 | #ifndef AVUTIL_XTEA_H
23 | #define AVUTIL_XTEA_H
24 |
25 | #include
26 |
27 | /**
28 | * @defgroup lavu_xtea XTEA
29 | * @ingroup lavu_crypto
30 | * @{
31 | */
32 |
33 | typedef struct AVXTEA {
34 | uint32_t key[16];
35 | } AVXTEA;
36 |
37 | /**
38 | * Initialize an AVXTEA context.
39 | *
40 | * @param ctx an AVXTEA context
41 | * @param key a key of 16 bytes used for encryption/decryption
42 | */
43 | void av_xtea_init(struct AVXTEA *ctx, const uint8_t key[16]);
44 |
45 | /**
46 | * Encrypt or decrypt a buffer using a previously initialized context.
47 | *
48 | * @param ctx an AVXTEA context
49 | * @param dst destination array, can be equal to src
50 | * @param src source array, can be equal to dst
51 | * @param count number of 8 byte blocks
52 | * @param iv initialization vector for CBC mode, if NULL then ECB will be used
53 | * @param decrypt 0 for encryption, 1 for decryption
54 | */
55 | void av_xtea_crypt(struct AVXTEA *ctx, uint8_t *dst, const uint8_t *src,
56 | int count, uint8_t *iv, int decrypt);
57 |
58 | /**
59 | * @}
60 | */
61 |
62 | #endif /* AVUTIL_XTEA_H */
63 |
--------------------------------------------------------------------------------
/ffmpeg/include/libpostproc/postprocess.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or modify
7 | * it under the terms of the GNU General Public License as published by
8 | * the Free Software Foundation; either version 2 of the License, or
9 | * (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 | * GNU General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU General Public License
17 | * along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef POSTPROC_POSTPROCESS_H
22 | #define POSTPROC_POSTPROCESS_H
23 |
24 | /**
25 | * @file
26 | * @ingroup lpp
27 | * external API header
28 | */
29 |
30 | /**
31 | * @defgroup lpp Libpostproc
32 | * @{
33 | */
34 |
35 | #include "libpostproc/version.h"
36 |
37 | /**
38 | * Return the LIBPOSTPROC_VERSION_INT constant.
39 | */
40 | unsigned postproc_version(void);
41 |
42 | /**
43 | * Return the libpostproc build-time configuration.
44 | */
45 | const char *postproc_configuration(void);
46 |
47 | /**
48 | * Return the libpostproc license.
49 | */
50 | const char *postproc_license(void);
51 |
52 | #define PP_QUALITY_MAX 6
53 |
54 | #define QP_STORE_T int8_t
55 |
56 | #include
57 |
58 | typedef void pp_context;
59 | typedef void pp_mode;
60 |
61 | #if LIBPOSTPROC_VERSION_INT < (52<<16)
62 | typedef pp_context pp_context_t;
63 | typedef pp_mode pp_mode_t;
64 | extern const char *const pp_help; ///< a simple help text
65 | #else
66 | extern const char pp_help[]; ///< a simple help text
67 | #endif
68 |
69 | void pp_postprocess(const uint8_t * src[3], const int srcStride[3],
70 | uint8_t * dst[3], const int dstStride[3],
71 | int horizontalSize, int verticalSize,
72 | const QP_STORE_T *QP_store, int QP_stride,
73 | pp_mode *mode, pp_context *ppContext, int pict_type);
74 |
75 |
76 | /**
77 | * Return a pp_mode or NULL if an error occurred.
78 | *
79 | * @param name the string after "-pp" on the command line
80 | * @param quality a number from 0 to PP_QUALITY_MAX
81 | */
82 | pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality);
83 | void pp_free_mode(pp_mode *mode);
84 |
85 | pp_context *pp_get_context(int width, int height, int flags);
86 | void pp_free_context(pp_context *ppContext);
87 |
88 | #define PP_CPU_CAPS_MMX 0x80000000
89 | #define PP_CPU_CAPS_MMX2 0x20000000
90 | #define PP_CPU_CAPS_3DNOW 0x40000000
91 | #define PP_CPU_CAPS_ALTIVEC 0x10000000
92 | #define PP_CPU_CAPS_AUTO 0x00080000
93 |
94 | #define PP_FORMAT 0x00000008
95 | #define PP_FORMAT_420 (0x00000011|PP_FORMAT)
96 | #define PP_FORMAT_422 (0x00000001|PP_FORMAT)
97 | #define PP_FORMAT_411 (0x00000002|PP_FORMAT)
98 | #define PP_FORMAT_444 (0x00000000|PP_FORMAT)
99 |
100 | #define PP_PICT_TYPE_QP2 0x00000010 ///< MPEG2 style QScale
101 |
102 | /**
103 | * @}
104 | */
105 |
106 | #endif /* POSTPROC_POSTPROCESS_H */
107 |
--------------------------------------------------------------------------------
/ffmpeg/include/libpostproc/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of FFmpeg.
5 | *
6 | * FFmpeg is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * FFmpeg is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with FFmpeg; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef POSTPROC_POSTPROCESS_VERSION_H
22 | #define POSTPROC_POSTPROCESS_VERSION_H
23 |
24 | /**
25 | * @file
26 | * Libpostproc version macros
27 | */
28 |
29 | #include "libavutil/avutil.h"
30 |
31 | #define LIBPOSTPROC_VERSION_MAJOR 52
32 | #define LIBPOSTPROC_VERSION_MINOR 2
33 | #define LIBPOSTPROC_VERSION_MICRO 100
34 |
35 | #define LIBPOSTPROC_VERSION_INT AV_VERSION_INT(LIBPOSTPROC_VERSION_MAJOR, \
36 | LIBPOSTPROC_VERSION_MINOR, \
37 | LIBPOSTPROC_VERSION_MICRO)
38 | #define LIBPOSTPROC_VERSION AV_VERSION(LIBPOSTPROC_VERSION_MAJOR, \
39 | LIBPOSTPROC_VERSION_MINOR, \
40 | LIBPOSTPROC_VERSION_MICRO)
41 | #define LIBPOSTPROC_BUILD LIBPOSTPROC_VERSION_INT
42 |
43 | #define LIBPOSTPROC_IDENT "postproc" AV_STRINGIFY(LIBPOSTPROC_VERSION)
44 |
45 | #endif /* POSTPROC_POSTPROCESS_VERSION_H */
46 |
--------------------------------------------------------------------------------
/ffmpeg/include/libswresample/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Version macros.
3 | *
4 | * This file is part of libswresample
5 | *
6 | * libswresample is free software; you can redistribute it and/or
7 | * modify it under the terms of the GNU Lesser General Public
8 | * License as published by the Free Software Foundation; either
9 | * version 2.1 of the License, or (at your option) any later version.
10 | *
11 | * libswresample is distributed in the hope that it will be useful,
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 | * Lesser General Public License for more details.
15 | *
16 | * You should have received a copy of the GNU Lesser General Public
17 | * License along with libswresample; if not, write to the Free Software
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 | */
20 |
21 | #ifndef SWR_VERSION_H
22 | #define SWR_VERSION_H
23 |
24 | /**
25 | * @file
26 | * Libswresample version macros
27 | */
28 |
29 | #include "libavutil/avutil.h"
30 |
31 | #define LIBSWRESAMPLE_VERSION_MAJOR 0
32 | #define LIBSWRESAMPLE_VERSION_MINOR 17
33 | #define LIBSWRESAMPLE_VERSION_MICRO 102
34 |
35 | #define LIBSWRESAMPLE_VERSION_INT AV_VERSION_INT(LIBSWRESAMPLE_VERSION_MAJOR, \
36 | LIBSWRESAMPLE_VERSION_MINOR, \
37 | LIBSWRESAMPLE_VERSION_MICRO)
38 | #define LIBSWRESAMPLE_VERSION AV_VERSION(LIBSWRESAMPLE_VERSION_MAJOR, \
39 | LIBSWRESAMPLE_VERSION_MINOR, \
40 | LIBSWRESAMPLE_VERSION_MICRO)
41 | #define LIBSWRESAMPLE_BUILD LIBSWRESAMPLE_VERSION_INT
42 |
43 | #define LIBSWRESAMPLE_IDENT "SwR" AV_STRINGIFY(LIBSWRESAMPLE_VERSION)
44 |
45 | #endif /* SWR_VERSION_H */
46 |
--------------------------------------------------------------------------------
/ffmpeg/include/libswscale/version.h:
--------------------------------------------------------------------------------
1 | /*
2 | * This file is part of FFmpeg.
3 | *
4 | * FFmpeg is free software; you can redistribute it and/or
5 | * modify it under the terms of the GNU Lesser General Public
6 | * License as published by the Free Software Foundation; either
7 | * version 2.1 of the License, or (at your option) any later version.
8 | *
9 | * FFmpeg is distributed in the hope that it will be useful,
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 | * Lesser General Public License for more details.
13 | *
14 | * You should have received a copy of the GNU Lesser General Public
15 | * License along with FFmpeg; if not, write to the Free Software
16 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 | */
18 |
19 | #ifndef SWSCALE_VERSION_H
20 | #define SWSCALE_VERSION_H
21 |
22 | /**
23 | * @file
24 | * swscale version macros
25 | */
26 |
27 | #include "libavutil/avutil.h"
28 |
29 | #define LIBSWSCALE_VERSION_MAJOR 2
30 | #define LIBSWSCALE_VERSION_MINOR 2
31 | #define LIBSWSCALE_VERSION_MICRO 100
32 |
33 | #define LIBSWSCALE_VERSION_INT AV_VERSION_INT(LIBSWSCALE_VERSION_MAJOR, \
34 | LIBSWSCALE_VERSION_MINOR, \
35 | LIBSWSCALE_VERSION_MICRO)
36 | #define LIBSWSCALE_VERSION AV_VERSION(LIBSWSCALE_VERSION_MAJOR, \
37 | LIBSWSCALE_VERSION_MINOR, \
38 | LIBSWSCALE_VERSION_MICRO)
39 | #define LIBSWSCALE_BUILD LIBSWSCALE_VERSION_INT
40 |
41 | #define LIBSWSCALE_IDENT "SwS" AV_STRINGIFY(LIBSWSCALE_VERSION)
42 |
43 | /**
44 | * FF_API_* defines may be placed below to indicate public API that will be
45 | * dropped at a future version bump. The defines themselves are not part of
46 | * the public API and may change, break or disappear at any time.
47 | */
48 |
49 | #ifndef FF_API_SWS_GETCONTEXT
50 | #define FF_API_SWS_GETCONTEXT (LIBSWSCALE_VERSION_MAJOR < 3)
51 | #endif
52 | #ifndef FF_API_SWS_CPU_CAPS
53 | #define FF_API_SWS_CPU_CAPS (LIBSWSCALE_VERSION_MAJOR < 3)
54 | #endif
55 | #ifndef FF_API_SWS_FORMAT_NAME
56 | #define FF_API_SWS_FORMAT_NAME (LIBSWSCALE_VERSION_MAJOR < 3)
57 | #endif
58 |
59 | #endif /* SWSCALE_VERSION_H */
60 |
--------------------------------------------------------------------------------
/ffmpeg/lib/avcodec.lib:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/lib/avcodec.lib
--------------------------------------------------------------------------------
/ffmpeg/lib/avdevice.lib:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/lib/avdevice.lib
--------------------------------------------------------------------------------
/ffmpeg/lib/avformat.lib:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/lib/avformat.lib
--------------------------------------------------------------------------------
/ffmpeg/lib/avutil.lib:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/lib/avutil.lib
--------------------------------------------------------------------------------
/ffmpeg/lib/swscale.lib:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/UnickSoft/FFMpeg-decode-example/6fc6686c1d62f1d6bf4cff690f8bf5904f5601fe/ffmpeg/lib/swscale.lib
--------------------------------------------------------------------------------
/ffmpegDecoder.sln:
--------------------------------------------------------------------------------
1 |
2 | Microsoft Visual Studio Solution File, Format Version 10.00
3 | # Visual C++ Express 2008
4 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ffmpegDecoder", "ffmpegDecoder\ffmpegDecoder.vcproj", "{C1D750CD-5B20-48BC-944E-276D23B77F6E}"
5 | EndProject
6 | Global
7 | GlobalSection(SolutionConfigurationPlatforms) = preSolution
8 | Debug|Win32 = Debug|Win32
9 | Release|Win32 = Release|Win32
10 | EndGlobalSection
11 | GlobalSection(ProjectConfigurationPlatforms) = postSolution
12 | {C1D750CD-5B20-48BC-944E-276D23B77F6E}.Debug|Win32.ActiveCfg = Debug|Win32
13 | {C1D750CD-5B20-48BC-944E-276D23B77F6E}.Debug|Win32.Build.0 = Debug|Win32
14 | {C1D750CD-5B20-48BC-944E-276D23B77F6E}.Release|Win32.ActiveCfg = Release|Win32
15 | {C1D750CD-5B20-48BC-944E-276D23B77F6E}.Release|Win32.Build.0 = Release|Win32
16 | EndGlobalSection
17 | GlobalSection(SolutionProperties) = preSolution
18 | HideSolutionNode = FALSE
19 | EndGlobalSection
20 | EndGlobal
21 |
--------------------------------------------------------------------------------
/ffmpegDecoder/ffmpegDecode.h:
--------------------------------------------------------------------------------
1 | /*
2 | It is FFmpeg decoder class. Sample for article from unick-soft.ru
3 | */
4 |
5 | #ifndef __FFMPEG_DECODER__
6 | #define __FFMPEG_DECODER__
7 |
8 | #include "ffmpegInclude.h"
9 | #include
10 |
11 | class FFmpegDecoder
12 | {
13 | // constructor.
14 | public: FFmpegDecoder() : pImgConvertCtx(NULL), audioBaseTime(0.0), videoBaseTime(0.0),
15 | videoFramePerSecond(0.0), isOpen(false), audioStreamIndex(-1), videoStreamIndex(-1),
16 | pAudioCodec(NULL), pAudioCodecCtx(NULL), pVideoCodec(NULL), pVideoCodecCtx(NULL),
17 | pFormatCtx(NULL) {;}
18 |
19 | // destructor.
20 | public: virtual ~FFmpegDecoder()
21 | {
22 | CloseFile();
23 | }
24 |
25 | // Open file
26 | public: virtual bool OpenFile(std::string& inputFile);
27 |
28 | // Close file and free resourses.
29 | public: virtual bool CloseFile();
30 |
31 | // Return next frame FFmpeg.
32 | public: virtual AVFrame * GetNextFrame();
33 |
34 | public: int GetWidth()
35 | {
36 | return width;
37 | }
38 | public: int GetHeight()
39 | {
40 | return height;
41 | }
42 |
43 | // open video stream.
44 | private: bool OpenVideo();
45 |
46 | // open audio stream.
47 | private: bool OpenAudio();
48 |
49 | // close video stream.
50 | private: void CloseVideo();
51 |
52 | // close audio stream.
53 | private: void CloseAudio();
54 |
55 | // return rgb image
56 | private: AVFrame * GetRGBAFrame(AVFrame *pFrameYuv);
57 |
58 | // Decode audio from packet.
59 | private: int DecodeAudio(int nStreamIndex, const AVPacket *avpkt,
60 | uint8_t* pOutBuffer, size_t nOutBufferSize);
61 |
62 | // Decode video buffer.
63 | private: bool DecodeVideo(const AVPacket *avpkt, AVFrame * pOutFrame);
64 |
65 | // FFmpeg file format.
66 | private: AVFormatContext* pFormatCtx;
67 |
68 | // FFmpeg codec context.
69 | private: AVCodecContext* pVideoCodecCtx;
70 |
71 | // FFmpeg codec for video.
72 | private: AVCodec* pVideoCodec;
73 |
74 | // FFmpeg codec context for audio.
75 | private: AVCodecContext* pAudioCodecCtx;
76 |
77 | // FFmpeg codec for audio.
78 | private: AVCodec* pAudioCodec;
79 |
80 | // Video stream number in file.
81 | private: int videoStreamIndex;
82 |
83 | // Audio stream number in file.
84 | private: int audioStreamIndex;
85 |
86 | // File is open or not.
87 | private: bool isOpen;
88 |
89 | // Video frame per seconds.
90 | private: double videoFramePerSecond;
91 |
92 | // FFmpeg timebase for video.
93 | private: double videoBaseTime;
94 |
95 | // FFmpeg timebase for audio.
96 | private: double audioBaseTime;
97 |
98 | // FFmpeg context convert image.
99 | private: struct SwsContext *pImgConvertCtx;
100 |
101 | // Width of image
102 | private: int width;
103 |
104 | // Height of image
105 | private: int height;
106 | };
107 |
108 | #endif
--------------------------------------------------------------------------------
/ffmpegDecoder/ffmpegDecoder.vcproj:
--------------------------------------------------------------------------------
1 |
2 |
11 |
12 |
15 |
16 |
17 |
18 |
19 |
26 |
29 |
32 |
35 |
38 |
41 |
53 |
56 |
59 |
62 |
71 |
74 |
77 |
80 |
83 |
86 |
89 |
93 |
94 |
102 |
105 |
108 |
111 |
114 |
117 |
129 |
132 |
135 |
138 |
150 |
153 |
156 |
159 |
162 |
165 |
168 |
172 |
173 |
174 |
175 |
176 |
177 |
182 |
185 |
186 |
189 |
190 |
193 |
194 |
195 |
200 |
203 |
204 |
207 |
208 |
211 |
212 |
213 |
218 |
219 |
220 |
221 |
222 |
223 |
--------------------------------------------------------------------------------
/ffmpegDecoder/ffmpegInclude.h:
--------------------------------------------------------------------------------
1 | /*
2 | * Include ffmpeg files
3 | */
4 |
5 |
6 | #pragma once
7 |
8 | #ifndef __STDC_CONSTANT_MACROS
9 | #define __STDC_CONSTANT_MACROS
10 | #endif
11 |
12 | //#include "stdint.h"
13 | extern "C"
14 | {
15 | #include
16 | #include
17 | #include
18 | }
--------------------------------------------------------------------------------
/ffmpegDecoder/main.cpp:
--------------------------------------------------------------------------------
1 | // ffmpegDecoder.cpp : Defines the entry point for the console application.
2 | //
3 |
4 | #include "stdafx.h"
5 | #include "ffmpegDecode.h"
6 | #include
7 |
8 | #define FILE_NAME "C:\\temp\\test.avi"
9 | #define OUTPUT_FILE_PREFIX "c:\\temp\\image%d.bmp"
10 | #define FRAME_COUNT 50
11 |
12 | bool BMPSave(const char *pFileName, AVFrame * frame, int w, int h)
13 | {
14 | bool bResult = false;
15 |
16 | if (frame)
17 | {
18 | FILE* file = fopen(pFileName, "wb");
19 |
20 | if (file)
21 | {
22 | // RGB image
23 | int imageSizeInBytes = 3 * w * h;
24 | int headersSize = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER);
25 | int fileSize = headersSize + imageSizeInBytes;
26 |
27 | uint8_t * pData = new uint8_t[headersSize];
28 |
29 | if (pData != NULL)
30 | {
31 | BITMAPFILEHEADER& bfHeader = *((BITMAPFILEHEADER *)(pData));
32 |
33 | bfHeader.bfType = 'MB';
34 | bfHeader.bfSize = fileSize;
35 | bfHeader.bfOffBits = headersSize;
36 | bfHeader.bfReserved1 = bfHeader.bfReserved2 = 0;
37 |
38 | BITMAPINFOHEADER& bmiHeader = *((BITMAPINFOHEADER *)(pData + headersSize - sizeof(BITMAPINFOHEADER)));
39 |
40 | bmiHeader.biBitCount = 3 * 8;
41 | bmiHeader.biWidth = w;
42 | bmiHeader.biHeight = h;
43 | bmiHeader.biPlanes = 1;
44 | bmiHeader.biSize = sizeof(bmiHeader);
45 | bmiHeader.biCompression = BI_RGB;
46 | bmiHeader.biClrImportant = bmiHeader.biClrUsed =
47 | bmiHeader.biSizeImage = bmiHeader.biXPelsPerMeter =
48 | bmiHeader.biYPelsPerMeter = 0;
49 |
50 | fwrite(pData, headersSize, 1, file);
51 |
52 | uint8_t *pBits = frame->data[0] + frame->linesize[0] * h - frame->linesize[0];
53 | int nSpan = -frame->linesize[0];
54 |
55 | int numberOfBytesToWrite = 3 * w;
56 |
57 | for (size_t i = 0; i < h; ++i, pBits += nSpan)
58 | {
59 | fwrite(pBits, numberOfBytesToWrite, 1, file);
60 | }
61 |
62 | bResult = true;
63 | delete [] pData;
64 | }
65 |
66 | fclose(file);
67 | }
68 | }
69 |
70 | return bResult;
71 | }
72 |
73 |
74 | int _tmain(int argc, _TCHAR* argv[])
75 | {
76 | FFmpegDecoder decoder;
77 |
78 | if (decoder.OpenFile(std::string(FILE_NAME)))
79 | {
80 | int w = decoder.GetWidth();
81 | int h = decoder.GetHeight();
82 |
83 | for (int i = 0; i < FRAME_COUNT; i++)
84 | {
85 | AVFrame * frame = decoder.GetNextFrame();
86 | if (frame)
87 | {
88 | char filename[MAX_PATH];
89 | sprintf(filename, OUTPUT_FILE_PREFIX, i);
90 | if (!BMPSave(filename, frame, frame->width, frame->height))
91 | {
92 | printf("Cannot save file %s\n", filename);
93 | }
94 | av_free(frame->data[0]);
95 | av_free(frame);
96 | }
97 | }
98 |
99 | decoder.CloseFile();
100 | }
101 | else
102 | {
103 | printf ("Cannot open file " FILE_NAME "\n");
104 | }
105 |
106 | return 0;
107 | }
108 |
109 |
--------------------------------------------------------------------------------
/ffmpegDecoder/stdafx.cpp:
--------------------------------------------------------------------------------
1 | // stdafx.cpp : source file that includes just the standard includes
2 | // ffmpegDecoder.pch will be the pre-compiled header
3 | // stdafx.obj will contain the pre-compiled type information
4 |
5 | #include "stdafx.h"
6 |
7 | // TODO: reference any additional headers you need in STDAFX.H
8 | // and not in this file
9 |
--------------------------------------------------------------------------------
/ffmpegDecoder/stdafx.h:
--------------------------------------------------------------------------------
1 | // stdafx.h : include file for standard system include files,
2 | // or project specific include files that are used frequently, but
3 | // are changed infrequently
4 | //
5 |
6 | #pragma once
7 |
8 | #include "targetver.h"
9 |
10 | #include
11 | #include
12 |
13 |
14 |
15 | // TODO: reference additional headers your program requires here
16 |
--------------------------------------------------------------------------------
/ffmpegDecoder/stdint.h:
--------------------------------------------------------------------------------
1 | /* ISO C9x 7.18 Integer types
2 | * Based on ISO/IEC SC22/WG14 9899 Committee draft (SC22 N2794)
3 | *
4 | * THIS SOFTWARE IS NOT COPYRIGHTED
5 | *
6 | * Contributor: Danny Smith
7 | *
8 | * This source code is offered for use in the public domain. You may
9 | * use, modify or distribute it freely.
10 | *
11 | * This code is distributed in the hope that it will be useful but
12 | * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
13 | * DISCLAIMED. This includes but is not limited to warranties of
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
15 | *
16 | * Date: 2000-12-02
17 | */
18 |
19 |
20 | #ifndef _STDINT_H
21 | #define _STDINT_H
22 | #define __need_wint_t
23 | #define __need_wchar_t
24 | #include
25 |
26 | /* 7.18.1.1 Exact-width integer types */
27 | typedef signed char int8_t;
28 | typedef unsigned char uint8_t;
29 | typedef short int16_t;
30 | typedef unsigned short uint16_t;
31 | typedef int int32_t;
32 | typedef unsigned uint32_t;
33 | typedef long long int64_t;
34 | typedef unsigned long long uint64_t;
35 |
36 | /* 7.18.1.2 Minimum-width integer types */
37 | typedef signed char int_least8_t;
38 | typedef unsigned char uint_least8_t;
39 | typedef short int_least16_t;
40 | typedef unsigned short uint_least16_t;
41 | typedef int int_least32_t;
42 | typedef unsigned uint_least32_t;
43 | typedef long long int_least64_t;
44 | typedef unsigned long long uint_least64_t;
45 |
46 | /* 7.18.1.3 Fastest minimum-width integer types
47 | * Not actually guaranteed to be fastest for all purposes
48 | * Here we use the exact-width types for 8 and 16-bit ints.
49 | */
50 | typedef char int_fast8_t;
51 | typedef unsigned char uint_fast8_t;
52 | typedef short int_fast16_t;
53 | typedef unsigned short uint_fast16_t;
54 | typedef int int_fast32_t;
55 | typedef unsigned int uint_fast32_t;
56 | typedef long long int_fast64_t;
57 | typedef unsigned long long uint_fast64_t;
58 |
59 | /* 7.18.1.4 Integer types capable of holding object pointers */
60 |
61 | #ifndef _INTPTR_T_DEFINED
62 | #define _INTPTR_T_DEFINED
63 | #ifdef _WIN64
64 | typedef __int64 intptr_t;
65 | #else
66 | typedef int intptr_t;
67 | #endif
68 | #endif
69 |
70 | #ifndef _UINTPTR_T_DEFINED
71 | #define _UINTPTR_T_DEFINED
72 | #ifdef _WIN64
73 | typedef unsigned __int64 uintptr_t;
74 | #else
75 | typedef unsigned int uintptr_t;
76 | #endif
77 | #endif
78 |
79 | /* 7.18.1.5 Greatest-width integer types */
80 | typedef long long intmax_t;
81 | typedef unsigned long long uintmax_t;
82 |
83 | /* 7.18.2 Limits of specified-width integer types */
84 | #if !defined ( __cplusplus) || defined (__STDC_LIMIT_MACROS)
85 |
86 | /* 7.18.2.1 Limits of exact-width integer types */
87 | #define INT8_MIN (-128)
88 | #define INT16_MIN (-32768)
89 | #define INT32_MIN (-2147483647 - 1)
90 | #define INT64_MIN (-9223372036854775807LL - 1)
91 |
92 | #define INT8_MAX 127
93 | #define INT16_MAX 32767
94 | #define INT32_MAX 2147483647
95 | #define INT64_MAX 9223372036854775807LL
96 |
97 | #define UINT8_MAX 0xff /* 255U */
98 | #define UINT16_MAX 0xffff /* 65535U */
99 | #define UINT32_MAX 0xffffffff /* 4294967295U */
100 | #define UINT64_MAX 0xffffffffffffffffULL /* 18446744073709551615ULL */
101 |
102 | /* 7.18.2.2 Limits of minimum-width integer types */
103 | #define INT_LEAST8_MIN INT8_MIN
104 | #define INT_LEAST16_MIN INT16_MIN
105 | #define INT_LEAST32_MIN INT32_MIN
106 | #define INT_LEAST64_MIN INT64_MIN
107 |
108 | #define INT_LEAST8_MAX INT8_MAX
109 | #define INT_LEAST16_MAX INT16_MAX
110 | #define INT_LEAST32_MAX INT32_MAX
111 | #define INT_LEAST64_MAX INT64_MAX
112 |
113 | #define UINT_LEAST8_MAX UINT8_MAX
114 | #define UINT_LEAST16_MAX UINT16_MAX
115 | #define UINT_LEAST32_MAX UINT32_MAX
116 | #define UINT_LEAST64_MAX UINT64_MAX
117 |
118 | /* 7.18.2.3 Limits of fastest minimum-width integer types */
119 | #define INT_FAST8_MIN INT8_MIN
120 | #define INT_FAST16_MIN INT16_MIN
121 | #define INT_FAST32_MIN INT32_MIN
122 | #define INT_FAST64_MIN INT64_MIN
123 |
124 | #define INT_FAST8_MAX INT8_MAX
125 | #define INT_FAST16_MAX INT16_MAX
126 | #define INT_FAST32_MAX INT32_MAX
127 | #define INT_FAST64_MAX INT64_MAX
128 |
129 | #define UINT_FAST8_MAX UINT8_MAX
130 | #define UINT_FAST16_MAX UINT16_MAX
131 | #define UINT_FAST32_MAX UINT32_MAX
132 | #define UINT_FAST64_MAX UINT64_MAX
133 |
134 | /* 7.18.2.4 Limits of integer types capable of holding
135 | object pointers */
136 | #ifdef _WIN64
137 | #define INTPTR_MIN INT64_MIN
138 | #define INTPTR_MAX INT64_MAX
139 | #define UINTPTR_MAX UINT64_MAX
140 | #else
141 | #define INTPTR_MIN INT32_MIN
142 | #define INTPTR_MAX INT32_MAX
143 | #define UINTPTR_MAX UINT32_MAX
144 | #endif
145 |
146 | /* 7.18.2.5 Limits of greatest-width integer types */
147 | #define INTMAX_MIN INT64_MIN
148 | #define INTMAX_MAX INT64_MAX
149 | #define UINTMAX_MAX UINT64_MAX
150 |
151 | /* 7.18.3 Limits of other integer types */
152 | #define PTRDIFF_MIN INTPTR_MIN
153 | #define PTRDIFF_MAX INTPTR_MAX
154 |
155 | #define SIG_ATOMIC_MIN INTPTR_MIN
156 | #define SIG_ATOMIC_MAX INTPTR_MAX
157 |
158 | #define SIZE_MAX UINTPTR_MAX
159 |
160 | #ifndef WCHAR_MIN /* also in wchar.h */
161 | #define WCHAR_MIN 0
162 | #define WCHAR_MAX 0xffff /* UINT16_MAX */
163 | #endif
164 |
165 | /*
166 | * wint_t is unsigned short for compatibility with MS runtime
167 | */
168 | #define WINT_MIN 0
169 | #define WINT_MAX 0xffff /* UINT16_MAX */
170 |
171 | #endif /* !defined ( __cplusplus) || defined __STDC_LIMIT_MACROS */
172 |
173 |
174 | /* 7.18.4 Macros for integer constants */
175 | #if !defined ( __cplusplus) || defined (__STDC_CONSTANT_MACROS)
176 |
177 | /* 7.18.4.1 Macros for minimum-width integer constants
178 |
179 | Accoding to Douglas Gwyn :
180 | "This spec was changed in ISO/IEC 9899:1999 TC1; in ISO/IEC
181 | 9899:1999 as initially published, the expansion was required
182 | to be an integer constant of precisely matching type, which
183 | is impossible to accomplish for the shorter types on most
184 | platforms, because C99 provides no standard way to designate
185 | an integer constant with width less than that of type int.
186 | TC1 changed this to require just an integer constant
187 | *expression* with *promoted* type."
188 | */
189 |
190 | #define INT8_C(val) ((int8_t) + (val))
191 | #define UINT8_C(val) ((uint8_t) + (val##U))
192 | #define INT16_C(val) ((int16_t) + (val))
193 | #define UINT16_C(val) ((uint16_t) + (val##U))
194 |
195 | #define INT32_C(val) val##L
196 | #define UINT32_C(val) val##UL
197 | #define INT64_C(val) val##LL
198 | #define UINT64_C(val) val##ULL
199 |
200 | /* 7.18.4.2 Macros for greatest-width integer constants */
201 | #define INTMAX_C(val) INT64_C(val)
202 | #define UINTMAX_C(val) UINT64_C(val)
203 |
204 | #endif /* !defined ( __cplusplus) || defined __STDC_CONSTANT_MACROS */
205 |
206 | #endif
207 |
--------------------------------------------------------------------------------
/ffmpegDecoder/targetver.h:
--------------------------------------------------------------------------------
1 | #pragma once
2 |
3 | // The following macros define the minimum required platform. The minimum required platform
4 | // is the earliest version of Windows, Internet Explorer etc. that has the necessary features to run
5 | // your application. The macros work by enabling all features available on platform versions up to and
6 | // including the version specified.
7 |
8 | // Modify the following defines if you have to target a platform prior to the ones specified below.
9 | // Refer to MSDN for the latest info on corresponding values for different platforms.
10 | #ifndef _WIN32_WINNT // Specifies that the minimum required platform is Windows Vista.
11 | #define _WIN32_WINNT 0x0600 // Change this to the appropriate value to target other versions of Windows.
12 | #endif
13 |
14 |
--------------------------------------------------------------------------------