aboutsummaryrefslogtreecommitdiffstats
path: root/tools/ioemu/iodev/crc32.cc
blob: a20abaaf8229bc486e2117cba33138a790488757 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/////////////////////////////////////////////////////////////////////////
// $Id: crc32.cc,v 1.4 2001/10/03 13:10:38 bdenney Exp $
/////////////////////////////////////////////////////////////////////////
//
/* CRC-32 calculator
 * Adapted from http://www.createwindow.org/programming/crc32/
 */

#include "crc32.h"

CRC_Generator::CRC_Generator() {
	init();
}

void CRC_Generator::init(void) {
  Bit32u POLYNOMIAL = 0x04c11db7;
  int i;

  for(i = 0; i<0xFF; i++) {
    int j;
    crc32_table[i]=reflect(i,8) << 24;
    for(j=0; j<8; j++)
      crc32_table[i] = (crc32_table[i]<<1)^(crc32_table[i] & (1<<31) ? POLYNOMIAL : 0);
    crc32_table[i] = reflect(crc32_table[i], 32);
  }
}

Bit32u CRC_Generator::reflect(Bit32u ref, Bit8u ch) {
  Bit32u value(0);
  int i;

  for(i=1; i<(ch+1); i++) {
    if(ref & 1)
      value |= 1 << (ch-i);
    ref >>= 1;
  }
  return value;
}

Bit32u CRC_Generator::get_CRC(Bit8u * buf, Bit32u buflen) {
  Bit32u ulCRC(0xFFFFFFFF);
  Bit32u len(buflen);
  Bit8u * buffer=(Bit8u *) buf;

  while(len--)
    ulCRC=(ulCRC>>8)^crc32_table[(ulCRC & 0xFF)^*buffer++];
  return ulCRC ^ 0xFFFFFFFF;
}