vivado学习——仿真
Verilog的代码编写完成了,代码是否正确,需要经过仿真的验证。
打开FreDivDou的工程,
data:image/s3,"s3://crabby-images/0e100/0e10009e4897f36044de280ba960a6fe31c22c81" alt=""
点击Sources中的“+”,
data:image/s3,"s3://crabby-images/7e6af/7e6afac438e5a12063628ca0681914a7d2389643" alt=""
选择添加仿真文件,点击“Next”,
data:image/s3,"s3://crabby-images/dcff7/dcff73a65e3de92ed6cdf3030528726b61a1afb1" alt=""
点击“Create File”,
data:image/s3,"s3://crabby-images/e5802/e58023b2a0d76f491e0ab1f447459979591767ca" alt=""
File Type选择Verilog,File name填写仿真文件名称,点击OK,
data:image/s3,"s3://crabby-images/1eb05/1eb05c8eb6dae4170d3fec5c9123957f8bc77840" alt=""
点击Finish,
data:image/s3,"s3://crabby-images/5c569/5c569ec03bc9a671bd7c078a3cad3d1fa7f9133e" alt=""
点击OK,
data:image/s3,"s3://crabby-images/b087e/b087e497d746f7759956b6d7de92fd1170fb2897" alt=""
点击Yes,
data:image/s3,"s3://crabby-images/fe13c/fe13c8512fb256fb566dbce5ce216ab10a2ba0b5" alt=""
成了仿真文件tb_Fre.v,双击tb_Fre(tb_Fre.v),
data:image/s3,"s3://crabby-images/f3332/f3332b76021b71b291757a6a729ea6fdbd8f4e84" alt=""
在tb_Fre.v中编写仿真代码,
moduletb_Fre(
);
reg clk_i;
reg rst_n_i;
wire div2_o;
wire div3_o;
wire div4_o;
wire dou2_o;
wire dou3_o;
FreDivDouttb( //调用FreDivDou.v
.clk_i(clk_i), //.后面的clk_i是FreDivDou.v中的端口名称,括号内的clk_i是仿
//真文件tb_Fre.v中定义的变量名称
.rst_n_i(rst_n_i),
.div2_o(div2_o),
.div3_o(div3_o),
.div4_o(div4_o),
.dou2_o(dou2_o),
.dou3_o(dou3_o)
);
//initial块从仿真0时刻开始执行,在整个仿真过程中只执行一次
initial begin
clk_i = 0;
rst_n_i = 0;
#1000;
rst_n_i = 'b1;
end
//产生一个周期为20ns的时钟
always #10 clk_i = ~clk_i;
endmodule
仿真代码编写完成后,保存该文件,
data:image/s3,"s3://crabby-images/f8e93/f8e9361eec333323a20e4cc4a9f7fe99e67439b5" alt=""
点击PROJECT MANAGER——SIMULATION——Run Simulation,
data:image/s3,"s3://crabby-images/d8a3c/d8a3c7fe9546e99c143eb63cf1b5dc41970deba8" alt=""
点击Run Behavior Simulation,
data:image/s3,"s3://crabby-images/7ded1/7ded1e54a66f116ff33c80fc819cecc7f1a3104e" alt=""
等待若干秒钟,
data:image/s3,"s3://crabby-images/7c598/7c5982481d8dd93c03364febdc72b3cf14ba9a7d" alt=""
点击仿真界面的最大化按钮,如上图所示,
data:image/s3,"s3://crabby-images/f67fb/f67fbcb5a30604b512779df3a3bde3647972c669" alt=""
点击上图中的Run All按钮,开始仿真,
data:image/s3,"s3://crabby-images/cabc3/cabc3eee772a6950774dcbefc0a130b18472a648" alt=""
数一数,你就会发现,假定clk_i是50M时钟,那么div2_o的时钟是50M/2=25M;div3_o的时钟是50M/3=16.67M;div4_o的时钟是50M/4=12.5M;dout2_o的时钟是50M*2=100M;dout3_o的时钟是50M*3=150M。