OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 716|回复: 4

[XILINX] modbus crc-16校验的Verilog,总是校验不对,问题在哪里?

[复制链接]

13

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
351
金钱
351
注册时间
2017-8-11
在线时间
92 小时
发表于 2024-5-13 10:28:25 | 显示全部楼层 |阅读模式
1金钱
先上源码:module CRC(
  input [7:0] data_in,
  input d_valid,
  output [15:0] crc,
  input sys_rst_n,
  input sys_clk);


  reg [15:0] lfsr_q,lfsr_c;


  assign crc = lfsr_q;


  always @(*)
    begin
    lfsr_c[0] = lfsr_q[8] ^ lfsr_q[9] ^ lfsr_q[10] ^ lfsr_q[11] ^ lfsr_q[12] ^ lfsr_q[13] ^ lfsr_q[14] ^ lfsr_q[15] ^ data_in[0] ^ data_in[1] ^ data_in[2] ^ data_in[3] ^ data_in[4] ^ data_in[5] ^ data_in[6] ^ data_in[7];
    lfsr_c[1] = lfsr_q[9] ^ lfsr_q[10] ^ lfsr_q[11] ^ lfsr_q[12] ^ lfsr_q[13] ^ lfsr_q[14] ^ lfsr_q[15] ^ data_in[1] ^ data_in[2] ^ data_in[3] ^ data_in[4] ^ data_in[5] ^ data_in[6] ^ data_in[7];
    lfsr_c[2] = lfsr_q[8] ^ lfsr_q[9] ^ data_in[0] ^ data_in[1];
    lfsr_c[3] = lfsr_q[9] ^ lfsr_q[10] ^ data_in[1] ^ data_in[2];
    lfsr_c[4] = lfsr_q[10] ^ lfsr_q[11] ^ data_in[2] ^ data_in[3];
    lfsr_c[5] = lfsr_q[11] ^ lfsr_q[12] ^ data_in[3] ^ data_in[4];
    lfsr_c[6] = lfsr_q[12] ^ lfsr_q[13] ^ data_in[4] ^ data_in[5];
    lfsr_c[7] = lfsr_q[13] ^ lfsr_q[14] ^ data_in[5] ^ data_in[6];
    lfsr_c[8] = lfsr_q[0] ^ lfsr_q[14] ^ lfsr_q[15] ^ data_in[6] ^ data_in[7];
    lfsr_c[9] = lfsr_q[1] ^ lfsr_q[15] ^ data_in[7];
    lfsr_c[10] = lfsr_q[2];
    lfsr_c[11] = lfsr_q[3];
    lfsr_c[12] = lfsr_q[4];
    lfsr_c[13] = lfsr_q[5];
    lfsr_c[14] = lfsr_q[6];
    lfsr_c[15] = lfsr_q[7] ^ lfsr_q[8] ^ lfsr_q[9] ^ lfsr_q[10] ^ lfsr_q[11] ^ lfsr_q[12] ^ lfsr_q[13] ^ lfsr_q[14] ^ lfsr_q[15] ^ data_in[0] ^ data_in[1] ^ data_in[2] ^ data_in[3] ^ data_in[4] ^ data_in[5] ^ data_in[6] ^ data_in[7];

end




  always @(posedge sys_clk, negedge sys_rst_n) begin
    if(!sys_rst_n) begin
      lfsr_q <= {16{1'b1}};
    end
    else begin
      lfsr_q <= d_valid ? lfsr_c : {16{1'b1}};
    end
  end // always
endmodule // crc


校验出来的结果总是不对。这是根据http://outputlogic.com/?page_id=321网站生成的,经测试该网站生成的 ccitt crc-16的校验结果是对的,但是modbus crc-16始终不对。ccitt初始值是0x0000,modbus初始值为0xffff。究竟问题出在哪里?求高手解答。






最佳答案

查看完整内容[请看2#楼]

自己搞出了一个正确结果,但还是对算法的过程不太明白。我是参照https://blog.csdn.net/wuzhikaidetb/article/details/136441181大神的帖子来捋的思路。既然CCITT和MODBUS差不多,那算法也应该差不多,但是上面的源码结果却不对。问题出在哪呢,自己先看了看帖子,经过多次调整,发现需要输入和输出翻转。翻转后仍然结果不对,但是对比一个C或C#程序,假如初始值都是0X0000,那么C程序结果和FPGA结果是一样的,但是初始值改为0XFFF ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

13

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
351
金钱
351
注册时间
2017-8-11
在线时间
92 小时
 楼主| 发表于 2024-5-13 10:28:26 | 显示全部楼层
自己搞出了一个正确结果,但还是对算法的过程不太明白。我是参照https://blog.csdn.net/wuzhikaidetb/article/details/136441181大神的帖子来捋的思路。既然CCITT和MODBUS差不多,那算法也应该差不多,但是上面的源码结果却不对。问题出在哪呢,自己先看了看帖子,经过多次调整,发现需要输入和输出翻转。翻转后仍然结果不对,但是对比一个C或C#程序,假如初始值都是0X0000,那么C程序结果和FPGA结果是一样的,但是初始值改为0XFFFF,结果就不一样了。究竟问题出在哪里,自己仍然没弄明白,但是自己经过测试计算出了一个FPGA的校验初始值,它不是0X0000,也不是0XFFFF,但是经过校验后也可以得出和C程序一样的正确结果,暂时还没发现有错误的。我觉得FPGA最难的就是资源少,算法或思路确实是难,但只要有资源,比猫画虎离成功也就不远了,当然做项目不能只能只想着比猫画虎。就一个简单的MODBUS-CRC校验搜遍全网几乎找不出一个真正的并行VERILOG源码,这要是换C语言或其他CODE,结果已经屏幕满天飞了。发个帖子吧,很少人看,很少人回,就得自己慢慢琢磨,慢慢解决。
回复

使用道具 举报

3

主题

2012

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5615
金钱
5615
注册时间
2018-10-21
在线时间
1590 小时
发表于 2024-5-13 13:43:50 | 显示全部楼层
结果值差距大吗,看看是不是还需要对结果值高低位互换,取反等等这些
回复

使用道具 举报

13

主题

53

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
351
金钱
351
注册时间
2017-8-11
在线时间
92 小时
 楼主| 发表于 2024-5-13 14:11:04 | 显示全部楼层
QinQZ 发表于 2024-5-13 13:43
结果值差距大吗,看看是不是还需要对结果值高低位互换,取反等等这些

差距很大。例如:校验55 A5 00 50 00 00 0F,结果应该是F457,而按上面的电路计算结果是8A16,虽说8A16取反后,经过一系列复杂(看不出有任何规律的)移位操作,也能变为F457,但是感觉还是不对。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2024-6-18 00:48:30 | 显示全部楼层
duanzhiruorou 发表于 2024-6-17 10:16
自己搞出了一个正确结果,但还是对算法的过程不太明白。我是参照https://blog.csdn.net/wuzhikaidetb/artic ...

谢谢分享
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 13:03

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表