Imported Upstream version 2.9.0
[debian/cc1111] / src / regression / mult1.c
1 #include "gpsim_assert.h"
2
3 #define TESTLIT 0x05
4
5 unsigned char failures=0;
6
7
8 signed char c1,c2,c3;
9 unsigned char uc1,uc2,uc3;
10
11 unsigned int ui1,ui2,ui3;
12 signed int i1,i2;
13
14 void
15 done()
16 {
17   ASSERT(MANGLE(failures) == 0);
18   PASSED();
19 }
20
21 void m1(void)
22 {
23
24   c1 = c1*5;       // char = char * lit
25
26   c2 = c1 *c3;     // char = char * char
27
28   uc1= uc1*5;      // uchar = uchar * lit
29   uc2=uc1*uc3;     // uchar = uchar * uchar
30
31   if(c2 != 25)
32     failures++;
33 }
34
35 void m2(unsigned char uc)
36 {
37
38   uc2 = uc1 * uc;
39
40   if(uc2 != 0x20)
41     failures++;
42 }
43
44 void m3(unsigned char uc)
45 {
46   volatile unsigned char vuc;
47   
48   // uchar = uchar * lit
49   // testing literal multiply with same source and destination
50   vuc = uc;
51   uc2 = 0;   
52   uc1 = vuc; uc1 = uc1*1; if( uc1 != (uc2+=TESTLIT) ) failures++; 
53   uc1 = vuc; uc1 = uc1*2; if( uc1 != (uc2+=TESTLIT) ) failures++;      
54   uc1 = vuc; uc1 = uc1*3; if( uc1 != (uc2+=TESTLIT) ) failures++;     
55   uc1 = vuc; uc1 = uc1*4; if( uc1 != (uc2+=TESTLIT) ) failures++;      
56   uc1 = vuc; uc1 = uc1*5; if( uc1 != (uc2+=TESTLIT) ) failures++;     
57   uc1 = vuc; uc1 = uc1*6; if( uc1 != (uc2+=TESTLIT) ) failures++;      
58   uc1 = vuc; uc1 = uc1*7; if( uc1 != (uc2+=TESTLIT) ) failures++;     
59   uc1 = vuc; uc1 = uc1*8; if( uc1 != (uc2+=TESTLIT) ) failures++;      
60   uc1 = vuc; uc1 = uc1*9; if( uc1 != (uc2+=TESTLIT) ) failures++;     
61   uc1 = vuc; uc1 = uc1*10; if( uc1 != (uc2+=TESTLIT) ) failures++;      
62   uc1 = vuc; uc1 = uc1*11; if( uc1 != (uc2+=TESTLIT) ) failures++;     
63   uc1 = vuc; uc1 = uc1*12; if( uc1 != (uc2+=TESTLIT) ) failures++;      
64   uc1 = vuc; uc1 = uc1*13; if( uc1 != (uc2+=TESTLIT) ) failures++;
65   uc1 = vuc; uc1 = uc1*14; if( uc1 != (uc2+=TESTLIT) ) failures++;
66   uc1 = vuc; uc1 = uc1*15; if( uc1 != (uc2+=TESTLIT) ) failures++;
67   uc1 = vuc; uc1 = uc1*16; if( uc1 != (uc2+=TESTLIT) ) failures++;
68   uc1 = vuc; uc1 = uc1*17; if( uc1 != (uc2+=TESTLIT) ) failures++;
69   uc1 = vuc; uc1 = uc1*18; if( uc1 != (uc2+=TESTLIT) ) failures++;
70   uc1 = vuc; uc1 = uc1*19; if( uc1 != (uc2+=TESTLIT) ) failures++;
71   uc1 = vuc; uc1 = uc1*20; if( uc1 != (uc2+=TESTLIT) ) failures++;
72   uc1 = vuc; uc1 = uc1*21; if( uc1 != (uc2+=TESTLIT) ) failures++;
73   uc1 = vuc; uc1 = uc1*22; if( uc1 != (uc2+=TESTLIT) ) failures++;
74   uc1 = vuc; uc1 = uc1*23; if( uc1 != (uc2+=TESTLIT) ) failures++;  
75   uc1 = vuc; uc1 = uc1*24; if( uc1 != (uc2+=TESTLIT) ) failures++;
76   
77   uc1 = vuc; uc1 = uc1*31; if( uc1 != ((31*TESTLIT) & 0xff) ) failures++;
78   uc1 = vuc; uc1 = uc1*32; if( uc1 != ((32*TESTLIT) & 0xff) ) failures++;
79   uc1 = vuc; uc1 = uc1*64; if( uc1 != ((64*TESTLIT) & 0xff) ) failures++;
80   uc1 = vuc; uc1 = uc1*128;if( uc1 != ((128*TESTLIT)& 0xff) ) failures++;
81
82   // testing literal multiply with different source and destination
83   uc1 = vuc*1; if( uc1 != ((1*TESTLIT) & 0xff) ) failures++;    
84   uc1 = vuc*2; if( uc1 != ((2*TESTLIT) & 0xff) ) failures++;    
85   uc1 = vuc*4; if( uc1 != ((4*TESTLIT) & 0xff) ) failures++;
86 }
87
88
89 void main(void)
90 {
91   c1 = 1;
92   c3 = 5;
93
94   m1();
95
96   uc1 = 0x10;
97   m2(2);
98
99   ui1 = uc1*uc2;   // uint = uchar * uchar
100
101   i1 = c1*c2;      // int = char * char
102
103   ui3 = ui1*ui2;   // uint = uint * unit
104
105   //m3(TESTLIT);
106
107   done();
108 }