pcm/Format: use number of samples instead of end pointer
This commit is contained in:
parent
a9e849ff4f
commit
b0b7244b3a
@ -26,11 +26,10 @@
|
|||||||
#include "PcmDither.cxx" // including the .cxx file to get inlined templates
|
#include "PcmDither.cxx" // including the .cxx file to get inlined templates
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_8_to_16(int16_t *out, const int8_t *in, const int8_t *in_end)
|
pcm_convert_8_to_16(int16_t *out, const int8_t *in, size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end) {
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 8;
|
out[i] = in[i] << 8;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -50,27 +49,18 @@ pcm_convert_32_to_16(PcmDither &dither,
|
|||||||
template<SampleFormat F, class Traits=SampleTraits<F>>
|
template<SampleFormat F, class Traits=SampleTraits<F>>
|
||||||
static void
|
static void
|
||||||
ConvertFromFloat(typename Traits::pointer_type dest,
|
ConvertFromFloat(typename Traits::pointer_type dest,
|
||||||
const float *src, const float *end)
|
const float *src, size_t n)
|
||||||
{
|
{
|
||||||
constexpr auto bits = Traits::BITS;
|
constexpr auto bits = Traits::BITS;
|
||||||
|
|
||||||
const float factor = 1 << (bits - 1);
|
const float factor = 1 << (bits - 1);
|
||||||
|
|
||||||
while (src != end) {
|
for (size_t i = 0; i != n; ++i) {
|
||||||
typename Traits::long_type sample(*src++ * factor);
|
typename Traits::long_type sample(src[i] * factor);
|
||||||
*dest++ = PcmClamp<F, Traits>(sample);
|
dest[i] = PcmClamp<F, Traits>(sample);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<SampleFormat F, class Traits=SampleTraits<F>>
|
|
||||||
static void
|
|
||||||
ConvertFromFloat(typename Traits::pointer_type dest,
|
|
||||||
const float *src, size_t size)
|
|
||||||
{
|
|
||||||
ConvertFromFloat<F, Traits>(dest, src,
|
|
||||||
pcm_end_pointer(src, size));
|
|
||||||
}
|
|
||||||
|
|
||||||
template<SampleFormat F, class Traits=SampleTraits<F>>
|
template<SampleFormat F, class Traits=SampleTraits<F>>
|
||||||
static typename Traits::pointer_type
|
static typename Traits::pointer_type
|
||||||
AllocateFromFloat(PcmBuffer &buffer, const float *src, size_t src_size,
|
AllocateFromFloat(PcmBuffer &buffer, const float *src, size_t src_size,
|
||||||
@ -82,7 +72,7 @@ AllocateFromFloat(PcmBuffer &buffer, const float *src, size_t src_size,
|
|||||||
const size_t num_samples = src_size / src_sample_size;
|
const size_t num_samples = src_size / src_sample_size;
|
||||||
*dest_size_r = num_samples * sizeof(typename Traits::value_type);
|
*dest_size_r = num_samples * sizeof(typename Traits::value_type);
|
||||||
auto dest = (typename Traits::pointer_type)buffer.Get(*dest_size_r);
|
auto dest = (typename Traits::pointer_type)buffer.Get(*dest_size_r);
|
||||||
ConvertFromFloat<F, Traits>(dest, src, src_size);
|
ConvertFromFloat<F, Traits>(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,7 +83,7 @@ pcm_allocate_8_to_16(PcmBuffer &buffer,
|
|||||||
int16_t *dest;
|
int16_t *dest;
|
||||||
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
||||||
dest = (int16_t *)buffer.Get(*dest_size_r);
|
dest = (int16_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_8_to_16(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_8_to_16(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,26 +165,26 @@ pcm_convert_to_16(PcmBuffer &buffer, PcmDither &dither,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_8_to_24(int32_t *out, const int8_t *in, const int8_t *in_end)
|
pcm_convert_8_to_24(int32_t *out, const int8_t *in, size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 16;
|
out[i] = in[i] << 16;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_16_to_24(int32_t *out, const int16_t *in, const int16_t *in_end)
|
pcm_convert_16_to_24(int32_t *out, const int16_t *in, size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 8;
|
out[i] = in[i] << 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_32_to_24(int32_t *gcc_restrict out,
|
pcm_convert_32_to_24(int32_t *gcc_restrict out,
|
||||||
const int32_t *gcc_restrict in,
|
const int32_t *gcc_restrict in,
|
||||||
const int32_t *gcc_restrict in_end)
|
size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ >> 8;
|
out[i] = in[i] >> 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t *
|
static int32_t *
|
||||||
@ -204,7 +194,7 @@ pcm_allocate_8_to_24(PcmBuffer &buffer,
|
|||||||
int32_t *dest;
|
int32_t *dest;
|
||||||
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
||||||
dest = (int32_t *)buffer.Get(*dest_size_r);
|
dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_8_to_24(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_8_to_24(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,7 +206,7 @@ pcm_allocate_16_to_24(PcmBuffer &buffer,
|
|||||||
*dest_size_r = src_size * 2;
|
*dest_size_r = src_size * 2;
|
||||||
assert(*dest_size_r == src_size / sizeof(*src) * sizeof(*dest));
|
assert(*dest_size_r == src_size / sizeof(*src) * sizeof(*dest));
|
||||||
dest = (int32_t *)buffer.Get(*dest_size_r);
|
dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_16_to_24(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_16_to_24(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -226,7 +216,7 @@ pcm_allocate_32_to_24(PcmBuffer &buffer,
|
|||||||
{
|
{
|
||||||
*dest_size_r = src_size;
|
*dest_size_r = src_size;
|
||||||
int32_t *dest = (int32_t *)buffer.Get(*dest_size_r);
|
int32_t *dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_32_to_24(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_32_to_24(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -280,26 +270,26 @@ pcm_convert_to_24(PcmBuffer &buffer,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_8_to_32(int32_t *out, const int8_t *in, const int8_t *in_end)
|
pcm_convert_8_to_32(int32_t *out, const int8_t *in, size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 24;
|
out[i] = in[i] << 24;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_16_to_32(int32_t *out, const int16_t *in, const int16_t *in_end)
|
pcm_convert_16_to_32(int32_t *out, const int16_t *in, size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 16;
|
out[i] = in[i] << 16;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
pcm_convert_24_to_32(int32_t *gcc_restrict out,
|
pcm_convert_24_to_32(int32_t *gcc_restrict out,
|
||||||
const int32_t *gcc_restrict in,
|
const int32_t *gcc_restrict in,
|
||||||
const int32_t *gcc_restrict in_end)
|
size_t n)
|
||||||
{
|
{
|
||||||
while (in < in_end)
|
for (size_t i = 0; i != n; ++i)
|
||||||
*out++ = *in++ << 8;
|
out[i] = in[i] << 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t *
|
static int32_t *
|
||||||
@ -309,7 +299,7 @@ pcm_allocate_8_to_32(PcmBuffer &buffer,
|
|||||||
int32_t *dest;
|
int32_t *dest;
|
||||||
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
*dest_size_r = src_size / sizeof(*src) * sizeof(*dest);
|
||||||
dest = (int32_t *)buffer.Get(*dest_size_r);
|
dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_8_to_32(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_8_to_32(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,7 +311,7 @@ pcm_allocate_16_to_32(PcmBuffer &buffer,
|
|||||||
*dest_size_r = src_size * 2;
|
*dest_size_r = src_size * 2;
|
||||||
assert(*dest_size_r == src_size / sizeof(*src) * sizeof(*dest));
|
assert(*dest_size_r == src_size / sizeof(*src) * sizeof(*dest));
|
||||||
dest = (int32_t *)buffer.Get(*dest_size_r);
|
dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_16_to_32(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_16_to_32(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -332,7 +322,7 @@ pcm_allocate_24p32_to_32(PcmBuffer &buffer,
|
|||||||
{
|
{
|
||||||
*dest_size_r = src_size;
|
*dest_size_r = src_size;
|
||||||
int32_t *dest = (int32_t *)buffer.Get(*dest_size_r);
|
int32_t *dest = (int32_t *)buffer.Get(*dest_size_r);
|
||||||
pcm_convert_24_to_32(dest, src, pcm_end_pointer(src, src_size));
|
pcm_convert_24_to_32(dest, src, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -346,7 +336,7 @@ pcm_allocate_float_to_32(PcmBuffer &buffer,
|
|||||||
dest_size_r);
|
dest_size_r);
|
||||||
|
|
||||||
/* convert to 32 bit in-place */
|
/* convert to 32 bit in-place */
|
||||||
pcm_convert_24_to_32(dest, dest, pcm_end_pointer(dest, *dest_size_r));
|
pcm_convert_24_to_32(dest, dest, src_size / sizeof(*src));
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user