aboutsummaryrefslogtreecommitdiffstats
path: root/libswresample/swresample.c
diff options
context:
space:
mode:
authorClément Bœsch <ubitux@gmail.com>2011-11-17 15:06:35 +0100
committerClément Bœsch <ubitux@gmail.com>2011-11-17 18:30:03 +0100
commiteafa2b600502f5e8b36b99a2737d6b3d3a58441f (patch)
tree092268c2591a8cfd3c53fd8253bbe8e0d1c0c8d4 /libswresample/swresample.c
parentd3baced24fcf602f2bceff1f73871303d4011c15 (diff)
downloadffmpeg-eafa2b600502f5e8b36b99a2737d6b3d3a58441f.tar.gz
swr: introduce a public function to customize the channel mapping.
Diffstat (limited to 'libswresample/swresample.c')
-rw-r--r--libswresample/swresample.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/libswresample/swresample.c b/libswresample/swresample.c
index a8576d4b1b..b0a00414bd 100644
--- a/libswresample/swresample.c
+++ b/libswresample/swresample.c
@@ -73,6 +73,13 @@ static const AVClass av_class = {
static int resample(SwrContext *s, AudioData *out_param, int out_count,
const AudioData * in_param, int in_count);
+int swr_set_channel_mapping(struct SwrContext *s, const int *channel_map){
+ if(!s || s->in_convert) // s needs to be allocated but not initialized
+ return AVERROR(EINVAL);
+ s->channel_map = channel_map;
+ return 0;
+}
+
struct SwrContext *swr_alloc(void){
SwrContext *s= av_mallocz(sizeof(SwrContext));
if(s){
@@ -85,7 +92,7 @@ struct SwrContext *swr_alloc(void){
struct SwrContext *swr_alloc_set_opts(struct SwrContext *s,
int64_t out_ch_layout, enum AVSampleFormat out_sample_fmt, int out_sample_rate,
int64_t in_ch_layout, enum AVSampleFormat in_sample_fmt, int in_sample_rate,
- const int *channel_map, int log_offset, void *log_ctx){
+ int log_offset, void *log_ctx){
if(!s) s= swr_alloc();
if(!s) return NULL;
@@ -101,8 +108,6 @@ struct SwrContext *swr_alloc_set_opts(struct SwrContext *s,
av_opt_set_int(s, "tsf", AV_SAMPLE_FMT_S16, 0);
av_opt_set_int(s, "ich", av_get_channel_layout_nb_channels(s-> in_ch_layout), 0);
av_opt_set_int(s, "och", av_get_channel_layout_nb_channels(s->out_ch_layout), 0);
-
- s->channel_map = channel_map;
return s;
}