mirror of
https://github.com/hrydgard/ppsspp.git
synced 2024-12-13 16:45:46 +00:00
70 lines
2.0 KiB
C
70 lines
2.0 KiB
C
// Copyright (c) 2012- PPSSPP Project.
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
|
|
|
// This program 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 General Public License 2.0 for more details.
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
// Official git repository and contact information can be found at
|
|
// https://github.com/hrydgard/ppsspp and http://www.ppsspp.org/.
|
|
|
|
#pragma once
|
|
|
|
#include "ppsspp_config.h"
|
|
#include "Common/Common.h"
|
|
#include "Common/CommonTypes.h"
|
|
|
|
#define IS_LITTLE_ENDIAN (*(const u16 *)"\0\xff" >= 0x100)
|
|
|
|
static inline u8 clamp_u8(int i) {
|
|
#if PPSSPP_ARCH(ARM) && !defined(_MSC_VER)
|
|
asm("usat %0, #8, %1" : "=r"(i) : "r"(i));
|
|
#else
|
|
if (i > 255)
|
|
return 255;
|
|
if (i < 0)
|
|
return 0;
|
|
#endif
|
|
return i;
|
|
}
|
|
|
|
static inline s16 clamp_s16(int i) {
|
|
#if PPSSPP_ARCH(ARM) && !defined(_MSC_VER)
|
|
asm("ssat %0, #16, %1" : "=r"(i) : "r"(i));
|
|
#else
|
|
if (i > 32767)
|
|
return 32767;
|
|
if (i < -32768)
|
|
return -32768;
|
|
#endif
|
|
return i;
|
|
}
|
|
|
|
static inline s16 ApplySampleVolume(s16 sample, int vol) {
|
|
#if PPSSPP_ARCH(ARM) && !defined(_MSC_VER)
|
|
int r;
|
|
asm volatile("smulwb %0, %1, %2\n\t" \
|
|
"ssat %0, #16, %0" \
|
|
: "=r"(r) : "r"(vol), "r"(sample));
|
|
return r;
|
|
#else
|
|
return clamp_s16((sample * vol) >> 16);
|
|
#endif
|
|
}
|
|
|
|
// We sacrifice a little volume precision to fit in 32 bits, for speed.
|
|
// Probably not worth it to make a special path for 64-bit CPUs.
|
|
static inline s16 ApplySampleVolume20Bit(s16 sample, int vol20) {
|
|
return clamp_s16((sample * (vol20 >> 4)) >> 12);
|
|
}
|
|
|
|
void AdjustVolumeBlock(s16 *out, s16 *in, size_t size, int leftVol, int rightVol);
|
|
void ConvertS16ToF32(float *ou, const s16 *in, size_t size);
|