737eb5976f
It is pretty hopeless that other considerable projects will adopt libavutil alone in other projects. Projects that need small footprint are better off with more specialized libraries such as gnulib or rather just copy the necessary parts that they need. With this in mind, nobody is helped by having libavutil and libavcore split. In order to ease maintenance inside and around FFmpeg and to reduce confusion where to put common code, avcore's functionality is merged (back) to avutil. Signed-off-by: Reinhard Tartler <siretart@tauware.de>
120 lines
3.8 KiB
C
120 lines
3.8 KiB
C
/*
|
|
* audio conversion
|
|
* Copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
|
|
* Copyright (c) 2008 Peter Ross
|
|
*
|
|
* This file is part of FFmpeg.
|
|
*
|
|
* FFmpeg is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* FFmpeg is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with FFmpeg; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef AVCODEC_AUDIOCONVERT_H
|
|
#define AVCODEC_AUDIOCONVERT_H
|
|
|
|
/**
|
|
* @file
|
|
* Audio format conversion routines
|
|
*/
|
|
|
|
|
|
#include "libavutil/cpu.h"
|
|
#include "avcodec.h"
|
|
#include "libavutil/audioconvert.h"
|
|
|
|
#if FF_API_OLD_SAMPLE_FMT
|
|
/**
|
|
* @deprecated Use av_get_sample_fmt_string() instead.
|
|
*/
|
|
attribute_deprecated
|
|
void avcodec_sample_fmt_string(char *buf, int buf_size, int sample_fmt);
|
|
|
|
/**
|
|
* @deprecated Use av_get_sample_fmt_name() instead.
|
|
*/
|
|
attribute_deprecated
|
|
const char *avcodec_get_sample_fmt_name(int sample_fmt);
|
|
|
|
/**
|
|
* @deprecated Use av_get_sample_fmt() instead.
|
|
*/
|
|
attribute_deprecated
|
|
enum AVSampleFormat avcodec_get_sample_fmt(const char* name);
|
|
#endif
|
|
|
|
#if FF_API_OLD_AUDIOCONVERT
|
|
/**
|
|
* @deprecated Use av_get_channel_layout() instead.
|
|
*/
|
|
attribute_deprecated
|
|
int64_t avcodec_get_channel_layout(const char *name);
|
|
|
|
/**
|
|
* @deprecated Use av_get_channel_layout_string() instead.
|
|
*/
|
|
attribute_deprecated
|
|
void avcodec_get_channel_layout_string(char *buf, int buf_size, int nb_channels, int64_t channel_layout);
|
|
|
|
/**
|
|
* @deprecated Use av_get_channel_layout_nb_channels() instead.
|
|
*/
|
|
attribute_deprecated
|
|
int avcodec_channel_layout_num_channels(int64_t channel_layout);
|
|
#endif
|
|
|
|
/**
|
|
* Guess the channel layout
|
|
* @param nb_channels
|
|
* @param codec_id Codec identifier, or CODEC_ID_NONE if unknown
|
|
* @param fmt_name Format name, or NULL if unknown
|
|
* @return Channel layout mask
|
|
*/
|
|
int64_t avcodec_guess_channel_layout(int nb_channels, enum CodecID codec_id, const char *fmt_name);
|
|
|
|
struct AVAudioConvert;
|
|
typedef struct AVAudioConvert AVAudioConvert;
|
|
|
|
/**
|
|
* Create an audio sample format converter context
|
|
* @param out_fmt Output sample format
|
|
* @param out_channels Number of output channels
|
|
* @param in_fmt Input sample format
|
|
* @param in_channels Number of input channels
|
|
* @param[in] matrix Channel mixing matrix (of dimension in_channel*out_channels). Set to NULL to ignore.
|
|
* @param flags See AV_CPU_FLAG_xx
|
|
* @return NULL on error
|
|
*/
|
|
AVAudioConvert *av_audio_convert_alloc(enum AVSampleFormat out_fmt, int out_channels,
|
|
enum AVSampleFormat in_fmt, int in_channels,
|
|
const float *matrix, int flags);
|
|
|
|
/**
|
|
* Free audio sample format converter context
|
|
*/
|
|
void av_audio_convert_free(AVAudioConvert *ctx);
|
|
|
|
/**
|
|
* Convert between audio sample formats
|
|
* @param[in] out array of output buffers for each channel. set to NULL to ignore processing of the given channel.
|
|
* @param[in] out_stride distance between consecutive output samples (measured in bytes)
|
|
* @param[in] in array of input buffers for each channel
|
|
* @param[in] in_stride distance between consecutive input samples (measured in bytes)
|
|
* @param len length of audio frame size (measured in samples)
|
|
*/
|
|
int av_audio_convert(AVAudioConvert *ctx,
|
|
void * const out[6], const int out_stride[6],
|
|
const void * const in[6], const int in_stride[6], int len);
|
|
|
|
#endif /* AVCODEC_AUDIOCONVERT_H */
|