Contiki-Inga 3.x
Main Page
Related Pages
Modules
Data Structures
Files
Examples
File List
Globals
core
lib
crc16.h
Go to the documentation of this file.
1
/** \addtogroup lib
2
* @{ */
3
4
/**
5
* \defgroup crc16 Cyclic Redundancy Check 16 (CRC16) calculation
6
*
7
* The Cyclic Redundancy Check 16 is a hash function that produces a
8
* checksum that is used to detect errors in transmissions. The CRC16
9
* calculation module is an iterative CRC calculator that can be used
10
* to cumulatively update a CRC checksum for every incoming byte.
11
*
12
* @{
13
*/
14
15
/**
16
* \file
17
* Header file for the CRC16 calculcation
18
* \author
19
* Adam Dunkels <adam@sics.se>
20
*
21
*/
22
23
/*
24
* Copyright (c) 2005, Swedish Institute of Computer Science
25
* All rights reserved.
26
*
27
* Redistribution and use in source and binary forms, with or without
28
* modification, are permitted provided that the following conditions
29
* are met:
30
* 1. Redistributions of source code must retain the above copyright
31
* notice, this list of conditions and the following disclaimer.
32
* 2. Redistributions in binary form must reproduce the above copyright
33
* notice, this list of conditions and the following disclaimer in the
34
* documentation and/or other materials provided with the distribution.
35
* 3. Neither the name of the Institute nor the names of its contributors
36
* may be used to endorse or promote products derived from this software
37
* without specific prior written permission.
38
*
39
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
40
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
41
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
42
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
43
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
44
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
45
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
46
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
47
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
48
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
49
* SUCH DAMAGE.
50
*
51
* This file is part of the Contiki operating system.
52
*
53
*/
54
#ifndef CRC16_H_
55
#define CRC16_H_
56
57
/**
58
* \brief Update an accumulated CRC16 checksum with one byte.
59
* \param b The byte to be added to the checksum
60
* \param crc The accumulated CRC that is to be updated.
61
* \return The updated CRC checksum.
62
*
63
* This function updates an accumulated CRC16 checksum
64
* with one byte. It can be used as a running checksum, or
65
* to checksum an entire data block.
66
*
67
* \note The algorithm used in this implementation is
68
* tailored for a running checksum and does not perform as
69
* well as a table-driven algorithm when checksumming an
70
* entire data block.
71
*
72
*/
73
unsigned
short
crc16_add
(
unsigned
char
b,
unsigned
short
crc);
74
75
/**
76
* \brief Calculate the CRC16 over a data area
77
* \param data Pointer to the data
78
* \param datalen The length of the data
79
* \param crc The accumulated CRC that is to be updated (or zero).
80
* \return The CRC16 checksum.
81
*
82
* This function calculates the CRC16 checksum of a data area.
83
*
84
* \note The algorithm used in this implementation is
85
* tailored for a running checksum and does not perform as
86
* well as a table-driven algorithm when checksumming an
87
* entire data block.
88
*/
89
unsigned
short
crc16_data
(
const
unsigned
char
*data,
int
datalen,
90
unsigned
short
acc);
91
92
#endif
/* CRC16_H_ */
93
94
/** @} */
95
/** @} */
Generated on Thu Apr 24 2014 16:26:11 for Contiki-Inga 3.x by
1.8.3.1