Blame view

RIOT/sys/checksum/fletcher32.c 976 Bytes
fb11e647   vrobic   reseau statique a...
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
  /*
   * Copyright 2015 Eistec AB
   *
   * This file is subject to the terms and conditions of the GNU Lesser
   * General Public License v2.1. See the file LICENSE in the top level
   * directory for more details.
   */
  
  /**
   * @ingroup     sys_checksum_fletcher32
   * @{
   *
   * @file
   * @brief       Fletcher32 implementation
   *
   * @author      Joakim Nohlgård <joakim.nohlgard@eistec.se>
   *
   * @}
   */
  
  #include "checksum/fletcher32.h"
  
  uint32_t fletcher32(const uint16_t *data, size_t words)
  {
      uint32_t sum1 = 0xffff, sum2 = 0xffff;
  
      while (words) {
          unsigned tlen = words > 359 ? 359 : words;
          words -= tlen;
          do {
              sum2 += sum1 += *data++;
          } while (--tlen);
          sum1 = (sum1 & 0xffff) + (sum1 >> 16);
          sum2 = (sum2 & 0xffff) + (sum2 >> 16);
      }
      /* Second reduction step to reduce sums to 16 bits */
      sum1 = (sum1 & 0xffff) + (sum1 >> 16);
      sum2 = (sum2 & 0xffff) + (sum2 >> 16);
      return (sum2 << 16) | sum1;
  }