From 1092515e6551b3967226f0ff21b2a74236330932 Mon Sep 17 00:00:00 2001 From: Nathan Binkert Date: Fri, 10 Oct 2003 09:44:49 -0400 Subject: [PATCH] Rename intmath.h to intmath.hh clean up the formatting make things use templates since this is C++ now. base/circlebuf.cc: base/intmath.cc: base/intmath.hh: base/range.hh: base/remote_gdb.cc: base/statistics.cc: base/str.cc: intmath.h -> intmath.hh base/intmath.hh: Make this more like C++ by templatizing these functions --HG-- rename : base/intmath.h => base/intmath.hh extra : convert_revision : 8f9b14de9db751b1bd78588c51613d77afd96989 --- base/circlebuf.cc | 4 +- base/intmath.cc | 2 +- base/{intmath.h => intmath.hh} | 122 +++++++++++++++++++-------------- base/range.hh | 2 +- base/remote_gdb.cc | 2 +- base/statistics.cc | 2 +- base/str.cc | 2 +- 7 files changed, 79 insertions(+), 57 deletions(-) rename base/{intmath.h => intmath.hh} (60%) diff --git a/base/circlebuf.cc b/base/circlebuf.cc index 482c97f84..311de60b7 100644 --- a/base/circlebuf.cc +++ b/base/circlebuf.cc @@ -33,9 +33,9 @@ #include #include -#include "cprintf.hh" #include "circlebuf.hh" -#include "intmath.h" +#include "cprintf.hh" +#include "intmath.hh" using namespace std; diff --git a/base/intmath.cc b/base/intmath.cc index 8d08e59a8..7a6858d16 100644 --- a/base/intmath.cc +++ b/base/intmath.cc @@ -26,7 +26,7 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "intmath.h" +#include "intmath.hh" int PrevPrime(int n) diff --git a/base/intmath.h b/base/intmath.hh similarity index 60% rename from base/intmath.h rename to base/intmath.hh index 814dacd5f..16467426d 100644 --- a/base/intmath.h +++ b/base/intmath.hh @@ -26,84 +26,106 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef __INTMATH_H__ -#define __INTMATH_H__ +#ifndef __INTMATH_HH__ +#define __INTMATH_HH__ // Returns the prime number one less than n. int PrevPrime(int n); // Determine if a number is prime +template inline bool -IsPrime(int n) +IsPrime(T n) { - int i; + T i; - if (n == 2 || n == 3) - return true; + if (n == 2 || n == 3) + return true; - // Don't try every odd number to prove if it is a prime. - // Toggle between every 2nd and 4th number. - // (This is because every 6th odd number is divisible by 3.) - for (i = 5; i*i <= n; i += 6) { - if (((n % i) == 0 ) || ((n % (i + 2)) == 0) ) { - return false; + // Don't try every odd number to prove if it is a prime. + // Toggle between every 2nd and 4th number. + // (This is because every 6th odd number is divisible by 3.) + for (i = 5; i*i <= n; i += 6) { + if (((n % i) == 0 ) || ((n % (i + 2)) == 0) ) { + return false; + } } - } - return true; + return true; } -inline unsigned -LeastSigBit(unsigned n) -{ return n & ~(n - 1); } - -inline bool -IsPowerOf2(unsigned n) -{ return n != 0 && LeastSigBit(n) == n; } - -inline int -FloorLog2(unsigned x) +template +inline T +LeastSigBit(T n) { - if (x == 0) - return -1; - - int y = 0; - - if (x & 0xffff0000) { y += 16; x >>= 16; } - if (x & 0x0000ff00) { y += 8; x >>= 8; } - if (x & 0x000000f0) { y += 4; x >>= 4; } - if (x & 0x0000000c) { y += 2; x >>= 2; } - if (x & 0x00000002) { y += 1; } - - return y; + return n & ~(n - 1); } +template +inline bool +IsPowerOf2(T n) +{ + return n != 0 && LeastSigBit(n) == n; +} + +template inline int -CeilLog2(unsigned n) -{ return FloorLog2(n-1)+1; } +FloorLog2(T x) +{ + if (x == 0) + return -1; -inline unsigned -FloorPow2(unsigned n) -{ return 1 << FloorLog2(n); } + int y = 0; -inline unsigned -CeilPow2(unsigned n) -{ return 1 << CeilLog2(n); } + if (x & 0xffff0000) { y += 16; x >>= 16; } + if (x & 0x0000ff00) { y += 8; x >>= 8; } + if (x & 0x000000f0) { y += 4; x >>= 4; } + if (x & 0x0000000c) { y += 2; x >>= 2; } + if (x & 0x00000002) { y += 1; } + + return y; +} + +template +inline int +CeilLog2(T n) +{ + return FloorLog2(n - 1) + 1; +} + +template +inline T +FloorPow2(T n) +{ + return (T)1 << FloorLog2(n); +} + +template +inline T +CeilPow2(T n) +{ + return (T)1 << CeilLog2(n); +} inline bool IsHex(char c) -{ return (c >= '0' && c <= '9' || - c >= 'A' && c <= 'F' || - c >= 'a' && c <= 'f'); +{ + return c >= '0' && c <= '9' || + c >= 'A' && c <= 'F' || + c >= 'a' && c <= 'f'; } inline bool IsOct(char c) -{ return (c >= '0' && c <= '7'); } +{ + return c >= '0' && c <= '7'; +} inline bool IsDec(char c) -{ return (c >= '0' && c <= '9'); } +{ + return c >= '0' && c <= '9'; +} inline int Hex2Int(char c) @@ -120,4 +142,4 @@ Hex2Int(char c) return 0; } -#endif // __INTMATH_H__ +#endif // __INTMATH_HH__ diff --git a/base/range.hh b/base/range.hh index 254e71460..dcc863e06 100644 --- a/base/range.hh +++ b/base/range.hh @@ -31,8 +31,8 @@ #include +#include "intmath.hh" #include "str.hh" -#include "intmath.h" template class Range diff --git a/base/remote_gdb.cc b/base/remote_gdb.cc index 5a6987877..280b1cc23 100644 --- a/base/remote_gdb.cc +++ b/base/remote_gdb.cc @@ -94,7 +94,7 @@ #include #include "exec_context.hh" -#include "intmath.h" +#include "intmath.hh" #include "kgdb.h" #include "physical_memory.hh" diff --git a/base/statistics.cc b/base/statistics.cc index 1e8cd2565..f956de828 100644 --- a/base/statistics.cc +++ b/base/statistics.cc @@ -36,7 +36,7 @@ #include #include "cprintf.hh" -#include "intmath.h" +#include "intmath.hh" #include "misc.hh" #include "statistics.hh" #include "str.hh" diff --git a/base/str.cc b/base/str.cc index f54729813..19cbea27d 100644 --- a/base/str.cc +++ b/base/str.cc @@ -34,7 +34,7 @@ #include #include -#include "intmath.h" +#include "intmath.hh" #include "str.hh" using namespace std;