计算机应用 | 古代文学 | 市场营销 | 生命科学 | 交通物流 | 财务管理 | 历史学 | 毕业 | 哲学 | 政治 | 财税 | 经济 | 金融 | 审计 | 法学 | 护理学 | 国际经济与贸易
计算机软件 | 新闻传播 | 电子商务 | 土木工程 | 临床医学 | 旅游管理 | 建筑学 | 文学 | 化学 | 数学 | 物理 | 地理 | 理工 | 生命 | 文化 | 企业管理 | 电子信息工程
计算机网络 | 语言文学 | 信息安全 | 工程力学 | 工商管理 | 经济管理 | 计算机 | 机电 | 材料 | 医学 | 药学 | 会计 | 硕士 | 法律 | MBA
现当代文学 | 英美文学 | 通讯工程 | 网络工程 | 行政管理 | 公共管理 | 自动化 | 艺术 | 音乐 | 舞蹈 | 美术 | 本科 | 教育 | 英语 |

CD-ROM格式数据的软解码模块设计(2)

2017-08-31 01:34
导读:2 CD-ROM扇区中的EDC检错原理及算法 CD-ROM扇区采用32位CRC(循环冗余校验码)检错码,其生成多项式为 P(X)=(X 16 X 15 X 2 1)×(X 16 X 2 X 1) 对应的码字是0x1


2 CD-ROM扇区中的EDC检错原理及算法

CD-ROM扇区采用32位CRC(循环冗余校验码)检错码,其生成多项式为

P(X)=(X 16 X 15 X 2 1)×(X 16 X 2 X 1)

对应的码字是0x18001801B。计算CRC码时用的数据块是从扇区的开头到用户数据区结束为止的数据字节。即将字节0~2063共2064字节的数据所对应的长多项式整除P(X),得到32位的余式,放在2064~2067字节位置。这2068字节的数据对应的多项式是能够被生成多项式P(X)整除的。如果不能整除,则表明数据有错。所以,我们的解码过程就将2068字节的数据组成的多项式来整除生成多项式,如果余式为0,则表明数据正确,否则数据有错。

但我们不可能直接进行长除法操作,因为计算机不可能将一个2068×8位的极其长的二进制数直接拿来做长除法。根据长除法的规律,以字节(8比特)为单位进行操作,每次除法将上一字节的所得的余数与本字节组合成新的数进行除法运算。除式是33位的,因此,每个字节的除法须把这个字节的数左移24位,跟上次的余式组合成一个32位的二进制数,来整除除式。主要实现现代码如下:

for(i=0;i

上一篇:CPLD器件在时间统一系统中的应用 下一篇:没有了