FPGA之道(65)代码中的约束信息(二)乘法器的相关约束

举报
李锐博恩 发表于 2021/07/15 03:15:00 2021/07/15
【摘要】 文章目录 前言乘法器的相关约束use_dsp48mult_style 前言 这是这个话题的第二篇,最重要的前言是本文节选自:《FPGA之道》。 乘法器的相关约束 通常,FPGA开发者们无需显式的使用相关的乘法器约束,因为当需要使用乘法器时,一般都会调用集成开发环境提供的乘法器IP核,并在其中完成乘法器的相关配置即可。这也就是说,编译器通常帮我们完...

前言

这是这个话题的第二篇,最重要的前言是本文节选自:《FPGA之道》。

乘法器的相关约束

通常,FPGA开发者们无需显式的使用相关的乘法器约束,因为当需要使用乘法器时,一般都会调用集成开发环境提供的乘法器IP核,并在其中完成乘法器的相关配置即可。这也就是说,编译器通常帮我们完成了在HDL中添加乘法器相关实现约束的工作。不过大量IP核的调用和修改可是一个比较繁琐的过程,因此了解一些基本的乘法器相关实现约束,可以有效的提高我们的工作效率。

use_dsp48

use_dsp48是一个综合约束,从它的名字我们就可以推断出,它肯定和【知己知彼篇->FPGA内部资源介绍->DSP】小节中介绍的这个DSP资源相关。的确是这样,在Xilinx生产的Vertex-4及以后系列的器件中,都普遍采用了这种名为DSP48的资源。它的内部主要是由一个高性能的硬件乘法器组成,不过除此以外它也可以实现加法、累加等基本运算,就连其内部的寄存器也可以另作它用,因此use_dsp48这一综合约束并不仅限于乘法器方面的应用。
下面列举出在HDL中嵌入use_dsp48约束的语法:
– VHDL syntax
– 第一步,先要声明use_dsp48约束;
attribute use_dsp48 : string;
– 第二步,为use_dsp48语法指定约束线网名称和属性取值;
attribute use_dsp48 of <{entity_name|component_name|signal_name}> :
{entity|component|signal} is “{auto|yes|no}”;

// Verilog syntax
(* use_dsp48 = “{auto|yes|no}” *)
// 上述约束会作用于紧随其后调用的实体、模块或信号
从上述语法可以看出,use_dsp48约束具有三个属性值,分别为:auto——由编译器自动调配;yes——使用DSP48资源;no——不使用DSP48资源。
当我们想利用DSP48资源来实现一个高性能的无符号16bits乘16bits乘法器的时候,如果事先知道了use_dsp48这个约束语法,就可以不用通过调用IP核这样一个繁琐的步骤来完成,例如:

-- VHDL example
signal MulA, MulB : std_logic_vector(15 downto 0);
signal Product : std_logic_vector(31 downto 0); 
attribute use_dsp48: string;
attribute use_dsp48 of Product : signal is "yes"; 
	……
	process (clk)
begin
		if (clk'event and clk = '1') then Product <= MulA * MulB;
		end if;
end process;

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
// Verilog example
reg [15:0] MulA, MulB
(* use_dsp48 = "yes" *)
	reg [31:0] Product;
	……
always@(posedge clk)
begin
	Product <= MulA * MulB;
end

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

mult_style

mult_style是描述乘法器的另一个综合约束。它通常是以DSP资源的约束一起作用的,若use_dsp48约束的属性值为yes或auto时,我们可以使用mult_style的pipe_block属性值来搭建需要多个DSP48资源才能实现的乘法器;若use_dsp48约束的属性值为no时,那我们就只能使用mult_style的pipe_lut、KCM、CSD这些属性值,来表明使用查找表实现乘法器时的风格。
下面列举出在HDL中嵌入mult_style约束的语法:
– VHDL syntax
– 第一步,先要声明mult_style约束;

attribute mult_style : string; 

  
 
  • 1

– 第二步,为mult_style语法指定约束线网名称和属性取值;

attribute mult_style of <{signal_name|entity_name}: {signal|entity}> is
"{auto|block|pipe_block|kcm|csd|lut|pipe_lut}";

  
 
  • 1
  • 2
// Verilog syntax
(* mult_style = "{auto|block|pipe_block|kcm|csd|lut|pipe_lut}" *)

  
 
  • 1
  • 2

// 上述约束会作用于紧随其后调用的实体、模块或信号

文章来源: reborn.blog.csdn.net,作者:李锐博恩,版权归原作者所有,如需转载,请联系作者。

原文链接:reborn.blog.csdn.net/article/details/105020677

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。