]> git.sesse.net Git - ffmpeg/blob - libavfilter/audio.h
lavfi/af_volumedetect: print stats in uninit().
[ffmpeg] / libavfilter / audio.h
1 /*
2  * Copyright (c) Stefano Sabatini | stefasab at gmail.com
3  * Copyright (c) S.N. Hemanth Meenakshisundaram | smeenaks at ucsd.edu
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 AVFILTER_AUDIO_H
23 #define AVFILTER_AUDIO_H
24
25 #include "avfilter.h"
26
27 static const enum AVSampleFormat ff_packed_sample_fmts_array[] = {
28     AV_SAMPLE_FMT_U8,
29     AV_SAMPLE_FMT_S16,
30     AV_SAMPLE_FMT_S32,
31     AV_SAMPLE_FMT_FLT,
32     AV_SAMPLE_FMT_DBL,
33     AV_SAMPLE_FMT_NONE
34 };
35
36 static const enum AVSampleFormat ff_planar_sample_fmts_array[] = {
37     AV_SAMPLE_FMT_U8P,
38     AV_SAMPLE_FMT_S16P,
39     AV_SAMPLE_FMT_S32P,
40     AV_SAMPLE_FMT_FLTP,
41     AV_SAMPLE_FMT_DBLP,
42     AV_SAMPLE_FMT_NONE
43 };
44
45 /** default handler for get_audio_buffer() for audio inputs */
46 AVFilterBufferRef *ff_default_get_audio_buffer(AVFilterLink *link, int perms,
47                                                      int nb_samples);
48
49 /** get_audio_buffer() handler for filters which simply pass audio along */
50 AVFilterBufferRef *ff_null_get_audio_buffer(AVFilterLink *link, int perms,
51                                                   int nb_samples);
52
53 /**
54  * Request an audio samples buffer with a specific set of permissions.
55  *
56  * @param link           the output link to the filter from which the buffer will
57  *                       be requested
58  * @param perms          the required access permissions
59  * @param nb_samples     the number of samples per channel
60  * @return               A reference to the samples. This must be unreferenced with
61  *                       avfilter_unref_buffer when you are finished with it.
62  */
63 AVFilterBufferRef *ff_get_audio_buffer(AVFilterLink *link, int perms,
64                                              int nb_samples);
65
66 /**
67  * Send a buffer of audio samples to the next filter.
68  *
69  * @param link       the output link over which the audio samples are being sent
70  * @param samplesref a reference to the buffer of audio samples being sent. The
71  *                   receiving filter will free this reference when it no longer
72  *                   needs it or pass it on to the next filter.
73  *
74  * @return >= 0 on success, a negative AVERROR on error. The receiving filter
75  * is responsible for unreferencing samplesref in case of error.
76  */
77 int ff_filter_samples(AVFilterLink *link, AVFilterBufferRef *samplesref);
78
79 /**
80  * Send a buffer of audio samples to the next link, without checking
81  * min_samples.
82  */
83 int ff_filter_samples_framed(AVFilterLink *link,
84                               AVFilterBufferRef *samplesref);
85
86 #endif /* AVFILTER_AUDIO_H */