|
|
1.1 root 1: /*
2: * libc/gen/decvax_d.c
3: */
4:
5: /*
6: * decvax_d(double *ddp, double *idp)
7: * Convert double from IEEE format to DECVAX format.
8: * idp points to an IEEE format double to convert.
9: * ddp points to a destination for the converted DECVAX value;
10: * ddp may be identical to idp for in-place conversion.
11: * Returns 0 on success, -1 on underflow, 1 on overflow.
12: */
13:
14: int
15: decvax_d(ddp, idp) double *ddp, *idp;
16: {
17: unsigned char a[8];
18: register unsigned char *cp;
19: register int exp, a0123456;
20:
21: /* Extract sign, biased exponent. */
22: cp = (char *)idp;
23: exp = ((cp[7] & 0x7F) << 4) | ((cp[6] & 0xF0) >> 4);
24: if (exp == 0) {
25: a0123456 = (a[6] & 0x0F) | a[5] | a[4] | a[3] | a[2] | a[1] | a[0];
26: memset((char *)ddp, 0, 8); /* set to 0.0 */
27: return (a0123456 == 0) ? 0 : -1; /* return -1 for denormals */
28: }
29:
30: /* Adjust exponent bias. */
31: exp -= 1023 - 129;
32: if (exp <= 0) {
33: memset((char *)ddp, 0, 8); /* set to 0.0 */
34: return -1; /* underflow */
35: } else if (exp > 255) {
36: /* Overflow, also used for NaNs. */
37: cp = (char *)ddp;
38: memset(cp, 0xFF, 7); /* set to max */
39: cp[7] |= 0x7F; /* preserving sign bit */
40: return 1; /* overflow */
41: }
42:
43: /* Repack. */
44: a[7] = (cp[7] & 0x80) | ((exp & 0xFE) >> 1);
45: a[6] = ((exp & 1) << 7) | ((cp[6] & 0x0F) << 3) | ((cp[5] & 0xE0) >> 5);
46: a[5] = ((cp[5] & 0x1F) << 3) | ((cp[4] & 0xE0) >> 5);
47: a[4] = ((cp[4] & 0x1F) << 3) | ((cp[3] & 0xE0) >> 5);
48: a[3] = ((cp[3] & 0x1F) << 3) | ((cp[2] & 0xE0) >> 5);
49: a[2] = ((cp[2] & 0x1F) << 3) | ((cp[1] & 0xE0) >> 5);
50: a[1] = ((cp[1] & 0x1F) << 3) | ((cp[0] & 0xE0) >> 5);
51: a[0] = ((cp[0] & 0x1F) << 3);
52: memcpy((char *)ddp, a, 8);
53: return 0;
54: }
55:
56: /* end of libc/gen/decvax_d.c */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.