1 //-----------------------------------------------------------------------------
2 // This code is licensed to you under the terms of the GNU GPL, version 2 or,
3 // at your option, any later version. See the LICENSE.txt file for the text of
5 //-----------------------------------------------------------------------------
6 // Generic CRC calculation code.
7 //-----------------------------------------------------------------------------
11 void crc_init(crc_t
*crc
, int order
, uint32_t polynom
, uint32_t initial_value
, uint32_t final_xor
)
14 crc
->polynom
= polynom
;
15 crc
->initial_value
= initial_value
;
16 crc
->final_xor
= final_xor
;
17 crc
->mask
= (1L<<order
)-1;
21 void crc_update(crc_t
*crc
, uint32_t data
, int data_width
)
24 for(i
=0; i
<data_width
; i
++) {
25 int oldstate
= crc
->state
;
26 crc
->state
= crc
->state
>> 1;
27 if( (oldstate
^data
) & 1 ) {
28 crc
->state
^= crc
->polynom
;
34 void crc_clear(crc_t
*crc
)
36 crc
->state
= crc
->initial_value
& crc
->mask
;
39 uint32_t crc_finish(crc_t
*crc
)
41 return ( crc
->state
^ crc
->final_xor
) & crc
->mask
;