Subversion Repositories freemyipod

Rev

Rev 491 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
491 theseven 1
//
2
//
3
//    Copyright 2011 TheSeven
4
//
5
//
6
//    This file is part of emCORE.
7
//
8
//    emCORE is free software: you can redistribute it and/or
9
//    modify it under the terms of the GNU General Public License as
10
//    published by the Free Software Foundation, either version 2 of the
11
//    License, or (at your option) any later version.
12
//
13
//    emCORE is distributed in the hope that it will be useful,
14
//    but WITHOUT ANY WARRANTY; without even the implied warranty of
15
//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
//    See the GNU General Public License for more details.
17
//
18
//    You should have received a copy of the GNU General Public License along
19
//    with emCORE.  If not, see <http://www.gnu.org/licenses/>.
20
//
21
//
22
 
23
 
24
#include "global.h"
25
#include "crc32.h"
26
 
27
static const unsigned int crc32tab[16] =
28
{
29
   0x00000000, 0x1db71064, 0x3b6e20c8, 0x26d930ac, 0x76dc4190, 0x6b6b51f4, 0x4db26158, 0x5005713c,
30
   0xedb88320, 0xf00f9344, 0xd6d6a3e8, 0xcb61b38c, 0x9b64c2b0, 0x86d3d2d4, 0xa00ae278, 0xbdbdf21c
31
};
32
 
33
uint32_t crc32(const void* data, size_t length)
34
{
35
   const uint8_t* buf = (const uint8_t *)data;
36
   unsigned int crc = 0xffffffff;
37
 
38
   while (length--)
39
   {
40
      crc ^= *buf++;
41
      crc = crc32tab[crc & 0xf] ^ (crc >> 4);
42
      crc = crc32tab[crc & 0xf] ^ (crc >> 4);
43
   }
44
 
45
   return crc ^ 0xffffffff;
46
}