2016-11-25 17:18:40 +01:00
|
|
|
#include <u.h>
|
2017-04-19 23:33:14 +02:00
|
|
|
#include <lib9.h>
|
2016-11-25 17:18:40 +01:00
|
|
|
|
|
|
|
#define DPRECSTR "0.0000004000000000125"
|
|
|
|
#define DPREC 0.0000004000000000125
|
|
|
|
#define DIEEELO 0x9ac0499f
|
|
|
|
#define DIEEEHI 0x3e9ad7f2
|
|
|
|
|
|
|
|
jmp_buf errj;
|
|
|
|
char *err;
|
|
|
|
|
|
|
|
void
|
|
|
|
catcher(void *u, char *s)
|
|
|
|
{
|
|
|
|
err = 0;
|
|
|
|
if(strncmp(s, "sys: fp:", 8) == 0){
|
|
|
|
err = s;
|
|
|
|
notejmp(u, errj, 0);
|
|
|
|
}
|
|
|
|
noted(NDFLT);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
tstdiv(double p)
|
|
|
|
{
|
|
|
|
double r = 1.0;
|
|
|
|
|
|
|
|
r /= p;
|
|
|
|
fprint(2, "1/%0.20g = %0.20g\n", p, r);
|
|
|
|
}
|
|
|
|
|
2017-05-19 01:09:51 +02:00
|
|
|
typedef union I2UL
|
|
|
|
{
|
|
|
|
int d[2];
|
|
|
|
unsigned long l;
|
|
|
|
}I2UL;
|
|
|
|
typedef union D2UL
|
|
|
|
{
|
|
|
|
double d;
|
|
|
|
unsigned long l;
|
|
|
|
}D2UL;
|
|
|
|
|
2016-11-25 17:18:40 +01:00
|
|
|
void
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
double p = DPREC;
|
|
|
|
int d[2] = { DIEEELO, DIEEEHI };
|
2017-05-19 01:09:51 +02:00
|
|
|
I2UL i2l;
|
|
|
|
D2UL d2l;
|
2016-11-25 17:18:40 +01:00
|
|
|
uint64_t dieee, q;
|
2017-05-19 01:09:51 +02:00
|
|
|
|
|
|
|
i2l.d[0] = d[0];
|
|
|
|
i2l.d[1] = d[1];
|
|
|
|
dieee = i2l.l;
|
|
|
|
d2l.d = p;
|
|
|
|
q = d2l.l;
|
2016-11-25 17:18:40 +01:00
|
|
|
|
|
|
|
err = 0;
|
|
|
|
notify(catcher);
|
|
|
|
setjmp(errj);
|
|
|
|
if(err){
|
|
|
|
fprint(2, "FAIL: %s\n", err);
|
|
|
|
exits("FAIL");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprint(2, "Double-precision test number: %s\n", DPRECSTR);
|
|
|
|
fprint(2, "Expected internal representation: %ullx\n", dieee);
|
|
|
|
fprint(2, "Actual internal representation: %ullx\n", q);
|
|
|
|
|
|
|
|
if(q != dieee) {
|
|
|
|
print("FAIL\n");
|
|
|
|
exits("FAIL");
|
|
|
|
}
|
|
|
|
|
|
|
|
tstdiv(p);
|
|
|
|
print("PASS\n");
|
|
|
|
exits("PASS");
|
|
|
|
}
|