2018-01-12 16:22:38 +00:00
|
|
|
/* This file is part of the dynarmic project.
|
|
|
|
* Copyright (c) 2018 MerryMage
|
|
|
|
* This software may be used and distributed according to the terms of the GNU
|
|
|
|
* General Public License version 2 or any later version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <utility>
|
|
|
|
|
2018-09-08 03:45:00 +01:00
|
|
|
#include "common/common_types.h"
|
|
|
|
|
|
|
|
namespace Dynarmic::Common {
|
2018-01-12 16:22:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This function is a workaround for a bug in MSVC 19.12 where fold expressions
|
|
|
|
* do not work when the /permissive- flag is enabled.
|
|
|
|
*/
|
|
|
|
template<typename T, typename... Ts>
|
2018-04-08 10:37:11 +01:00
|
|
|
constexpr T Sum(T first, Ts&&... rest) {
|
2018-01-12 16:22:38 +00:00
|
|
|
if constexpr (sizeof...(rest) == 0) {
|
|
|
|
return first;
|
|
|
|
} else {
|
|
|
|
return first + Sum(std::forward<Ts>(rest)...);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-08 03:45:00 +01:00
|
|
|
/**
|
|
|
|
* Input is a u0.9 fixed point number. Only values in [0.5, 1.0) are valid.
|
|
|
|
* Output is a u0.8 fixed point number, with an implied 1 prefixed.
|
|
|
|
* i.e.: The output is a value in [1.0, 2.0).
|
|
|
|
*
|
|
|
|
* @see RecipEstimate() within the ARMv8 architecture reference manual
|
|
|
|
* for a general overview of the requirements of the algorithm.
|
|
|
|
*/
|
|
|
|
u8 RecipEstimate(u64 a);
|
|
|
|
|
2018-09-08 04:41:05 +01:00
|
|
|
/**
|
|
|
|
* Input is a u0.9 fixed point number. Only values in [0.25, 1.0) are valid.
|
|
|
|
* Output is a u0.8 fixed point number, with an implied 1 prefixed.
|
|
|
|
* i.e.: The output is a value in [1.0, 2.0).
|
|
|
|
*
|
|
|
|
* @see RecipSqrtEstimate() within the ARMv8 architecture reference manual
|
|
|
|
* for a general overview of the requirements of the algorithm.
|
|
|
|
*/
|
|
|
|
u8 RecipSqrtEstimate(u64 a);
|
|
|
|
|
2018-09-08 03:45:00 +01:00
|
|
|
} // namespace Dynarmic::Common
|