~ubuntu-branches/ubuntu/raring/avr-libc/raring-proposed

« back to all changes in this revision

Viewing changes to tests/simulate/fplib/add-03.c

  • Committer: Bazaar Package Importer
  • Author(s): Hakan Ardo
  • Date: 2008-08-10 09:59:16 UTC
  • mfrom: (1.1.7 upstream) (4.1.1 lenny)
  • Revision ID: james.westby@ubuntu.com-20080810095916-wwyigh3vt0e9s7ud
Tags: 1:1.6.2.cvs20080610-2
Added build-depends on texlive-extra-utils (closes: #493454)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* Test of addition.  Rounding.
 
2
   $Id: add-03.c,v 1.1 2007/02/05 21:35:58 dmix Exp $
 
3
 */
 
4
#include <stdio.h>
 
5
#include <stdlib.h>
 
6
#include "progmem.h"
 
7
 
 
8
union lofl_u {
 
9
    long lo;
 
10
    float fl;
 
11
};
 
12
 
 
13
volatile union lofl_u v = { .lo = 1 };
 
14
 
 
15
PROGMEM const struct {          /* Table of test cases:  x + y = z      */
 
16
    union lofl_u x, y, z;
 
17
} t[] = {
 
18
 
 
19
    /* The remainder is exactly 0.5: look the smart rounding direction. */
 
20
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000008p0 }, { .fl = 0x0.800000p0 } },
 
21
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000010p0 }, { .fl = 0x0.800001p0 } },
 
22
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000018p0 }, { .fl = 0x0.800002p0 } },
 
23
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000020p0 }, { .fl = 0x0.800002p0 } },
 
24
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000028p0 }, { .fl = 0x0.800002p0 } },
 
25
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000030p0 }, { .fl = 0x0.800003p0 } },
 
26
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000038p0 }, { .fl = 0x0.800004p0 } },
 
27
    { { .fl = 0x0.8p0 }, { .fl = 0x0.0000040p0 }, { .fl = 0x0.800004p0 } },
 
28
 
 
29
    /* The remainder is exactly 0.5, subtraction.       */
 
30
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000008p0 }, { .fl = 0x0.900000p0 } },
 
31
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000010p0 }, { .fl = 0x0.8fffffp0 } },
 
32
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000018p0 }, { .fl = 0x0.8ffffep0 } },
 
33
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000020p0 }, { .fl = 0x0.8ffffep0 } },
 
34
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000028p0 }, { .fl = 0x0.8ffffep0 } },
 
35
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000030p0 }, { .fl = 0x0.8ffffdp0 } },
 
36
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000038p0 }, { .fl = 0x0.8ffffcp0 } },
 
37
    { { .fl = 0x0.9p0 }, { .fl = -0x0.0000040p0 }, { .fl = 0x0.8ffffcp0 } },
 
38
 
 
39
};
 
40
 
 
41
void x_exit (int index)
 
42
{
 
43
#ifndef __AVR__
 
44
    fprintf (stderr, "t[%d]:  %#lx\n", index - 1, v.lo);
 
45
#endif
 
46
    exit (index ? index : -1);
 
47
}
 
48
 
 
49
int main ()
 
50
{
 
51
    union lofl_u x,y,z;
 
52
    int i;
 
53
    
 
54
    for (i = 0; i < (int) (sizeof(t) / sizeof(t[0])); i++) {
 
55
        x.lo = pgm_read_dword (& t[i].x);
 
56
        y.lo = pgm_read_dword (& t[i].y);
 
57
        z.lo = pgm_read_dword (& t[i].z);
 
58
        v.fl = x.fl + y.fl;
 
59
        /* Comparison is integer to verify the zero sign.       */
 
60
        if (v.lo != z.lo)
 
61
            x_exit (i+1);
 
62
    }
 
63
    return 0;
 
64
}