• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1From Vince Weaver:
2
3I've been running the SPEC CPU 2006 benchmarks under valgrind (doing some
4work on my BBV generating plugin).
5
6There are two benchmarks that have issues, and I thought I'd share them
7here for future reference.
8
91). zeusmp - does not run
10
11    It has a 1GB data segment, which valgrind cannot handle on a 32-bit
12    CPU.
13
142). dealII - runs forever, never ending
15
16    It took a while, but I tracked this down to a 64bit/80bit
17    floating point issue.
18
19    The code in the QGauss<1>::QGauss() function has some code like this:
20
21    const long double tolerance = std::max (static_cast<long double>
22       (std::numeric_limits<double>::epsilon() / 100),
23       static_cast<long double>(std::numeric_limits<long
24       double>::epsilon() *5));
25
26     do {
27       ....
28       various fp operations
29       ....
30     } while (abs(p1/pp) > tolerance);
31
32
33     The tolerance in this case is being set to ~2.22e-18, but the
34     abs(p1/pp) value never gets below ~2.586e-17 under valgrind.
35
36     [This is because Valgrind only uses 64-bit FP values on x86, not 80-bit
37     values.]
38
39     This is similar to an issue that happens with the "art"
40     benchmark on SPEC CPU 2000, but in the "art" case it only
41     makes the code take longer to finish; this "dealII" problem
42     makes the benchmark loop forever.
43
44