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综合后的版本。

相关推荐
tiantianuser2 小时前
RDMA设计15:连接管理模块设计2
网络协议·fpga开发·rdma·高速传输·cmac
民乐团扒谱机3 小时前
十字路口交通信号灯控制器设计(Multisim 电路 + Vivado 仿真)
单片机·fpga开发·verilog·状态机·仿真·时序逻辑·multism
乌恩大侠3 小时前
一文讲解 USRP X410
fpga开发·usrp
s09071366 小时前
多波束声呐 FPGA 信号处理链路介绍
算法·fpga开发·信号处理·声呐
坏孩子的诺亚方舟6 小时前
FPGA系统架构设计实践11_FPGA开机
fpga开发·系统架构·xilinx·fpga配置
晓晓暮雨潇潇1 天前
Diamond基础6:LatticeFPGA配置流程
fpga开发·diamond·lattice·latticeecp3
江蘇的蘇1 天前
基于7系列FPGA实现万兆网通信
fpga开发
GateWorld1 天前
FPGA实战:一段让我重新认识时序收敛的FPGA迁移之旅
fpga开发·实战经验·fpga时序收敛·建立保持时间
GateWorld1 天前
性能飞跃:DDR4特性解析与FPGA实战指南
fpga开发·信号完整性·ddr3·ddr4
第二层皮-合肥1 天前
50天学习FPGA第21天-verilog的时序与延迟
学习·fpga开发