pcm/PcmVolume: use the SampleTraits library

This commit is contained in:
Max Kellermann 2013-12-02 08:58:40 +01:00
parent 83e4475021
commit 30c4136c4d

View File

@ -20,37 +20,41 @@
#include "config.h" #include "config.h"
#include "PcmVolume.hxx" #include "PcmVolume.hxx"
#include "PcmUtils.hxx" #include "PcmUtils.hxx"
#include "Traits.hxx"
#include "AudioFormat.hxx" #include "AudioFormat.hxx"
#include <stdint.h> #include <stdint.h>
#include <string.h> #include <string.h>
template<SampleFormat F, class Traits=SampleTraits<F>>
static void static void
pcm_volume_change_8(int8_t *buffer, const int8_t *end, int volume) pcm_volume_change(typename Traits::pointer_type buffer,
typename Traits::const_pointer_type end,
int volume)
{ {
while (buffer < end) { while (buffer < end) {
int32_t sample = *buffer; typename Traits::long_type sample = *buffer;
sample = (sample * volume + pcm_volume_dither() + sample = (sample * volume + pcm_volume_dither() +
PCM_VOLUME_1 / 2) PCM_VOLUME_1 / 2)
/ PCM_VOLUME_1; / PCM_VOLUME_1;
*buffer++ = PcmClamp<int8_t, int16_t, 8>(sample); *buffer++ = PcmClamp<typename Traits::value_type,
typename Traits::long_type,
Traits::BITS>(sample);
} }
} }
static void
pcm_volume_change_8(int8_t *buffer, const int8_t *end, int volume)
{
pcm_volume_change<SampleFormat::S8>(buffer, end, volume);
}
static void static void
pcm_volume_change_16(int16_t *buffer, const int16_t *end, int volume) pcm_volume_change_16(int16_t *buffer, const int16_t *end, int volume)
{ {
while (buffer < end) { pcm_volume_change<SampleFormat::S16>(buffer, end, volume);
int32_t sample = *buffer;
sample = (sample * volume + pcm_volume_dither() +
PCM_VOLUME_1 / 2)
/ PCM_VOLUME_1;
*buffer++ = PcmClamp<int16_t, int32_t, 16>(sample);
}
} }
#ifdef __i386__ #ifdef __i386__
@ -87,44 +91,32 @@ pcm_volume_sample_24(int32_t sample, int32_t volume, gcc_unused int32_t dither)
static void static void
pcm_volume_change_24(int32_t *buffer, const int32_t *end, int volume) pcm_volume_change_24(int32_t *buffer, const int32_t *end, int volume)
{ {
while (buffer < end) {
#ifdef __i386__ #ifdef __i386__
while (buffer < end) {
/* assembly version for i386 */ /* assembly version for i386 */
int32_t sample = *buffer; int32_t sample = *buffer;
sample = pcm_volume_sample_24(sample, volume, sample = pcm_volume_sample_24(sample, volume,
pcm_volume_dither()); pcm_volume_dither());
#else
/* portable version */
int64_t sample = *buffer;
sample = (sample * volume + pcm_volume_dither() +
PCM_VOLUME_1 / 2)
/ PCM_VOLUME_1;
#endif
*buffer++ = PcmClamp<int32_t, int32_t, 24>(sample);
} }
#else
pcm_volume_change<SampleFormat::S24_P32>(buffer, end, volume);
#endif
} }
static void static void
pcm_volume_change_32(int32_t *buffer, const int32_t *end, int volume) pcm_volume_change_32(int32_t *buffer, const int32_t *end, int volume)
{ {
while (buffer < end) {
#ifdef __i386__ #ifdef __i386__
while (buffer < end) {
/* assembly version for i386 */ /* assembly version for i386 */
int32_t sample = *buffer; int32_t sample = *buffer;
*buffer++ = pcm_volume_sample_24(sample, volume, 0); *buffer++ = pcm_volume_sample_24(sample, volume, 0);
#else
/* portable version */
int64_t sample = *buffer;
sample = (sample * volume + pcm_volume_dither() +
PCM_VOLUME_1 / 2)
/ PCM_VOLUME_1;
*buffer++ = PcmClamp<int32_t, int64_t, 32>(sample);
#endif
} }
#else
pcm_volume_change<SampleFormat::S32>(buffer, end, volume);
#endif
} }
static void static void