From 69476b4f2193546cb72c3def9679136a182adfe3 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 22 Jun 2015 14:45:59 +0200 Subject: pcm/Interleave: add optimization for 32 bit samples Move code from the "vorbis" decoder. --- src/pcm/Interleave.cxx | 33 ++++++++++++++++++++++++++++----- 1 file changed, 28 insertions(+), 5 deletions(-) (limited to 'src/pcm/Interleave.cxx') diff --git a/src/pcm/Interleave.cxx b/src/pcm/Interleave.cxx index 14ca53434..8f8f152c5 100644 --- a/src/pcm/Interleave.cxx +++ b/src/pcm/Interleave.cxx @@ -20,7 +20,6 @@ #include "config.h" #include "Interleave.hxx" -#include #include static void @@ -37,13 +36,37 @@ GenericPcmInterleave(uint8_t *gcc_restrict dest, } } +void +PcmInterleave32(int32_t *gcc_restrict dest, + const ConstBuffer src, + size_t n_frames) +{ + for (const auto *s : src) { + auto *d = dest++; + + for (const auto *const s_end = s + n_frames; + s != s_end; ++s, d += src.size) + *d = *s; + } +} + void PcmInterleave(void *gcc_restrict dest, ConstBuffer src, size_t n_frames, size_t sample_size) { - GenericPcmInterleave((uint8_t *)dest, - ConstBuffer((const uint8_t *const*)src.data, - src.size), - n_frames, sample_size); + switch (sample_size) { + case 4: + PcmInterleave32((int32_t *)dest, + ConstBuffer((const int32_t *const*)src.data, + src.size), + n_frames); + break; + + default: + GenericPcmInterleave((uint8_t *)dest, + ConstBuffer((const uint8_t *const*)src.data, + src.size), + n_frames, sample_size); + } } -- cgit v1.2.3