[PATCH 3/4 v2] lib: add crc16_le helper
Matthieu CASTET
matthieu.castet at parrot.com
Wed Aug 18 12:10:11 EDT 2010
Hi,
thanks for the review.
Joakim Tjernlund a écrit :
>> This patch adds a crc16_le helper function to lib/crc16.c
>>
>> Signed-off-by: Matthieu CASTET <matthieu.castet at parrot.com>
>> Signed-off-by: Florian Fainelli <ffainelli at freebox.fr>
>> --
>> diff --git a/include/linux/crc16.h b/include/linux/crc16.h
>> index 9443c08..6c1c61f 100644
>> --- a/include/linux/crc16.h
>> +++ b/include/linux/crc16.h
>> @@ -26,5 +26,7 @@ static inline u16 crc16_byte(u16 crc, const u8 data)
>> return (crc >> 8) ^ crc16_table[(crc ^ data) & 0xff];
>> }
>>
>> +extern u16 crc16_le(u16 crc, const u8 *buffer, size_t len);
>> +
>> #endif /* __CRC16_H */
>>
>> diff --git a/lib/crc16.c b/lib/crc16.c
>> index 8737b08..ec4a95c 100644
>> --- a/lib/crc16.c
>> +++ b/lib/crc16.c
>> @@ -62,6 +62,18 @@ u16 crc16(u16 crc, u8 const *buffer, size_t len)
>> }
>> EXPORT_SYMBOL(crc16);
>>
>> +u16 crc16_le(u16 crc, u8 const *p, size_t len)
>> +{
>> + int i;
>> + while (len--) {
>> + crc ^= *p++ << 8;
>> + for (i = 0; i < 8; i++)
>> + crc = (crc << 1) ^ ((crc & 0x8000) ? 0x8005 : 0);
>> + }
>> + return crc;
>> +}
>> +EXPORT_SYMBOL(crc16_le);
>> +
>> MODULE_DESCRIPTION("CRC16 calculations");
>> MODULE_LICENSE("GPL");
>
> Don't recall much of my earlier crc32 work but the above looks wrong.
> crc & 0x8000 suggests this is a big endian crc.
yes it is a be crc while crc16 is a le one. So we should rename it to
crc16_be.
>if so, 0x8005 looks
> wrong too. see CRCPOLY_LE resp. CRCPOLY_BE for an idea.
Why ?
> What is this crc sum used for?
Onfi flash parsing in mtd.
Matthieu
More information about the linux-mtd
mailing list