summaryrefslogtreecommitdiffstats
path: root/interleave.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2007-05-12 23:38:38 +0000
committerLennart Poettering <lennart@poettering.net>2007-05-12 23:38:38 +0000
commita64e85acf96bc0c55363fe55c9e9116aef2a8584 (patch)
tree69ec57b46bdebe0e7496bf11ea9a54cdf5806904 /interleave.c
parent2eb6dec8e9f0114bdbad59cf8f11f197f8fdaaf3 (diff)
resampling works
git-svn-id: file:///home/lennart/svn/public/libsydney/trunk@4 9ba3c220-e4d3-45a2-8aa3-73fcc9aff6ce
Diffstat (limited to 'interleave.c')
-rw-r--r--interleave.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/interleave.c b/interleave.c
new file mode 100644
index 0000000..e503671
--- /dev/null
+++ b/interleave.c
@@ -0,0 +1,64 @@
+#include <inttypes.h>
+
+#include "macro.h"
+#include "interleave.h"
+
+static void interleave8(void *_dst, size_t dstr, const void *_src, size_t sstr, size_t bytes) {
+ uint8_t *dst = _dst;
+ const uint8_t *src = _src;
+
+ for (; bytes > 0; bytes--, src += sstr, dst += dstr)
+ *dst = *src;
+}
+
+static void interleave16(void *_dst, size_t dstr, const void *_src, size_t sstr, size_t bytes) {
+ uint16_t *dst = _dst;
+ const uint16_t *src = _src;
+ unsigned n = bytes / sizeof(uint16_t);
+
+ for (; n > 0; n--, src += sstr/sizeof(uint16_t), dst += dstr/sizeof(uint16_t))
+ *dst = *src;
+}
+
+static void interleave24(void *_dst, size_t dstr, const void *_src, size_t sstr, size_t bytes) {
+ uint8_t *dst = _dst;
+ const uint8_t *src = _src;
+ unsigned n = bytes / 3;
+
+ for (; n > 0; n--, src += sstr/3, dst += dstr/3) {
+ dst[0] = src[0];
+ dst[1] = src[1];
+ dst[2] = src[2];
+ }
+}
+
+static void interleave32(void *_dst, size_t dstr, const void *_src, size_t sstr, size_t bytes) {
+ uint32_t *dst = _dst;
+ const uint32_t *src = _src;
+ unsigned n = bytes / sizeof(uint32_t);
+
+ for (; n > 0; n--, src += sstr/sizeof(uint32_t), dst += dstr/sizeof(uint32_t))
+ *dst = *src;
+}
+
+interleave_func_t get_interleave_func(sa_pcm_format_t f) {
+
+ static const interleave_func_t funcs[SA_PCM_FORMAT_MAX] = {
+ [SA_PCM_FORMAT_U8] = interleave8,
+ [SA_PCM_FORMAT_ULAW] = interleave8,
+ [SA_PCM_FORMAT_ALAW] = interleave8,
+ [SA_PCM_FORMAT_S16_LE] = interleave16,
+ [SA_PCM_FORMAT_S16_BE] = interleave16,
+ [SA_PCM_FORMAT_S24_LE] = interleave24,
+ [SA_PCM_FORMAT_S24_BE] = interleave24,
+ [SA_PCM_FORMAT_S32_LE] = interleave32,
+ [SA_PCM_FORMAT_S32_BE] = interleave32,
+ [SA_PCM_FORMAT_FLOAT32_LE] = interleave32,
+ [SA_PCM_FORMAT_FLOAT32_BE] = interleave32,
+ };
+
+ sa_assert(f < SA_PCM_FORMAT_MAX);
+
+ return funcs[f];
+}
+