00001
00002
00003
00004
00005
00006
00007
00008 #define DTYPE unsigned char
00009
00010
static inline int mod255(
int x){
00011
while (x >= 255) {
00012 x -= 255;
00013 x = (x >> 8) + (x & 255);
00014 }
00015
return x;
00016 }
00017 #define MODNN(x) mod255(x)
00018
00019
extern unsigned char CCSDS_alpha_to[];
00020
extern unsigned char CCSDS_index_of[];
00021
extern unsigned char CCSDS_poly[];
00022
00023 #define MM 8
00024 #define NN 255
00025 #define ALPHA_TO CCSDS_alpha_to
00026 #define INDEX_OF CCSDS_index_of
00027 #define GENPOLY CCSDS_poly
00028 #define NROOTS 32
00029 #define FCR 112
00030 #define PRIM 11
00031 #define IPRIM 116
00032 #define A0 (NN)
00033
00034 #define ENCODE_RS encode_rs_8
00035 #define DECODE_RS decode_rs_8
00036
00037
void ENCODE_RS(DTYPE *data,DTYPE *parity);
00038
int DECODE_RS(DTYPE *data,
int *eras_pos,
int no_eras);