mirror of
https://github.com/Proxmark/proxmark3.git
synced 2025-10-24 12:46:24 +08:00
I have kept whatever copyright notices exist. Please add your own copyright notice if you have made any nontrivial changes or additions to the code. There are several files without any attribution, currently.
42 lines
1.1 KiB
C
42 lines
1.1 KiB
C
//-----------------------------------------------------------------------------
|
|
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
|
|
// at your option, any later version. See the LICENSE.txt file for the text of
|
|
// the license.
|
|
//-----------------------------------------------------------------------------
|
|
// Generic CRC calculation code.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#include "crc.h"
|
|
|
|
void crc_init(crc_t *crc, int order, uint32_t polynom, uint32_t initial_value, uint32_t final_xor)
|
|
{
|
|
crc->order = order;
|
|
crc->polynom = polynom;
|
|
crc->initial_value = initial_value;
|
|
crc->final_xor = final_xor;
|
|
crc->mask = (1L<<order)-1;
|
|
crc_clear(crc);
|
|
}
|
|
|
|
void crc_update(crc_t *crc, uint32_t data, int data_width)
|
|
{
|
|
int i;
|
|
for(i=0; i<data_width; i++) {
|
|
int oldstate = crc->state;
|
|
crc->state = crc->state >> 1;
|
|
if( (oldstate^data) & 1 ) {
|
|
crc->state ^= crc->polynom;
|
|
}
|
|
data >>= 1;
|
|
}
|
|
}
|
|
|
|
void crc_clear(crc_t *crc)
|
|
{
|
|
crc->state = crc->initial_value & crc->mask;
|
|
}
|
|
|
|
uint32_t crc_finish(crc_t *crc)
|
|
{
|
|
return ( crc->state ^ crc->final_xor ) & crc->mask;
|
|
}
|