[Bug 192134]
Joseph-codesourcery
192134 at bugs.launchpad.net
Thu Mar 11 21:12:20 UTC 2021
If you log in to Bugzilla with your @gcc.gnu.org address you should have
access to mark bugs RESOLVED / FIXED with target milestone set to the
first release that will have the fix, rather than just commenting that
they are fixed.
--
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to glibc in Ubuntu.
https://bugs.launchpad.net/bugs/192134
Title:
slow math sin function for some values on amd64
Status in GLibC:
Fix Released
Status in glibc package in Ubuntu:
Triaged
Bug description:
Hello.
I have found that math sin function is unreasonable slow (400us on Athlon64 A2 4800+) for some values. It only happens on 64bit distribution.
Used versions:
Kubuntu 7.10 amd64 gutsy gutter
linux kernel 2.6.24
libc6 2.6.1-1ubuntu10
libc6-dev 2.6.1-1ubuntu10
Some of those values: -----------------------------------------------------------------------
0.93340582292648832662962377071381 00 b0 6b e3 75 de ed 3f 0x3fedde75e36bb000
2.3328432680770916363144351635128 d0 ad 38 bb a9 a9 02 40 0x4002a9a9bb38add0
3.7439477503636453548097051680088 00 f5 cd e0 9a f3 0d 40 0x400df39ae0cdf500
3.9225160069792437411706487182528 50 19 80 12 50 61 0f 40 0x400f615012801950
4.0711651639931289992091478779912 20 dc 4f 85 df 48 10 40 0x401048df854fdc20
4.7858438478542097982426639646292 c0 2f e9 3f b4 24 13 40 0x401324b43fe92fc0
5.9840767662578002727968851104379 a0 52 df d1 b1 ef 17 40 0x4017efb1d1df52a0
Short program for testing: ------------------------------------------------------------------
#include <stdlib.h>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <math.h>
#include <sys/time.h>
using namespace std;
int main(int argc, char** argv) {
volatile union {
double dbl;
unsigned char hex[sizeof(double)];
} value;
if (argc == sizeof(double)+1) {
for (int i=0; i < sizeof(double); i++) {
istringstream s(argv[i+1]);
int tmp;
s >> hex >> tmp;
value.hex[i] = tmp;
}
} else if (argc == 2) {
istringstream s(argv[1]);
double tmp;
s >> tmp;
value.dbl = tmp;
} else {
cout << "usage: sintest 00 b0 6b e3 75 de ed 3f\n"
" sintest 0.93340582292648832662962377071381";
return (EXIT_FAILURE);
}
cout.precision(32);
cout << value.dbl << endl;
cout << "start\n";
struct timeval time1, time2;
gettimeofday(&time1, NULL);
for (int i=0; i < 10000; i++) {
volatile double out = sin(value.dbl);
}
gettimeofday(&time2, NULL);
long long diftime = 1000000ll * (time2.tv_sec - time1.tv_sec) +
(time2.tv_usec - time1.tv_usec);
cout << "end: " << diftime / 1000000ll << '.' << setw(6) << setfill('0') << diftime % 1000000ll << " s" << endl;
return (EXIT_SUCCESS);
}
Petr Cervenka
To manage notifications about this bug go to:
https://bugs.launchpad.net/glibc/+bug/192134/+subscriptions
More information about the foundations-bugs
mailing list