ini
[aversive.git] / modules / encoding / hamming / test / main.c
1 /*  
2  *  Copyright Droids Corporation, Microb Technology, Eirbot (2005)
3  * 
4  *  This program is free software; you can redistribute it and/or modify
5  *  it under the terms of the GNU General Public License as published by
6  *  the Free Software Foundation; either version 2 of the License, or
7  *  (at your option) any later version.
8  *
9  *  This program is distributed in the hope that it will be useful,
10  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  *  GNU General Public License for more details.
13  *
14  *  You should have received a copy of the GNU General Public License
15  *  along with this program; if not, write to the Free Software
16  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17  *
18  *  Revision : $Id: main.c,v 1.2.4.2 2007-05-23 17:18:14 zer0 Exp $
19  *
20  */
21
22 #include <aversive.h>
23 #include <uart.h>
24 #include <hamming.h>
25
26 /* in data is 24 bits */
27 uint32_t tab[] = { 
28         0x00001200,
29         0x00a843e1,
30         0x00001560,
31         0x001504e4,
32         0x00d1d156,
33         0x00000000,
34         0x00123456,
35         0x00d8de6a,
36 };
37
38 int main(void)
39 {
40         uint32_t data;
41         uint32_t data_try;
42         uint8_t error;
43         int i;
44
45 #ifndef HOST_VERSION
46         /* UART */
47         uart_init();
48         fdevopen(uart0_dev_send, uart0_dev_recv);
49
50         sei();
51 #endif
52
53
54         for (i=0; i<(sizeof(tab)/sizeof(uint32_t)) ; i++) {
55                 data=tab[i];
56                 for(error=0; error<29 ; error++) {
57                         data_try = data;
58                         
59                         hamming_do(&data_try);
60                         data_try ^= (1L << error);
61                         
62                         // block if pb
63                         hamming_undo(&data_try);
64                         if (data != data_try) {
65                                 printf("Hamming fail %d %d\n", i, error);
66                         }
67                 }
68         }
69
70         printf("Hamming success\n");
71         return 0;
72 }