Commit e71a6529 authored by Max Kellermann's avatar Max Kellermann

pcm_mix: implement float samples

parent bfef0fbf
...@@ -98,6 +98,20 @@ pcm_add_vol_32(int32_t *buffer1, const int32_t *buffer2, ...@@ -98,6 +98,20 @@ pcm_add_vol_32(int32_t *buffer1, const int32_t *buffer2,
} }
} }
static void
pcm_add_vol_float(float *buffer1, const float *buffer2,
unsigned num_samples, float volume1, float volume2)
{
while (num_samples > 0) {
float sample1 = *buffer1;
float sample2 = *buffer2++;
sample1 = (sample1 * volume1 + sample2 * volume2);
*buffer1++ = sample1;
--num_samples;
}
}
static bool static bool
pcm_add_vol(void *buffer1, const void *buffer2, size_t size, pcm_add_vol(void *buffer1, const void *buffer2, size_t size,
int vol1, int vol2, int vol1, int vol2,
...@@ -130,8 +144,10 @@ pcm_add_vol(void *buffer1, const void *buffer2, size_t size, ...@@ -130,8 +144,10 @@ pcm_add_vol(void *buffer1, const void *buffer2, size_t size,
return true; return true;
case SAMPLE_FORMAT_FLOAT: case SAMPLE_FORMAT_FLOAT:
/* XXX */ pcm_add_vol_float(buffer1, buffer2, size / 4,
return false; pcm_volume_to_float(vol1),
pcm_volume_to_float(vol2));
return true;
} }
/* unreachable */ /* unreachable */
...@@ -195,6 +211,17 @@ pcm_add_32(int32_t *buffer1, const int32_t *buffer2, unsigned num_samples) ...@@ -195,6 +211,17 @@ pcm_add_32(int32_t *buffer1, const int32_t *buffer2, unsigned num_samples)
} }
} }
static void
pcm_add_float(float *buffer1, const float *buffer2, unsigned num_samples)
{
while (num_samples > 0) {
float sample1 = *buffer1;
float sample2 = *buffer2++;
*buffer1++ = sample1 + sample2;
--num_samples;
}
}
static bool static bool
pcm_add(void *buffer1, const void *buffer2, size_t size, pcm_add(void *buffer1, const void *buffer2, size_t size,
enum sample_format format) enum sample_format format)
...@@ -222,8 +249,8 @@ pcm_add(void *buffer1, const void *buffer2, size_t size, ...@@ -222,8 +249,8 @@ pcm_add(void *buffer1, const void *buffer2, size_t size,
return true; return true;
case SAMPLE_FORMAT_FLOAT: case SAMPLE_FORMAT_FLOAT:
/* XXX */ pcm_add_float(buffer1, buffer2, size / 4);
return false; return true;
} }
/* unreachable */ /* unreachable */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment