mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 18:35:35 +00:00
108 lines
5 KiB
C
108 lines
5 KiB
C
/* GStreamer
|
|
* Copyright (C) <2015> Wim Taymans <wim.taymans@gmail.com>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Library General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library General Public
|
|
* License along with this library; if not, write to the
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
* Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef __GST_AUDIO_RESAMPLER_MACROS_H__
|
|
#define __GST_AUDIO_RESAMPLER_MACROS_H__
|
|
|
|
#include <string.h>
|
|
|
|
#include "audio-resampler-private.h"
|
|
|
|
#define PRECISION_S16 15
|
|
#define PRECISION_S32 31
|
|
|
|
#define DECL_GET_TAPS_FULL_FUNC(type) \
|
|
gpointer \
|
|
get_taps_##type##_full (GstAudioResampler * resampler, \
|
|
gint *samp_index, gint *samp_phase, type icoeff[4])
|
|
|
|
DECL_GET_TAPS_FULL_FUNC (gint16);
|
|
DECL_GET_TAPS_FULL_FUNC (gint32);
|
|
DECL_GET_TAPS_FULL_FUNC (gfloat);
|
|
DECL_GET_TAPS_FULL_FUNC (gdouble);
|
|
|
|
|
|
#define DECL_GET_TAPS_INTERPOLATE_FUNC(type, inter) \
|
|
gpointer \
|
|
get_taps_##type##_##inter (GstAudioResampler * resampler, \
|
|
gint *samp_index, gint *samp_phase, type icoeff[4]) \
|
|
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gint16, linear);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gint32, linear);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gfloat, linear);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gdouble, linear);
|
|
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gint16, cubic);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gint32, cubic);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gfloat, cubic);
|
|
DECL_GET_TAPS_INTERPOLATE_FUNC (gdouble, cubic);
|
|
|
|
|
|
#define DECL_RESAMPLE_FUNC(type,inter,channels,arch) \
|
|
void \
|
|
resample_ ##type## _ ##inter## _ ##channels## _ ##arch (GstAudioResampler * resampler, \
|
|
gpointer in[], gsize in_len, gpointer out[], gsize out_len, \
|
|
gsize * consumed)
|
|
|
|
#define MAKE_RESAMPLE_FUNC(type,inter,channels,arch) \
|
|
DECL_RESAMPLE_FUNC (type, inter, channels, arch) \
|
|
{ \
|
|
gint c, di = 0; \
|
|
gint n_taps = resampler->n_taps; \
|
|
gint blocks = resampler->blocks; \
|
|
gint ostride = resampler->ostride; \
|
|
gint taps_stride = resampler->taps_stride; \
|
|
gint samp_index = 0; \
|
|
gint samp_phase = 0; \
|
|
\
|
|
for (c = 0; c < blocks; c++) { \
|
|
type *ip = in[c]; \
|
|
type *op = ostride == 1 ? out[c] : (type *)out[0] + c; \
|
|
\
|
|
samp_index = resampler->samp_index; \
|
|
samp_phase = resampler->samp_phase; \
|
|
\
|
|
for (di = 0; di < out_len; di++) { \
|
|
type *ipp, icoeff[4], *taps; \
|
|
\
|
|
ipp = &ip[samp_index * channels]; \
|
|
\
|
|
taps = get_taps_ ##type##_##inter \
|
|
(resampler, &samp_index, &samp_phase, icoeff); \
|
|
inner_product_ ##type##_##inter##_##channels##_##arch \
|
|
(op, ipp, taps, n_taps, icoeff, taps_stride); \
|
|
op += ostride; \
|
|
} \
|
|
if (in_len > samp_index) \
|
|
memmove (ip, &ip[samp_index * channels], \
|
|
(in_len - samp_index) * sizeof(type) * channels); \
|
|
} \
|
|
*consumed = samp_index - resampler->samp_index; \
|
|
\
|
|
resampler->samp_index = 0; \
|
|
resampler->samp_phase = samp_phase; \
|
|
}
|
|
|
|
#define DECL_RESAMPLE_FUNC_STATIC(type,inter,channels,arch) \
|
|
static DECL_RESAMPLE_FUNC (type, inter, channels, arch)
|
|
|
|
#define MAKE_RESAMPLE_FUNC_STATIC(type,inter,channels,arch) \
|
|
static MAKE_RESAMPLE_FUNC (type, inter, channels, arch)
|
|
|
|
#endif /* __GST_AUDIO_RESAMPLER_MACROS_H__ */
|