2012-04-21 21:13:50 +00:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2014-01-01 00:50:59 +00:00
|
|
|
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
2014-09-26 13:50:24 +00:00
|
|
|
* Copyright (C) 2011-2014 - Daniel De Matteis
|
2011-02-06 11:57:12 +00:00
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
2011-02-06 11:57:12 +00:00
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
2011-02-06 11:57:12 +00:00
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
2012-04-21 21:31:57 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
2011-02-06 11:57:12 +00:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2012-04-21 21:25:32 +00:00
|
|
|
#ifndef __RARCH_RESAMPLER_H
|
|
|
|
#define __RARCH_RESAMPLER_H
|
2011-02-06 11:57:12 +00:00
|
|
|
|
2014-09-26 14:13:10 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
2012-07-06 15:36:37 +00:00
|
|
|
#endif
|
|
|
|
|
2011-02-06 11:57:12 +00:00
|
|
|
#include <stddef.h>
|
2012-07-06 15:36:37 +00:00
|
|
|
#include <stdint.h>
|
2012-02-25 13:02:56 +00:00
|
|
|
#include <math.h>
|
2014-09-09 19:54:41 +00:00
|
|
|
#include "../../boolean.h"
|
2012-02-25 13:02:56 +00:00
|
|
|
|
|
|
|
#ifndef M_PI
|
|
|
|
#define M_PI 3.14159265358979323846264338327
|
|
|
|
#endif
|
2011-02-06 11:57:12 +00:00
|
|
|
|
2014-09-26 14:13:10 +00:00
|
|
|
#define RESAMPLER_SIMD_SSE (1 << 0)
|
|
|
|
#define RESAMPLER_SIMD_SSE2 (1 << 1)
|
|
|
|
#define RESAMPLER_SIMD_VMX (1 << 2)
|
|
|
|
#define RESAMPLER_SIMD_VMX128 (1 << 3)
|
|
|
|
#define RESAMPLER_SIMD_AVX (1 << 4)
|
|
|
|
#define RESAMPLER_SIMD_NEON (1 << 5)
|
|
|
|
#define RESAMPLER_SIMD_SSE3 (1 << 6)
|
|
|
|
#define RESAMPLER_SIMD_SSSE3 (1 << 7)
|
|
|
|
#define RESAMPLER_SIMD_MMX (1 << 8)
|
|
|
|
#define RESAMPLER_SIMD_MMXEXT (1 << 9)
|
|
|
|
#define RESAMPLER_SIMD_SSE4 (1 << 10)
|
|
|
|
#define RESAMPLER_SIMD_SSE42 (1 << 11)
|
|
|
|
#define RESAMPLER_SIMD_AVX2 (1 << 12)
|
|
|
|
#define RESAMPLER_SIMD_VFPU (1 << 13)
|
|
|
|
#define RESAMPLER_SIMD_PS (1 << 14)
|
|
|
|
|
|
|
|
/* A bit-mask of all supported SIMD instruction sets.
|
|
|
|
* Allows an implementation to pick different
|
|
|
|
* dspfilter_implementation structs.
|
|
|
|
*/
|
|
|
|
typedef unsigned resampler_simd_mask_t;
|
|
|
|
|
2014-09-26 14:36:36 +00:00
|
|
|
#define RESAMPLER_API_VERSION 1
|
|
|
|
|
2012-02-23 22:19:23 +00:00
|
|
|
struct resampler_data
|
2011-02-06 11:57:12 +00:00
|
|
|
{
|
2013-02-16 11:30:26 +00:00
|
|
|
const float *data_in;
|
|
|
|
float *data_out;
|
2011-02-06 11:57:12 +00:00
|
|
|
|
2011-02-06 17:38:04 +00:00
|
|
|
size_t input_frames;
|
|
|
|
size_t output_frames;
|
|
|
|
|
2011-10-15 12:33:41 +00:00
|
|
|
double ratio;
|
2011-02-06 11:57:12 +00:00
|
|
|
};
|
|
|
|
|
2014-09-26 14:49:03 +00:00
|
|
|
/* Bandwidth factor. Will be < 1.0 for downsampling, > 1.0 for upsampling.
|
|
|
|
* Corresponds to expected resampling ratio. */
|
|
|
|
typedef void *(*resampler_init_t)(double bandwidth_mod,
|
|
|
|
resampler_simd_mask_t mask);
|
|
|
|
|
|
|
|
/* Frees the handle. */
|
|
|
|
typedef void (*resampler_free_t)(void *data);
|
|
|
|
|
|
|
|
/* Processes input data. */
|
|
|
|
typedef void (*resampler_process_t)(void *_data, struct resampler_data *data);
|
|
|
|
|
2013-02-08 10:49:51 +00:00
|
|
|
typedef struct rarch_resampler
|
|
|
|
{
|
2014-09-26 14:49:03 +00:00
|
|
|
resampler_init_t init;
|
|
|
|
resampler_process_t process;
|
|
|
|
resampler_free_t free;
|
2014-09-26 14:36:36 +00:00
|
|
|
|
|
|
|
/* Must be RESAMPLER_API_VERSION */
|
|
|
|
unsigned api_version;
|
|
|
|
|
|
|
|
/* Human readable identifier of implementation. */
|
2013-02-08 10:49:51 +00:00
|
|
|
const char *ident;
|
2014-09-26 14:36:36 +00:00
|
|
|
|
2014-09-26 14:49:03 +00:00
|
|
|
/* Computer-friendly short version of ident.
|
|
|
|
* Lower case, no spaces and special characters, etc. */
|
|
|
|
const char *short_ident;
|
2013-02-08 10:49:51 +00:00
|
|
|
} rarch_resampler_t;
|
|
|
|
|
2014-09-15 22:54:18 +00:00
|
|
|
typedef struct audio_frame_float
|
|
|
|
{
|
|
|
|
float l;
|
|
|
|
float r;
|
|
|
|
} audio_frame_float_t;
|
|
|
|
|
2014-09-12 22:10:15 +00:00
|
|
|
extern rarch_resampler_t sinc_resampler;
|
|
|
|
extern rarch_resampler_t CC_resampler;
|
|
|
|
extern rarch_resampler_t nearest_resampler;
|
2013-02-08 10:49:51 +00:00
|
|
|
|
2014-09-09 03:56:12 +00:00
|
|
|
/* Reallocs resampler. Will free previous handle before
|
|
|
|
* allocating a new one. If ident is NULL, first resampler will be used. */
|
|
|
|
bool rarch_resampler_realloc(void **re, const rarch_resampler_t **backend,
|
|
|
|
const char *ident, double bw_ratio);
|
2013-02-08 10:49:51 +00:00
|
|
|
|
2014-09-09 03:56:12 +00:00
|
|
|
/* Convenience macros.
|
|
|
|
* freep makes sure to set handles to NULL to avoid double-free
|
|
|
|
* in rarch_resampler_realloc. */
|
2013-02-08 10:49:51 +00:00
|
|
|
#define rarch_resampler_freep(backend, handle) do { \
|
|
|
|
if (*(backend) && *(handle)) \
|
|
|
|
(*backend)->free(*handle); \
|
|
|
|
*backend = NULL; \
|
|
|
|
*handle = NULL; \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define rarch_resampler_process(backend, handle, data) do { \
|
|
|
|
(backend)->process(handle, data); \
|
|
|
|
} while(0)
|
2011-02-06 11:57:12 +00:00
|
|
|
|
2014-09-26 14:13:10 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2011-02-06 11:57:12 +00:00
|
|
|
#endif
|
|
|
|
|