EMILE/libemile/emile_checksum.c

42 lines
614 B
C
Raw Normal View History

2005-02-02 14:25:30 +00:00
/*
*
2008-08-12 09:12:25 +00:00
* (c) 2004-2008 Laurent Vivier <Laurent@lvivier.info>
2005-02-02 14:25:30 +00:00
*
*/
#include "libemile.h"
2008-08-12 09:12:25 +00:00
#include <stdio.h>
2005-02-02 14:25:30 +00:00
unsigned short emile_checksum(unsigned char *addr, unsigned int length)
2005-02-02 14:25:30 +00:00
{
int j;
unsigned short sum = 0;
2008-08-12 09:12:25 +00:00
length &= 0xFFFF;
2005-02-02 14:25:30 +00:00
for (j = 0; j < length; j++)
{
sum += addr[j];
sum = (sum << 1) | (sum >> 15);
}
if (sum == 0)
sum = 0xFFFF;
return sum;
}
unsigned short emile_checksum_ATA(unsigned char *addr, unsigned int length)
2005-02-02 14:25:30 +00:00
{
unsigned int sum = 0;
unsigned int i;
for (i = 0; i < length; i++)
{
sum += addr[i];
sum <<= 1;
sum |= (sum & 0x00010000) ? 1 : 0;
}
return sum;
}