RTL代码分析思路(这里不进行具体代码的分析)
verilog文件是以.v结尾的
1 RTL代码示例
//Date : 2023-01-09
//E-mail : xxxxxx@163.com
//copyright : xxxx
//-------------------------------------------------------------------------------
//module header may includes:
//module name,port,direction,port width and port types
module AndOr {
output X,Y,
input A,B,C
};
assign #10 X = A & B;
assign #10 Y = B | C;
endmodule
- RTL中有内建的and or 一般写& |
2 使用Makefile进行仿真
Makefile是一个脚本,简单理解为将仿真使用的命令放到脚本中,方便执行
all:compile simulate
compile:
vcs -sverilog -debug_all -timescale=1np/1ps full_adder.v full_adder_tb.v -l com.lg
simulate:
.simv -l sim.log
clean:
@rm -rf csrc DVEfiles simv simv.daidir ucli.key VCS*
@rm -rf *.log *.vpd *.svf *.SDF *Synth *Netlist*
@rm -rf alib-52
make all就会执行all下面的complie和simulate
生成sim.og文件
使用 dve查看波形文件
// & 后台运行dve
dve &
设计人员也需要会部分验证
使用tcl脚本进行逻辑综合
1 tcl脚本的方式进行逻辑综合
//在linux中使用脚本进行综合
dc_shell -f xxx.tcl
//自动调用design compiler进行综合
- 延时信息--#5 是不可综合的
2 使用GUI界面方式进行逻辑综合
//调出design compiler的界面工具
design_vision &
详细的过程不在这里进行详细叙述
通过逻辑综合可以看到RTL变成的具体电路