summaryrefslogtreecommitdiffstats
path: root/audio/filter/af_surround.c
diff options
context:
space:
mode:
Diffstat (limited to 'audio/filter/af_surround.c')
-rw-r--r--audio/filter/af_surround.c19
1 files changed, 6 insertions, 13 deletions
diff --git a/audio/filter/af_surround.c b/audio/filter/af_surround.c
index e584e6505a..efeecdc1e3 100644
--- a/audio/filter/af_surround.c
+++ b/audio/filter/af_surround.c
@@ -144,9 +144,6 @@ static int control(struct af_instance* af, int cmd, void* arg)
// Deallocate memory
static void uninit(struct af_instance* af)
{
- if(af->data)
- free(af->data->audio);
- free(af->data);
free(af->setup);
}
@@ -165,17 +162,16 @@ static float steering_matrix[][12] = {
static struct mp_audio* play(struct af_instance* af, struct mp_audio* data){
af_surround_t* s = (af_surround_t*)af->setup;
float* m = steering_matrix[0];
- float* in = data->audio; // Input audio data
+ float* in = data->planes[0]; // Input audio data
float* out = NULL; // Output audio data
- float* end = in + data->len / sizeof(float); // Loop end
+ float* end = in + data->samples * data->nch;
int i = s->i; // Filter queue index
int ri = s->ri; // Read index for delay queue
int wi = s->wi; // Write index for delay queue
- if (AF_OK != RESIZE_LOCAL_BUFFER(af, data))
- return NULL;
+ mp_audio_realloc_min(af->data, data->samples);
- out = af->data->audio;
+ out = af->data->planes[0];
while(in < end){
/* Dominance:
@@ -237,8 +233,7 @@ static struct mp_audio* play(struct af_instance* af, struct mp_audio* data){
s->i = i; s->ri = ri; s->wi = wi;
// Set output data
- data->audio = af->data->audio;
- data->len *= 2;
+ data->planes[0] = af->data->planes[0];
mp_audio_set_channels_old(data, af->data->nch);
return data;
@@ -248,10 +243,8 @@ static int af_open(struct af_instance* af){
af->control=control;
af->uninit=uninit;
af->play=play;
- af->mul=2;
- af->data=calloc(1,sizeof(struct mp_audio));
af->setup=calloc(1,sizeof(af_surround_t));
- if(af->data == NULL || af->setup == NULL)
+ if(af->setup == NULL)
return AF_ERROR;
((af_surround_t*)af->setup)->d = 20;
return AF_OK;