![]() |
|
||||||||||||||
| . 网站首页 . 新闻 . 新品 . 方案 . 专访 . 活动 . DSP . EDA . 评测室 . 技术文库 . 会员区 . 商城 . 服务导航 . 邮购 . 资源 . | ||
|
||
|
|||||
| 有关并行CRC校验的一些尝试--Verilog | |||||
作者:Free 文章来源:Free 点击数: 更新时间:2008-1-4 ![]() |
|||||
|
首先介绍一个不错的CRC校验的网站,http://www.easics.com/webtools/crctool 现在估计所有的工程应用均来自该网站生成的代码。使用方便。 但是该网站的代码不易于CRC的学习和研究,但是保证是对的,工程实践证明。现在将我的研究成果和大家分享一下:用于任意CRC的校验。 网站上的校验方式最大提供CRC32 和任意数据位(最大511)的校验。当然一般的情况下应该是够用了。我所做的设计可以扩展到任意数据的校验,当然是并行数据的校验,串行数据的校验应用可以参照网上的一些资料。很简单,不再赘述。以CRC32为例 首先建立函数,=====设计的的关键 //-------------------------------------------------------------------------- input [31:0] crc; endfunction /*这是校验和左移一位求校验和的计算公式*/ 相同的如果CRC8 //-------------------------------------------------------------------------- input [7:0] crc; endfunction 其他的是一样的。 其次 如果我们要求CRC32_D(M)M >= 32 function [31:0] next_c32_ge; //M+1 is the data maximum with 假设我们求CRC32_D64 那么M=63 function [31:0] next_c32_D64; //M+1 is the data maximum with 假设我们求CRC32_D128 那么M=127 function [31:0] next_c32_D128; input [127:0] data; 再次如果我们要求CRC32_D(M) M<=32 function [31:0] next_c32_le; 我们首先校验完毕所有的有效数据位下面的函数是对CRC的空闲位的修正。 function [K-1:0] next_cK_1_any_LEK_1; //以CRC32D16 K =32 N =16 这个函数就变成 function [31:0] next_C32_D16; 经过modelsim和Qii软件仿真无误。本来想做成动态数据长度校验的函数,本人也作了一些尝试,在CRC--N N = 2^m时都是没有问题的 比如CRC8 CRC16 CRC32 CRC64 等等,但是若是不是这些数值比如CRC12 CRC10的Qii会抱错(因为部分函数的输入部分必须为常数),但是Modelsim不会抱错而且仿真和实际的结果一致。可以用来做验证。 这边仅仅举了CRC32 的例子,其他的也都类似。欢迎大家把想法告诉我。 |
|||||
| 欢迎点击进入:TI德州中文网 (国内唯一针对TI应用的中文技术网站) 文章录入:admin 责任编辑:admin | |||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | |||||
| 最新热点 | 最新推荐 | 相关文章 | ||
| 没有相关文章 |
| 网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告 | 管理登录 | | |||
|
|