summaryrefslogtreecommitdiffhomepage
path: root/src/crc.c
blob: 0451c363ca2b8a8bc74407ac843454f9f11bb115 (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
/*
** crc.c - calculate CRC
**
** See Copyright Notice in mruby.h
*/

#include <limits.h>
#include <stdint.h>
// Calculate CRC (CRC-16-CCITT)
//
//  0000_0000_0000_0000_0000_0000_0000_0000
//          ^|------- CRC -------|- work --|
//        carry
#define  CRC_16_CCITT       0x11021ul        //x^16+x^12+x^5+1
#define  CRC_XOR_PATTERN    (CRC_16_CCITT << 8)
#define  CRC_CARRY_BIT      (1 << 24)

uint16_t
calc_crc_16_ccitt(unsigned char *src, int nbytes)
{
  uint32_t   crcwk = 0ul;
  int             ibyte, ibit;

  for (ibyte = 0; ibyte < nbytes; ibyte++) {
    crcwk |= *src++;
    for (ibit = 0; ibit < CHAR_BIT; ibit++) {
      crcwk <<= 1;
      if (crcwk & CRC_CARRY_BIT) {
        crcwk ^= CRC_XOR_PATTERN;
      }
    }
  }
  return (uint16_t)(crcwk >> 8);
}