From b83a1d79b78265ff197f2677790eb34eb3bf7aae Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Wed, 24 Dec 2014 23:02:19 +0100 Subject: [PATCH] output/jack: pass float* to WriteSamples() --- src/output/plugins/JackOutputPlugin.cxx | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/src/output/plugins/JackOutputPlugin.cxx b/src/output/plugins/JackOutputPlugin.cxx index e104c3cb4..2872e27aa 100644 --- a/src/output/plugins/JackOutputPlugin.cxx +++ b/src/output/plugins/JackOutputPlugin.cxx @@ -114,7 +114,7 @@ struct JackOutput { /** * @return the number of frames that were written */ - size_t WriteSamples(const void *src, size_t n_frames); + size_t WriteSamples(const float *src, size_t n_frames); size_t Play(const void *chunk, size_t size, Error &error); }; @@ -641,12 +641,10 @@ mpd_jack_delay(AudioOutput *ao) } inline size_t -JackOutput::WriteSamples(const void *_src, size_t n_frames) +JackOutput::WriteSamples(const float *src, size_t n_frames) { const size_t result = n_frames; - const float *src = (const float *)_src; - while (n_frames-- > 0) { for (unsigned i = 0; i < audio_format.channels; ++i, ++src) { jack_ringbuffer_write(ringbuffer[i], @@ -697,7 +695,7 @@ JackOutput::Play(const void *chunk, size_t size, Error &error) if (space < size) size = space; - return WriteSamples(chunk, size) * frame_size; + return WriteSamples((const float *)chunk, size) * frame_size; } static size_t