summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Hansson <andreas.hansson@arm.com>2014-08-26 10:14:32 -0400
committerAndreas Hansson <andreas.hansson@arm.com>2014-08-26 10:14:32 -0400
commit6fa8015b7fd50e75e97a175a511958b652eca11e (patch)
tree0b566b68cf77dab4cc1ce45ea2fec9958e0c3e16
parent2e17d83629c45e3f9a7321bfd93a79f6c2b55f63 (diff)
downloadgem5-6fa8015b7fd50e75e97a175a511958b652eca11e.tar.xz
base: Add const to intmath and be more flexible with typing
This patch ensures the functions can be used on const variables.
-rw-r--r--src/base/intmath.hh20
1 files changed, 10 insertions, 10 deletions
diff --git a/src/base/intmath.hh b/src/base/intmath.hh
index f46133764..eded26d4a 100644
--- a/src/base/intmath.hh
+++ b/src/base/intmath.hh
@@ -42,7 +42,7 @@ int prevPrime(int n);
// Determine if a number is prime
template <class T>
inline bool
-isPrime(T n)
+isPrime(const T& n)
{
T i;
@@ -63,14 +63,14 @@ isPrime(T n)
template <class T>
inline T
-leastSigBit(T n)
+leastSigBit(const T& n)
{
return n & ~(n - 1);
}
template <class T>
inline bool
-isPowerOf2(T n)
+isPowerOf2(const T& n)
{
return n != 0 && leastSigBit(n) == n;
}
@@ -171,7 +171,7 @@ floorLog2(long long x)
template <class T>
inline int
-ceilLog2(T n)
+ceilLog2(const T& n)
{
if (n == 1)
return 0;
@@ -181,14 +181,14 @@ ceilLog2(T n)
template <class T>
inline T
-floorPow2(T n)
+floorPow2(const T& n)
{
return (T)1 << floorLog2(n);
}
template <class T>
inline T
-ceilPow2(T n)
+ceilPow2(const T& n)
{
return (T)1 << ceilLog2(n);
}
@@ -200,17 +200,17 @@ divCeil(const T& a, const U& b)
return (a + b - 1) / b;
}
-template <class T>
+template <class T, class U>
inline T
-roundUp(T val, int align)
+roundUp(const T& val, const U& align)
{
T mask = (T)align - 1;
return (val + mask) & ~mask;
}
-template <class T>
+template <class T, class U>
inline T
-roundDown(T val, int align)
+roundDown(const T& val, const U& align)
{
T mask = (T)align - 1;
return val & ~mask;