designware IP如何被FPGA综合

DW的IP要被vivado等综合还是很麻烦的,而是用synplify等综合工具,然后再嫁接到vivado中也非常麻烦。本文提供一种解决办法。

  1. 对DW的IP进行gtech综合。即使用DC工具对DW IP进行综合。而使用的综合库是gtech。脚本如下:
bash 复制代码
set target_library "gtech.db"
set synthetic_library "dw_foundation.sldb"
set link_library " *  $target_library  $synthetic_library "
analyze -format sverilog -vcs "-sverilog -f ***" > analyze.log
elaborate *_module > elaborate.log
current_design xxx
link
compile
write_file -f verilog -hier -o design_gtech_netlist.v

生成完的design_gtech_netlist.v为一堆使用gtech的网表:

  1. 编写一个gtech.v,对上述网表中的每一个门电路都进行描述,例如:
bash 复制代码
module GTECH_ADD_ABC(A,B,C,S,COUT);
input	A,B,C;
output	S,COUT;
assign S=A^B^C;
assign COUT=A&B|A&C|B&C;
endmodule

由于gtech的种类不是很多,所以一开始描述会麻烦点。但随着时间的推移。很快就会形成一个完整gtech.v的库。

  1. 然后将design_gtech_netlist.v和gtech.v一同引用至vivado中,即可完成综合。

  2. 对于参数化IP,可以根据不同参数分别gtech综合。然后在实际引用IP的代码中,用下面的方式进行fpga和流片版本的区分:

bash 复制代码
`ifdef FPGA_SIM
DW02_mac_12x12
`else
DW02_mac #(A_BW, B_BW)
`endif
u_mac (.A(a), .B(b), .C(c), .TC(1'b1), .MAC(mac) );

DW02_mac_12x12是gtech综合后的版本。

相关推荐
9527华安18 小时前
紫光同创FPGA实现AD7606数据采集转UDP网络传输,提供PDS工程源码和技术支持和QT上位机
网络·qt·fpga开发·udp·紫光同创·ad7606
szxinmai主板定制专家19 小时前
基于TI AM6442+FPGA解决方案,支持6网口,4路CAN,8个串口
arm开发·人工智能·fpga开发
7yewh19 小时前
FPGA前瞻篇-计数器设计与实现实例
arm开发·驱动开发·嵌入式硬件·fpga开发·硬件架构·硬件工程·精益工程
爱学习的张哥21 小时前
UDP--DDR--SFP,FPGA实现之指令监测模块实现
fpga开发·udp·指令
碎碎思1 天前
FPGA+ESP32 = GameBoy 是你的童年吗?
fpga开发
搬砖的小码农_Sky1 天前
FPGA:XILINX FPGA产品线以及器件选型建议
嵌入式硬件·fpga开发·硬件架构·硬件工程
YprgDay1 天前
【Lattice FPGA 开发】Diamond在线调试Reveal逻辑乱跳的解决
fpga开发·diamond·reveal
MVP-curry-萌神1 天前
FPGA图像处理(六)------ 图像腐蚀and图像膨胀
图像处理·人工智能·fpga开发
&Cheems1 天前
ZYNQ笔记(二十):Clocking Wizard 动态配置
笔记·fpga开发
怪小庄吖1 天前
7系列 之 I/O标准和终端技术
经验分享·笔记·fpga开发·硬件架构·硬件工程·xilinx 7系列 fpga·i/o标准和终端技术