]> code.delx.au - pulseaudio/commitdiff
remap: Add (optional) state to remap struct
authorPeter Meerwald <p.meerwald@bct-electronic.com>
Wed, 16 Apr 2014 13:00:45 +0000 (15:00 +0200)
committerPeter Meerwald <pmeerw@pmeerw.net>
Mon, 28 Apr 2014 22:00:06 +0000 (00:00 +0200)
State can be used by remap function implementations to
speed up the remapping, e.g. by precomputing things or
even by generating specialized code for a specific channel
remapping task

Signed-off-by: Peter Meerwald <pmeerw@pmeerw.net>
src/pulsecore/remap.h
src/pulsecore/resampler.c

index 157f974e4267ce0fee0d56444d6cbc3dbed7ff87..66ab7bca3a9df1f5315f0a70e292b80e0c1468e5 100644 (file)
@@ -35,6 +35,7 @@ struct pa_remap {
     float map_table_f[PA_CHANNELS_MAX][PA_CHANNELS_MAX];
     int32_t map_table_i[PA_CHANNELS_MAX][PA_CHANNELS_MAX];
     pa_do_remap_func_t do_remap;
+    void *state; /* optional state information for the remap function */
 };
 
 void pa_init_remap_func(pa_remap_t *m);
index 473cbd3c6477aa1debe03a0df1fb065626a220d3..1153281cae3c98ba8156ee9b71571071eb7e59d4 100644 (file)
@@ -115,6 +115,7 @@ static int libsamplerate_init(pa_resampler*r);
 #endif
 
 static void setup_remap(const pa_resampler *r, pa_remap_t *m);
+static void free_remap(pa_remap_t *m);
 
 static int (* const init_table[])(pa_resampler*r) = {
 #ifdef HAVE_LIBSAMPLERATE
@@ -477,6 +478,8 @@ void pa_resampler_free(pa_resampler *r) {
     if (r->from_work_format_buf.memblock)
         pa_memblock_unref(r->from_work_format_buf.memblock);
 
+    free_remap(&r->remap);
+
     pa_xfree(r);
 }
 
@@ -1152,6 +1155,12 @@ static void setup_remap(const pa_resampler *r, pa_remap_t *m) {
     pa_init_remap_func(m);
 }
 
+static void free_remap(pa_remap_t *m) {
+    pa_assert(m);
+
+    pa_xfree(m->state);
+}
+
 /* check if buf's memblock is large enough to hold 'len' bytes; create a
  * new memblock if necessary and optionally preserve 'copy' data bytes */
 static void fit_buf(pa_resampler *r, pa_memchunk *buf, size_t len, size_t *size, size_t copy) {