4 /* #include "stdlib.h" */
5 /* #include "EUCR6SK.h" */
9 /* #include <stdio.h> */
10 /* #include <stdlib.h> */
11 /* #include <string.h> */
12 /* #include <dos.h> */
13 /* #include "EMCRIOS.h" */
15 /* CP0-CP5 code table */
16 static u8 ecctable
[256] = {
17 0x00, 0x55, 0x56, 0x03, 0x59, 0x0C, 0x0F, 0x5A, 0x5A, 0x0F, 0x0C, 0x59, 0x03,
18 0x56, 0x55, 0x00, 0x65, 0x30, 0x33, 0x66, 0x3C, 0x69, 0x6A, 0x3F, 0x3F, 0x6A,
19 0x69, 0x3C, 0x66, 0x33, 0x30, 0x65, 0x66, 0x33, 0x30, 0x65, 0x3F, 0x6A, 0x69,
20 0x3C, 0x3C, 0x69, 0x6A, 0x3F, 0x65, 0x30, 0x33, 0x66, 0x03, 0x56, 0x55, 0x00,
21 0x5A, 0x0F, 0x0C, 0x59, 0x59, 0x0C, 0x0F, 0x5A, 0x00, 0x55, 0x56, 0x03, 0x69,
22 0x3C, 0x3F, 0x6A, 0x30, 0x65, 0x66, 0x33, 0x33, 0x66, 0x65, 0x30, 0x6A, 0x3F,
23 0x3C, 0x69, 0x0C, 0x59, 0x5A, 0x0F, 0x55, 0x00, 0x03, 0x56, 0x56, 0x03, 0x00,
24 0x55, 0x0F, 0x5A, 0x59, 0x0C, 0x0F, 0x5A, 0x59, 0x0C, 0x56, 0x03, 0x00, 0x55,
25 0x55, 0x00, 0x03, 0x56, 0x0C, 0x59, 0x5A, 0x0F, 0x6A, 0x3F, 0x3C, 0x69, 0x33,
26 0x66, 0x65, 0x30, 0x30, 0x65, 0x66, 0x33, 0x69, 0x3C, 0x3F, 0x6A, 0x6A, 0x3F,
27 0x3C, 0x69, 0x33, 0x66, 0x65, 0x30, 0x30, 0x65, 0x66, 0x33, 0x69, 0x3C, 0x3F,
28 0x6A, 0x0F, 0x5A, 0x59, 0x0C, 0x56, 0x03, 0x00, 0x55, 0x55, 0x00, 0x03, 0x56,
29 0x0C, 0x59, 0x5A, 0x0F, 0x0C, 0x59, 0x5A, 0x0F, 0x55, 0x00, 0x03, 0x56, 0x56,
30 0x03, 0x00, 0x55, 0x0F, 0x5A, 0x59, 0x0C, 0x69, 0x3C, 0x3F, 0x6A, 0x30, 0x65,
31 0x66, 0x33, 0x33, 0x66, 0x65, 0x30, 0x6A, 0x3F, 0x3C, 0x69, 0x03, 0x56, 0x55,
32 0x00, 0x5A, 0x0F, 0x0C, 0x59, 0x59, 0x0C, 0x0F, 0x5A, 0x00, 0x55, 0x56, 0x03,
33 0x66, 0x33, 0x30, 0x65, 0x3F, 0x6A, 0x69, 0x3C, 0x3C, 0x69, 0x6A, 0x3F, 0x65,
34 0x30, 0x33, 0x66, 0x65, 0x30, 0x33, 0x66, 0x3C, 0x69, 0x6A, 0x3F, 0x3F, 0x6A,
35 0x69, 0x3C, 0x66, 0x33, 0x30, 0x65, 0x00, 0x55, 0x56, 0x03, 0x59, 0x0C, 0x0F,
36 0x5A, 0x5A, 0x0F, 0x0C, 0x59, 0x03, 0x56, 0x55, 0x00
39 static void trans_result(u8
, u8
, u8
*, u8
*);
50 #define BIT23 0x00800000L
52 #define CORRECTABLE 0x00555554L
55 * reg2; * LP14,LP12,LP10,...
56 * reg3; * LP15,LP13,LP11,...
57 * *ecc1; * LP15,LP14,LP13,...
58 * *ecc2; * LP07,LP06,LP05,...
60 static void trans_result(u8 reg2
, u8 reg3
, u8
*ecc1
, u8
*ecc2
)
62 u8 a
; /* Working for reg2,reg3 */
63 u8 b
; /* Working for ecc1,ecc2 */
64 u8 i
; /* For counting */
66 a
= BIT7
; b
= BIT7
; /* 80h=10000000b */
67 *ecc1
= *ecc2
= 0; /* Clear ecc1,ecc2 */
68 for (i
= 0; i
< 4; ++i
) {
70 *ecc1
|= b
; /* LP15,13,11,9 -> ecc1 */
71 b
= b
>>1; /* Right shift */
73 *ecc1
|= b
; /* LP14,12,10,8 -> ecc1 */
74 b
= b
>>1; /* Right shift */
75 a
= a
>>1; /* Right shift */
78 b
= BIT7
; /* 80h=10000000b */
79 for (i
= 0; i
< 4; ++i
) {
81 *ecc2
|= b
; /* LP7,5,3,1 -> ecc2 */
82 b
= b
>>1; /* Right shift */
84 *ecc2
|= b
; /* LP6,4,2,0 -> ecc2 */
85 b
= b
>>1; /* Right shift */
86 a
= a
>>1; /* Right shift */
90 /*static void calculate_ecc(table,data,ecc1,ecc2,ecc3) */
92 * *table; * CP0-CP5 code table
94 * *ecc1; * LP15,LP14,LP13,...
95 * *ecc2; * LP07,LP06,LP05,...
96 * *ecc3; * CP5,CP4,CP3,...,"1","1"
98 void calculate_ecc(u8
*table
, u8
*data
, u8
*ecc1
, u8
*ecc2
, u8
*ecc3
)
100 u32 i
; /* For counting */
101 u8 a
; /* Working for table */
102 u8 reg1
; /* D-all,CP5,CP4,CP3,... */
103 u8 reg2
; /* LP14,LP12,L10,... */
104 u8 reg3
; /* LP15,LP13,L11,... */
106 reg1
= reg2
= reg3
= 0; /* Clear parameter */
107 for (i
= 0; i
< 256; ++i
) {
108 a
= table
[data
[i
]]; /* Get CP0-CP5 code from table */
109 reg1
^= (a
&MASK_CPS
); /* XOR with a */
110 if ((a
&BIT6
) != 0) { /* If D_all(all bit XOR) = 1 */
111 reg3
^= (u8
)i
; /* XOR with counter */
112 reg2
^= ~((u8
)i
); /* XOR with inv. of counter */
116 /* Trans LP14,12,10,... & LP15,13,11,... ->
117 LP15,14,13,... & LP7,6,5,.. */
118 trans_result(reg2
, reg3
, ecc1
, ecc2
);
119 *ecc1
= ~(*ecc1
); *ecc2
= ~(*ecc2
); /* Inv. ecc2 & ecc3 */
120 *ecc3
= ((~reg1
)<<2)|BIT1BIT0
; /* Make TEL format */
125 * *eccdata; * ECC DATA
126 * ecc1; * LP15,LP14,LP13,...
127 * ecc2; * LP07,LP06,LP05,...
128 * ecc3; * CP5,CP4,CP3,...,"1","1"
130 u8
correct_data(u8
*data
, u8
*eccdata
, u8 ecc1
, u8 ecc2
, u8 ecc3
)
132 u32 l
; /* Working to check d */
133 u32 d
; /* Result of comparison */
134 u32 i
; /* For counting */
135 u8 d1
, d2
, d3
; /* Result of comparison */
136 u8 a
; /* Working for add */
137 u8 add
; /* Byte address of cor. DATA */
138 u8 b
; /* Working for bit */
139 u8 bit
; /* Bit address of cor. DATA */
141 d1
= ecc1
^eccdata
[1]; d2
= ecc2
^eccdata
[0]; /* Compare LP's */
142 d3
= ecc3
^eccdata
[2]; /* Compare CP's */
143 d
= ((u32
)d1
<<16) /* Result of comparison */
148 return 0; /* If No error, return */
150 if (((d
^(d
>>1))&CORRECTABLE
) == CORRECTABLE
) { /* If correctable */
152 add
= 0; /* Clear parameter */
155 for (i
= 0; i
< 8; ++i
) { /* Checking 8 bit */
157 add
|= a
; /* Make byte address from LP's */
158 l
>>= 2; a
>>= 1; /* Right Shift */
161 bit
= 0; /* Clear parameter */
163 for (i
= 0; i
< 3; ++i
) { /* Checking 3 bit */
165 bit
|= b
; /* Make bit address from CP's */
166 l
>>= 2; b
>>= 1; /* Right shift */
170 data
[add
] ^= (b
<<bit
); /* Put corrected data */
174 i
= 0; /* Clear count */
175 d
&= 0x00ffffffL
; /* Masking */
177 while (d
) { /* If d=0 finish counting */
179 ++i
; /* Count number of 1 bit */
180 d
>>= 1; /* Right shift */
183 if (i
== 1) { /* If ECC error */
184 eccdata
[1] = ecc1
; eccdata
[0] = ecc2
; /* Put right ECC code */
188 return 3; /* Uncorrectable error */
191 int _Correct_D_SwECC(u8
*buf
, u8
*redundant_ecc
, u8
*calculate_ecc
)
195 err
= correct_data(buf
, redundant_ecc
, *(calculate_ecc
+ 1),
196 *(calculate_ecc
), *(calculate_ecc
+ 2));
198 memcpy(calculate_ecc
, redundant_ecc
, 3);
200 if (err
== 0 || err
== 1 || err
== 2)
206 void _Calculate_D_SwECC(u8
*buf
, u8
*ecc
)
208 calculate_ecc(ecctable
, buf
, ecc
+1, ecc
+0, ecc
+2);