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