当前位置:首页 > 嵌入式 > 嵌入式教程
[导读] CRC算法及工作原理

  CRC检验

  CRC校验实用程序库 在数据存储和数据通讯领域,为了保证数据的正确,就不得不采用检错的手段。在诸多检错手段中,CRC是最著名的一种。CRC的全称是循环冗余校验,其特点是:检错能力极强,开销小,易于用编码器及检测电路实现。从其检错能力来看,它所不能发现的错误的几率仅为0.0047%以下。从性能上和开销上考虑,均远远优于奇偶校验及算术和校验等方式。因而,在数据存储和数据通讯领域,CRC无处不在:著名的通讯协议X.25的FCS(帧检错序列)采用的是CRC-CCITT,WinRAR

  、NERO、ARJ、LHA等压缩工具软件采用的是CRC32,磁盘驱动器的读写采用了CRC16,通用的图像存储格式GIF、TIFF等也都用CRC作为检错手段。

  CRC的本质是模-2除法的余数,采用的除数不同,CRC的类型也就不一样。通常,CRC的除数用生成多项式来表示。最常用的CRC码的生成多项式如表1所示。

  @@10A08800.GIF;表1.最常用的CRC码及生成多项式@@

  由于CRC在通讯和数据处理软件中经常采用,笔者在实际工作中对其算法进行了研究和比较,总结并编写了一个具有最高效率的CRC通用程序库。该程序采用查表法计算CRC,在速度上优于一般的直接模仿硬件的算法,可以应用于通讯和数据压缩程序。

  算法

  通常的CRC算法在计算一个数据段的CRC值时,其CRC值是由求解每个数值的CRC值的和对CRC寄存器的值反复更新而得到的。这样,求解CRC的速度较慢。通过对CRC算法的研究,我们发现:一个8位数据加到16位累加器中去,只有累加器的高8位或低8位与数据相作用,其结果仅有256种可能的组合值。因而,我们可以用查表法来代替反复的运算,这也同样适用于CRC32的计算。本文所提供的程序库中,函数crchware是一般的16位CRC的算法;mk-crctbl用以在内存中建立一个CRC数值表;crcupdate用以查表并更新CRC累加器的值;crcrevhware和crcrevupdate是反序算法的两个函数;BuildCRCTable、CalculateBlockCRC32和UpdateCharac

  terCRC32用于CRC32的计算。

  /* CRC.C——CRC程序库 */

  #define CRCCCITT 0x1021

  #define CCITT-REV 0x8408

  #define CRC16 0x8005

  #define CRC16-REV 0xA001

  #define CRC32-POLYNOMIAL 0xEDB88320L

  /* 以上为CRC除数的定义 */

  #define NIL 0

  #define crcupdate(d,a,t)*(a)=(*(a)<<8)^(t)[(*(a)>>8)^(d)];

  #define crcupdate16(d,a,t)*(a)=(*(a)>>8^(t)[(*(a)^(d))&0x00ff])

  /* 以上两个宏可以代替函数crcupdate和crcrevupdate */

  #include #include #include /* 函数crchware是传统的CRC算法,其返回值即CRC值 */ unsigned short crchware(data,genpoly,accum)

  unsigned short data;/* 输入的数据 */

  unsigned short genpoly;/* CRC除数 */

  unsigned short accum;/* CRC累加器值 */

  {

  static int i;

  data<<=8;

  for(i=8;i>0;i--)

  {

  if((data^accum)&0x8000)

  accum=(accum<<1)^genpoly;

  else

  accum<<=1;

  data<<=1;

  }[!--empirenews.page--]

  return (accum);

  }

  /* 函数mk-crctbl利用函数crchware建立内存中的CRC数值表 */

  unsigned short *mk-crctbl(poly,crcfn);

  unsigned short poly;/* CRC除数--CRC生成多项式 */

  R>unsigned short (*crcfn)();/* 指向CRC函数(例如crchware)的指针 */

  {

  /* unsigned short */malloc(); */

  unsigned short *crctp;

  int i;

  if((crctp=(unsigned short*)malloc(256*sizeof(unsigned)))==0)

  return 0;

  for(i=0;i<256;i++)

  crctp=(*crcfn)(i,poly,0);

  return crctp;

  }

  /* 函数mk-crctbl的使用范例 */

  if((crctblp=mk-crctbl(CRCCCITT,crchware))==NIL)

  {

  puts("insuff memory for CRC lookup table.n");

  return 1; */

  /* 函数crcupdate用以用查表法计算CRC值并更新CRC累加器值 */

  void crcupdate(data,accum,crctab)

  unsigned short data;/* 输入的数据 */

  unsigned short *accum;/* 指向CRC累加器的指针 */

  unsigned short *crctab;/* 指向内存中CRC表的指针 */

  {

  static short comb-val;

  comb-val=(*accum>>8)^data;

  *accum=(*accum<<8)^crctab[comb-val];

  }[!--empirenews.page--]

  /* 函数crcrevhware是传统的CRC算法的反序算法,其返回值即CRC值 */

  unsigned short crcrevhware(data,genpoly,accum)

  unsigned short data;

  unsigned short genpoly;

  unsigned short accum;

  {

  static int i;

  data<<=1;

  for(i=8;i>0;i--)

  {

  data>>=1;

  if((data^accum)&0x0001)

  accum=(accum>>1)^genpoly;

  else

  accum>>=1;

  }

  return accum;

  }

  /* 函数crcrevupdate用以用反序查表法计算CRC值并更新CRC累加器值 */

  void crcrevupdate(data,accum,crcrevtab)

  unsigned short data;

  unsigned short *accum;

  CRC检验方法的工作原理

  循环冗余码CRC在发送端编码和接收端校验时,都可以利用事先约定的生成多项式G(X)来得到,k位要发送的信息位可对应一个(k-1)次多项式K(X),r位冗余位对应于一个(r-1)次多项式R(X),由k位信息位后面加上r位冗余位组成的n=k+r的码字则对应于一个(n-1)次多项式T(X)X×K(X)+R(X)。也即在发送端产生一个循环冗余码,附加在信息位后面一起发送到接收端。接收端的检验过程就是将接收到的码字多项式除以G(X),若余式为零则认为传输无差错;若余式不为零则传输有差错。

  CRC - Crazy Roller Crew

  CRC英文全称是Crazy Roller Crew,是疯狂轮滑阵线(CRF)核心成员团体。

  CRC是疯狂轮滑阵线组织力量和轮滑技术的核心,服务于疯狂轮滑阵线的技术团队,由阵线会员组成。但绝非纯技术团队,亲和力及沟通能力作为基本条件存在。荣誉承担疯狂轮滑阵线的各种对外技术交流活动。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

黑石(Blackstone Group)公布2022年第三季度财务业绩。季度营收10.58亿美元,上年同期为62.24亿美元,同比下降83%。归属于公司净利润为229.6万美元,上年同期为14.02亿美元。总资产管理规模...

关键字: GROUP ST CK AC

世界上最大的两家资产管理公司贝莱德(BlackRock)和先锋(Vanguard)等金融机构已在英国一项问询中表示,它们将继续投资化石燃料,并且不认同气候变化计划要求停止新的煤炭、石油和天然气投资的观点。贝莱德是试图采取...

关键字: CK 天然气 AN AC

北京2022年10月14日 /美通社/ -- 2022年10月14日,亚马逊云科技举办一年一度的中国合作伙伴峰会。本届峰会以"价值成就 探索无限"为主题,面向合作伙伴推出"3+3价值成就体系...

关键字: 亚马逊 网络 AC MARKET

珀金埃尔默日前推出Cellaca PLX图像式细胞分析系统,这是业界第一款能让研究人员在单个自动化工作流中实现对细胞样本多个关键质量属性进行分析和评估的台式平台,包括对细胞性质、质量和数量的分析评估。拥有尖端技术的Cel...

关键字: AC EXCEL 硬件 自动化

加速简化细胞和基因治疗的研发及制造流程 Cellaca® PLX图像式细胞分析仪带来工作流程的革新,一站式满足多个关键质量属性的分析 上海2022年10月12日 /美通社/ -- 致力于以创新技术打造更健康世...

关键字: AC 自动化 NEX EXCEL

上海2022年10月11日 /美通社/ -- 全球领先金融科技公司Airwallex空中云汇今日宣布完成1亿美元E2轮融资。现有投资方Square Peg、Salesforce Ventures、红杉中国、Lone Pi...

关键字: AIR CK AC API

上海2022年10月8日 /美通社/ -- 2022年10月7日,第34次上海市市长国际企业家咨询会议(IBLAC)在线举办。作为深化全球合作的重要平台与展示上海形象的重要名片,本次会议汇聚了来自全球24个城市...

关键字: AC 可持续发展 MIDDOT 数字化

百龄哥"洋高参"为上海再献良策! 上海2022年10月8日 /美通社/ -- 10月7日,勃林格殷格翰全球执行董事会主席冯保和(Hubertus von Baumbach)先生应邀出席第34届上海市...

关键字: 可持续发展 AC DNA 可再生能源

利安德巴塞尔宣布将在其德国法兰克福工厂启动一家新的催化剂生产工厂。该项目直接关系到基础设施项目的投资、不断增长的人口(特别是在新兴国家和地区)对聚合物需求的增加,以及Hostalen ACP聚乙烯(PE)技术的价值。此项...

关键字: ST OS AC

上海2022年9月30日 /美通社/ -- 2022年9月30日,君实生物肿瘤免疫高峰论坛暨拓益®(特瑞普利单抗注射液)肺癌适应症全国上市会以线上形式顺利召开。大会汇集中外肺癌大咖学者,荟萃全球肺癌前沿...

关键字: PD CHOICE AC SHEET

嵌入式教程

6897 篇文章

关注

发布文章

编辑精选

技术子站

关闭