Browse Source

Fix noinline definition so that it works for more compilers.

0.8
Ricardo M. Correia 12 years ago
parent
commit
78e851f94f
  1. 5
      src/test/bignum_tests.cpp
  2. 17
      src/util.h

5
src/test/bignum_tests.cpp

@ -2,6 +2,7 @@ @@ -2,6 +2,7 @@
#include <climits>
#include "bignum.h"
#include "util.h"
BOOST_AUTO_TEST_SUITE(bignum_tests)
@ -29,9 +30,7 @@ BOOST_AUTO_TEST_SUITE(bignum_tests) @@ -29,9 +30,7 @@ BOOST_AUTO_TEST_SUITE(bignum_tests)
// Let's force this code not to be inlined, in order to actually
// test a generic version of the function. This increases the chance
// that -ftrapv will detect overflows.
void mysetint64(CBigNum& num, int64 n) __attribute__((noinline));
void mysetint64(CBigNum& num, int64 n)
NOINLINE void mysetint64(CBigNum& num, int64 n)
{
num.setint64(n);
}

17
src/util.h

@ -43,6 +43,23 @@ static const int64 CENT = 1000000; @@ -43,6 +43,23 @@ static const int64 CENT = 1000000;
#define ARRAYLEN(array) (sizeof(array)/sizeof((array)[0]))
#define printf OutputDebugStringF
// Unfortunately there's no standard way of preventing a function from being
// inlined, so we define a macro for it.
//
// You should use it like this:
// NOINLINE void function() {...}
#if defined(__GNUC__)
// This also works and will be defined for any compiler implementing gcc
// extensions, such as clang and icc.
#define NOINLINE __attribute__((noinline))
#elif defined(_MSC_VER)
#define NOINLINE __declspec(noinline)
#else
// We give out a warning because it impacts the correctness of one bignum test.
#warning You should define NOINLINE for your compiler.
#define NOINLINE
#endif
#ifdef snprintf
#undef snprintf
#endif

Loading…
Cancel
Save