飞道的博客

fpga实操训练(硬件乘法器)

416人阅读  评论(0)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

        fpga上面的资源一般分成lut、pin、dff、dsp、pll。至于rom、ram、fifo,一般也是基于dff和lut来创建的,之前我们也讨论过。今天正好可以讨论下乘法器的使用。

        硬件乘法器在fpga上也是紧俏资源。对于fpga来说,加减运算、逻辑运算、移位运算,这些都是比较简单的。但是如果涉及到乘法,就比较麻烦一点了。而除法运算,对于fpga的开发者来说,一般也是转换成乘法运算。至于说浮点运算,通常是不会涉及的,这也不是fpga的强项所在。

1、创建一个ip_dsp工程

        这一步骤和之前其他工程的创建方法没有太多的不同。

2、调用lpm_mult乘法器

        在ip catalog中输入mult,在提示的选项中选择lpm_mult,

         命名好文件之后,就可以开始配置了。这里面最重要的部分就是设置字节的宽度,

         设置好宽度信息之后,其他部分都采用默认配置即可。

3、准备测试verilog文件

        有了ip之后,下面需要做的工作就是开始编写测试verilog文件,


  
  1. module top(clk, rst);
  2. input clk;
  3. input rst;
  4. wire clk;
  5. wire rst;
  6. reg[ 7: 0] data1;
  7. reg[ 7: 0] data2;
  8. wire[ 15: 0] result;
  9. always@(posedge clk or negedge rst)
  10. if(!rst)
  11. data1 <= 8 'd0;
  12. else
  13. data1 <= data1 + 1 'b1;
  14. always@(posedge clk or negedge rst)
  15. if(!rst)
  16. data2 <= 8 'd0;
  17. else
  18. data2 <= data2 + 1 'b1;
  19. lpm_mult_demo lpm_mult_demo0(
  20. .dataa(data1),
  21. .datab(data2),
  22. .result(result)
  23. );
  24. endmodule

        测试的方法比较简单,就是data1和data2不断自增,然后查看lpm_mult_demo的结果是多少。如果结果正确,那代表ip调用没有问题;反之则代表ip使用上面存在错误。这个时候,如果编译的话,通过compile report就会发现dsp资源确实被占用了,

4、配置sdc文件

        前面说过,在fpga过程中,有必要调试编译器哪一个pin是时钟,时钟的频率是多少,这样综合器才能帮助我们做更好的优化和检查。


  
  1. # Clock constraints
  2. create_clock -name "clk" -period 20.000ns [ get_ports {clk}]
  3. # Automatically constrain PLL and other generated clocks
  4. derive_pll_clocks -create_base_clocks
  5. # Automatically calculate clock uncertainty to jitter and other effects.
  6. derive_clock_uncertainty
  7. # tsu/th constraints
  8. # tco constraints
  9. # tpd constraints

        有了这一步,就可以在compile report中获取到当前最大允许的时钟频率、最差运行路径这些信息了。 比如下图,第一张是1.2v、室温85度时的最大允许频率,

         最差路径信息,

5、配置pin引脚

        pin的引脚部分只使用到了clk和rst,所以只要绑定到E1和N13即可。

6、配置stc文件

        因为整个fpga工程没有信号输出,所以如果需要验证我们的测试有没有成功,有必要借助于signal tap来完成这个事情。

7、测试和验证

        等这一切都准备好之后,就可以生成sof文件,烧入到fpga里面查看一下运行情况了。

        通过观察可以看到一个有意义的现象,那就是和rom、ram不同,硬件乘法器是会立马给出运算结果的。比如说,当data1和data2都是120的时候,这个时候结果14400就出来了。这和之前的ip会在下一个节拍才给出结果是完全不一样的,这是需要注意的地方。


转载:https://blog.csdn.net/feixiaoxing/article/details/128502888
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场