Contiki 2.5
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
* @(#)$Id: crc16.h,v 1.4 2008/10/15 14:17:28 nvt-se Exp $
54
*/
55
#ifndef __CRC16_H__
56
#define __CRC16_H__
57
58
/**
59
* \brief Update an accumulated CRC16 checksum with one byte.
60
* \param b The byte to be added to the checksum
61
* \param crc The accumulated CRC that is to be updated.
62
* \return The updated CRC checksum.
63
*
64
* This function updates an accumulated CRC16 checksum
65
* with one byte. It can be used as a running checksum, or
66
* to checksum an entire data block.
67
*
68
* \note The algorithm used in this implementation is
69
* tailored for a running checksum and does not perform as
70
* well as a table-driven algorithm when checksumming an
71
* entire data block.
72
*
73
*/
74
unsigned
short
crc16_add
(
unsigned
char
b,
unsigned
short
crc);
75
76
/**
77
* \brief Calculate the CRC16 over a data area
78
* \param data Pointer to the data
79
* \param datalen The length of the data
80
* \param crc The accumulated CRC that is to be updated (or zero).
81
* \return The CRC16 checksum.
82
*
83
* This function calculates the CRC16 checksum of a data area.
84
*
85
* \note The algorithm used in this implementation is
86
* tailored for a running checksum and does not perform as
87
* well as a table-driven algorithm when checksumming an
88
* entire data block.
89
*/
90
unsigned
short
crc16_data
(
const
unsigned
char
*data,
int
datalen,
91
unsigned
short
acc);
92
93
#endif
/* __CRC16_H__ */
94
95
/** @} */
96
/** @} */
Generated on Fri Aug 30 2013 12:34:05 for Contiki 2.5 by
1.8.3.1