mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-31 22:25:38 -04:00
fmt-ops: add sse2 version of f32 to s16 planar/interleaved
This commit is contained in:
parent
21fc163c49
commit
a520335581
3 changed files with 60 additions and 0 deletions
|
|
@ -543,6 +543,55 @@ conv_f32d_to_s32_sse2(struct convert *conv, void * SPA_RESTRICT dst[], const voi
|
||||||
conv_f32d_to_s32_1s_sse2(conv, &d[i], &src[i], n_channels, n_samples);
|
conv_f32d_to_s32_1s_sse2(conv, &d[i], &src[i], n_channels, n_samples);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
conv_f32_to_s16_1_sse2(void *data, void * SPA_RESTRICT dst, const void * SPA_RESTRICT src,
|
||||||
|
uint32_t n_samples)
|
||||||
|
{
|
||||||
|
const float *s = src;
|
||||||
|
int16_t *d = dst;
|
||||||
|
uint32_t n, unrolled;
|
||||||
|
__m128 in[2];
|
||||||
|
__m128i out[2];
|
||||||
|
__m128 int_max = _mm_set1_ps(S16_MAX_F);
|
||||||
|
__m128 int_min = _mm_sub_ps(_mm_setzero_ps(), int_max);
|
||||||
|
|
||||||
|
if (SPA_IS_ALIGNED(s, 16))
|
||||||
|
unrolled = n_samples & ~7;
|
||||||
|
else
|
||||||
|
unrolled = 0;
|
||||||
|
|
||||||
|
for(n = 0; n < unrolled; n += 8) {
|
||||||
|
in[0] = _mm_mul_ps(_mm_load_ps(&s[n]), int_max);
|
||||||
|
in[1] = _mm_mul_ps(_mm_load_ps(&s[n+4]), int_max);
|
||||||
|
out[0] = _mm_cvtps_epi32(in[0]);
|
||||||
|
out[1] = _mm_cvtps_epi32(in[1]);
|
||||||
|
out[0] = _mm_packs_epi32(out[0], out[1]);
|
||||||
|
_mm_storeu_si128((__m128i*)(d+0), out[0]);
|
||||||
|
d += 8;
|
||||||
|
}
|
||||||
|
for(; n < n_samples; n++) {
|
||||||
|
in[0] = _mm_mul_ss(_mm_load_ss(&s[n]), int_max);
|
||||||
|
in[0] = _mm_min_ss(int_max, _mm_max_ss(in[0], int_min));
|
||||||
|
*d++ = _mm_cvtss_si32(in[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
conv_f32d_to_s16d_sse2(struct convert *conv, void * SPA_RESTRICT dst[], const void * SPA_RESTRICT src[],
|
||||||
|
uint32_t n_samples)
|
||||||
|
{
|
||||||
|
uint32_t i, n_channels = conv->n_channels;
|
||||||
|
for(i = 0; i < n_channels; i++)
|
||||||
|
conv_f32_to_s16_1_sse2(conv, dst[i], src[i], n_samples);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
conv_f32_to_s16_sse2(struct convert *conv, void * SPA_RESTRICT dst[], const void * SPA_RESTRICT src[],
|
||||||
|
uint32_t n_samples)
|
||||||
|
{
|
||||||
|
conv_f32_to_s16_1_sse2(conv, dst[0], src[0], n_samples * conv->n_channels);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
conv_f32d_to_s16_1s_sse2(void *data, void * SPA_RESTRICT dst, const void * SPA_RESTRICT src[],
|
conv_f32d_to_s16_1s_sse2(void *data, void * SPA_RESTRICT dst, const void * SPA_RESTRICT src[],
|
||||||
uint32_t n_channels, uint32_t n_samples)
|
uint32_t n_channels, uint32_t n_samples)
|
||||||
|
|
|
||||||
|
|
@ -115,9 +115,18 @@ static struct conv_info conv_table[] =
|
||||||
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_U8P, 0, 0, conv_f32_to_u8d_c },
|
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_U8P, 0, 0, conv_f32_to_u8d_c },
|
||||||
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_U8, 0, 0, conv_f32d_to_u8_c },
|
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_U8, 0, 0, conv_f32d_to_u8_c },
|
||||||
|
|
||||||
|
#if defined (HAVE_SSE2)
|
||||||
|
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_S16, 0, SPA_CPU_FLAG_SSE2, conv_f32_to_s16_sse2 },
|
||||||
|
#endif
|
||||||
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_S16, 0, 0, conv_f32_to_s16_c },
|
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_S16, 0, 0, conv_f32_to_s16_c },
|
||||||
|
|
||||||
|
#if defined (HAVE_SSE2)
|
||||||
|
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_S16P, 0, SPA_CPU_FLAG_SSE2, conv_f32d_to_s16d_sse2 },
|
||||||
|
#endif
|
||||||
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_S16P, 0, 0, conv_f32d_to_s16d_c },
|
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_S16P, 0, 0, conv_f32d_to_s16d_c },
|
||||||
|
|
||||||
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_S16P, 0, 0, conv_f32_to_s16d_c },
|
{ SPA_AUDIO_FORMAT_F32, SPA_AUDIO_FORMAT_S16P, 0, 0, conv_f32_to_s16d_c },
|
||||||
|
|
||||||
#if defined (HAVE_NEON)
|
#if defined (HAVE_NEON)
|
||||||
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_S16, 0, SPA_CPU_FLAG_NEON, conv_f32d_to_s16_neon },
|
{ SPA_AUDIO_FORMAT_F32P, SPA_AUDIO_FORMAT_S16, 0, SPA_CPU_FLAG_NEON, conv_f32d_to_s16_neon },
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -196,8 +196,10 @@ DEFINE_FUNCTION(s16_to_f32d, sse2);
|
||||||
DEFINE_FUNCTION(s24_to_f32d, sse2);
|
DEFINE_FUNCTION(s24_to_f32d, sse2);
|
||||||
DEFINE_FUNCTION(s32_to_f32d, sse2);
|
DEFINE_FUNCTION(s32_to_f32d, sse2);
|
||||||
DEFINE_FUNCTION(f32d_to_s32, sse2);
|
DEFINE_FUNCTION(f32d_to_s32, sse2);
|
||||||
|
DEFINE_FUNCTION(f32_to_s16, sse2);
|
||||||
DEFINE_FUNCTION(f32d_to_s16_2, sse2);
|
DEFINE_FUNCTION(f32d_to_s16_2, sse2);
|
||||||
DEFINE_FUNCTION(f32d_to_s16, sse2);
|
DEFINE_FUNCTION(f32d_to_s16, sse2);
|
||||||
|
DEFINE_FUNCTION(f32d_to_s16d, sse2);
|
||||||
#endif
|
#endif
|
||||||
#if defined(HAVE_SSSE3)
|
#if defined(HAVE_SSSE3)
|
||||||
DEFINE_FUNCTION(s24_to_f32d, ssse3);
|
DEFINE_FUNCTION(s24_to_f32d, ssse3);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue