2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Commonly used math functions
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2006-04-12
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2006-2017 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2011-12-22 16:19:25 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__UTIL__MISC_MATH_H_
|
|
|
|
#define _INCLUDE__UTIL__MISC_MATH_H_
|
|
|
|
|
|
|
|
namespace Genode {
|
|
|
|
|
2012-01-09 21:46:32 +01:00
|
|
|
template <typename T1, typename T2>
|
2016-10-19 21:31:04 +02:00
|
|
|
static constexpr T1 max(T1 v1, T2 v2) { return v1 > v2 ? v1 : v2; }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2012-01-09 21:46:32 +01:00
|
|
|
template <typename T1, typename T2>
|
2016-10-19 21:31:04 +02:00
|
|
|
static constexpr T1 min(T1 v1, T2 v2) { return v1 < v2 ? v1 : v2; }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
template <typename T>
|
2016-10-19 21:31:04 +02:00
|
|
|
static constexpr T abs(T value) { return value >= 0 ? value : -value; }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Alignment to the power of two
|
|
|
|
*/
|
|
|
|
template <typename T>
|
2015-06-26 11:31:29 +02:00
|
|
|
static constexpr T _align_mask(T align) {
|
|
|
|
return ~(((T)1 << align) - (T)1); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
template <typename T>
|
2015-06-26 11:31:29 +02:00
|
|
|
static constexpr T _align_offset(T align) {
|
|
|
|
return ((T)1 << align) - (T)1; }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
template <typename T>
|
2015-06-26 11:31:29 +02:00
|
|
|
static constexpr T align_addr(T addr, int align) {
|
2013-05-07 16:31:41 +02:00
|
|
|
return (addr + _align_offset((T)align)) & _align_mask((T)align); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* LOG2
|
|
|
|
*
|
|
|
|
* Scan for most-significant set bit.
|
|
|
|
*/
|
|
|
|
template <typename T>
|
|
|
|
static inline T log2(T value)
|
|
|
|
{
|
|
|
|
if (!value) return -1;
|
|
|
|
for (int i = 8 * sizeof(value) - 1; i >= 0; --i)
|
2012-09-21 09:34:31 +02:00
|
|
|
if (((T)1 << i) & value) return i;
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Align value to next machine-word boundary
|
|
|
|
*/
|
|
|
|
template <typename T>
|
|
|
|
inline T align_natural(T value)
|
|
|
|
{
|
|
|
|
T mask = sizeof(long) - 1;
|
|
|
|
return (value + mask) & ~mask;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__UTIL__MISC_MATH_H_ */
|