121 lines
3.9 KiB
C
Raw Normal View History

/* Copyright (C) 2010-2016 The RetroArch team
2012-04-07 13:26:27 +02:00
*
* ---------------------------------------------------------------------------------------
* The following license statement only applies to this file (s16_to_float.h).
* ---------------------------------------------------------------------------------------
2012-04-07 13:26:27 +02:00
*
* Permission is hereby granted, free of charge,
* to any person obtaining a copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
* and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
2012-04-07 13:26:27 +02:00
*
* The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
2012-04-07 13:26:27 +02:00
*/
#ifndef __LIBRETRO_SDK_CONVERSION_S16_TO_FLOAT_H__
#define __LIBRETRO_SDK_CONVERSION_S16_TO_FLOAT_H__
2011-10-15 17:47:29 +02:00
#include <stdint.h>
2011-12-02 01:34:02 +01:00
#include <stddef.h>
2011-10-15 17:47:29 +02:00
#include <retro_common_api.h>
RETRO_BEGIN_DECLS
2012-12-09 17:28:49 +02:00
2012-12-05 23:17:07 +01:00
#if defined(__SSE2__)
2016-05-16 11:24:34 +02:00
#define convert_s16_to_float convert_s16_to_float_SSE2
2011-10-23 02:56:33 +02:00
2015-01-09 01:43:57 +01:00
/**
2016-05-16 11:24:34 +02:00
* convert_s16_to_float_SSE2:
2015-01-09 01:43:57 +01:00
* @out : output buffer
* @in : input buffer
* @samples : size of samples to be converted
2016-05-16 11:24:34 +02:00
* @gain : gain applied (.e.g. audio volume)
2015-01-09 01:43:57 +01:00
*
2016-05-16 11:24:34 +02:00
* Converts from signed integer 16-bit
2015-01-09 01:43:57 +01:00
* to floating point.
*
* SSE2 implementation callback function.
**/
2016-05-16 11:24:34 +02:00
void convert_s16_to_float_SSE2(float *out,
const int16_t *in, size_t samples, float gain);
2011-10-23 02:56:33 +02:00
2012-12-05 23:17:07 +01:00
#elif defined(__ALTIVEC__)
2016-05-16 11:24:34 +02:00
#define convert_s16_to_float convert_s16_to_float_altivec
2011-10-15 18:09:44 +02:00
2015-01-09 01:43:57 +01:00
/**
2016-05-16 11:24:34 +02:00
* convert_s16_to_float_altivec:
2015-01-09 01:43:57 +01:00
* @out : output buffer
* @in : input buffer
* @samples : size of samples to be converted
2016-05-16 11:24:34 +02:00
* @gain : gain applied (.e.g. audio volume)
2015-01-09 01:43:57 +01:00
*
2016-05-16 11:24:34 +02:00
* Converts from signed integer 16-bit
2015-01-09 01:43:57 +01:00
* to floating point.
*
* AltiVec implementation callback function.
**/
2016-05-16 11:24:34 +02:00
void convert_s16_to_float_altivec(float *out,
const int16_t *in, size_t samples, float gain);
2011-10-15 18:09:44 +02:00
2015-09-18 01:21:24 +02:00
#elif defined(__ARM_NEON__) && !defined(VITA)
2016-05-16 11:24:34 +02:00
#define convert_s16_to_float convert_s16_to_float_arm
2012-12-05 22:45:29 +01:00
2016-05-16 11:24:34 +02:00
void (*convert_s16_to_float_arm)(float *out,
2012-12-05 22:45:29 +01:00
const int16_t *in, size_t samples, float gain);
2015-01-09 01:43:57 +01:00
#elif defined(_MIPS_ARCH_ALLEGREX)
2016-05-16 11:24:34 +02:00
#define convert_s16_to_float convert_s16_to_float_ALLEGREX
2012-12-05 22:45:29 +01:00
2015-01-09 01:43:57 +01:00
/**
2016-05-16 11:24:34 +02:00
* convert_s16_to_float_ALLEGREX:
2015-01-09 01:43:57 +01:00
* @out : output buffer
* @in : input buffer
* @samples : size of samples to be converted
2016-05-16 11:24:34 +02:00
* @gain : gain applied (.e.g. audio volume)
2015-01-09 01:43:57 +01:00
*
2016-05-16 11:24:34 +02:00
* Converts from signed integer 16-bit
2015-01-09 01:43:57 +01:00
* to floating point.
*
* MIPS ALLEGREX implementation callback function.
**/
2016-05-16 11:24:34 +02:00
void convert_s16_to_float_ALLEGREX(float *out,
const int16_t *in, size_t samples, float gain);
2011-12-02 01:34:02 +01:00
#else
2016-05-16 11:24:34 +02:00
#define convert_s16_to_float convert_s16_to_float_C
2011-10-15 18:09:44 +02:00
#endif
2015-01-09 01:43:57 +01:00
/**
2016-05-16 11:24:34 +02:00
* convert_s16_to_float_C:
2015-01-09 01:43:57 +01:00
* @out : output buffer
* @in : input buffer
* @samples : size of samples to be converted
2016-05-16 11:24:34 +02:00
* @gain : gain applied (.e.g. audio volume)
2015-01-09 01:43:57 +01:00
*
2016-05-16 11:24:34 +02:00
* Converts from signed integer 16-bit
2015-01-09 01:43:57 +01:00
* to floating point.
*
* C implementation callback function.
**/
2016-05-16 11:24:34 +02:00
void convert_s16_to_float_C(float *out,
const int16_t *in, size_t samples, float gain);
2015-01-09 01:43:57 +01:00
/**
2016-05-16 11:24:34 +02:00
* convert_init_simd:
2015-01-09 01:43:57 +01:00
*
2016-05-16 11:24:34 +02:00
* Sets up function pointers for conversion
2015-01-09 01:43:57 +01:00
* functions based on CPU features.
**/
2016-05-16 11:24:34 +02:00
void convert_init_simd(void);
RETRO_END_DECLS
2011-10-15 17:47:29 +02:00
#endif