mirror of
https://github.com/blawar/GLideN64.git
synced 2024-07-02 09:03:37 +00:00
52 lines
870 B
C++
52 lines
870 B
C++
![]() |
#include "CRC.h"
|
||
|
#include <arm_acle.h>
|
||
|
|
||
|
void CRC_BuildTable()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
u32 CRC_Calculate( u32 crc, const void * buffer, u32 count )
|
||
|
{
|
||
|
u8 *p;
|
||
|
u32 orig = crc;
|
||
|
|
||
|
p = (u8*) buffer;
|
||
|
|
||
|
// use eight byte crc intrinsic __crc32d if count is high enough.
|
||
|
// __crc32d, __crc32w, __crc32h and __crc32b use polynomial 0x04C11DB7
|
||
|
while (count >= 8) {
|
||
|
crc = __crc32d(crc, *((u64*)p));
|
||
|
p += 8;
|
||
|
count -= 8;
|
||
|
}
|
||
|
if (count >= 4) {
|
||
|
crc = __crc32w(crc, *((u32*)p));
|
||
|
p += 4;
|
||
|
count -= 4;
|
||
|
}
|
||
|
if (count >= 2) {
|
||
|
crc = __crc32h(crc, *((u16*)p));
|
||
|
p += 2;
|
||
|
count -= 2;
|
||
|
}
|
||
|
if (count == 1)
|
||
|
crc = __crc32b(crc, *p);
|
||
|
|
||
|
return crc ^ orig;
|
||
|
}
|
||
|
|
||
|
u32 CRC_CalculatePalette(u32 crc, const void * buffer, u32 count )
|
||
|
{
|
||
|
u8 *p;
|
||
|
u32 orig = crc;
|
||
|
|
||
|
p = (u8*) buffer;
|
||
|
while (count--) {
|
||
|
// use two byte intrinsic __crc32h
|
||
|
crc = __crc32h(crc, *((u16*)p));
|
||
|
p += 8;
|
||
|
}
|
||
|
|
||
|
return crc ^ orig;
|
||
|
}
|