我在char* s = "pratik"
上调用了两个函数:
用户代码:
#include <zlib.h>
int main()
{
char *s = "pratik";
printf("%x\n",crc32(0x80000000, s, strlen(s)));
return 0;
}
输出: 66fa3c99
内核代码:
#include <linux/crc32.h>
int main()
{
char *s = "pratik";
u32 checksum = crc32(0x80000000, s, strlen(s));
printk("\nChecksum --> %x", checksum);
return checksum;
}
输出:
校验和 - &gt; d7389d3a
为什么相同字符串的校验和值不同?
答案 0 :(得分:9)
似乎有人对标准以太网(PKZIP,ITU V.42等)CRC-32执行前后独占或0xffffffff
这一事实感到不安。因此,Linux内核中的版本将其排除在外,并期望应用程序执行此操作。去图。
无论如何,您可以使用(非标准的)Linux crc32()
获得与(正确的)zlib crc32()
相同的结果,因此:
crc_final = crc32(crc_initial ^ 0xffffffff, buf, len) ^ 0xffffffff;
事实上,完全相同的代码也允许您使用zlib crc32()
复制Linux crc32()
。