在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2007|回复: 0

[求助] 求助verilog代码

[复制链接]
发表于 2017-5-9 10:23:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
在夏宇闻老师的verilog经典教程里有一个可综合的RISC CPU代码,testbench里有一段我看不懂,谁能给我讲讲是什么意思?标成粗体的那段。
`timescale 1 ns / 1 ns

`define PERIOD 100
module cputop;
reg reset_req,clock;
integer test;
reg [(2*8):0] mnemonic;
reg [12:0] PC_addr,IR_addr;
wire [7:0] data;
wire [12:0] addr;
wire rd,wr,halt,ram_sel,rom_sel;
wire [2:0] opcode;
wire fetch;
wire [12:0] ir_addr,pc_addr;

//--------------ccpuÄ£¿éóêμØÖ·òëÂëÆ÷oírom£¬ramμÄá¬Ïß2¿·Ö--------
cpu t_cpu(.clk(clock),.reset(reset_req),.halt(halt),.rd(rd),
                      .wr(wr),.addr(addr),.data(data),.opcode(opcode),.fetch(fetch),

.ir_addr(ir_addr),.pc_addr(pc_addr));
ram t_ram(.addr(addr[9:0]),.read(rd),.write(wr),.ena(ram_sel),.data(data));

rom t_rom(.addr(addr),.read(rd),.ena(rom_sel),.data(data));

addr_decode t_addr_decode(.addr(addr),.ram_sel(ram_sel),.rom_sel(rom_sel));

//-------------------------cpuÄ£¿éóêμØÖ·òëÂëÆ÷oírom£¬ramμÄᬽó2¿·Ö½áêø------------------------------
initial
begin
clock = 1;
sys_reset;
test1;
$stop;
test2;
$stop;
test3;
$finish;
end


task test1;
begin
test = 0;
disable MONITOR;
$readmemb("test11.dat",t_rom.memory);
$readmemb("test1.dat",t_ram.ram);
# 1 test = 1;
# 14800 ;
sys_reset;
end
endtask


task test2;
begin
test = 0;
disable MONITOR;
$readmemb("test22.dat",t_rom.memory);
$readmemb("test2.dat",t_ram.ram);
# 1 test = 2;
# 11600 ;
sys_reset;
end
endtask


task test3;
begin
test = 0;
disable MONITOR;
$readmemb("test33.dat",t_rom.memory);
$readmemb("test3.dat",t_ram.ram);
# 1 test = 3;
# 94000 ;
sys_reset;
end
endtask

task sys_reset;
begin

reset_req = 0;
#(`PERIOD*0.7) reset_req = 1;
#(1.5*`PERIOD) reset_req =0;
end
endtask


always@(test)
begin:MONITOR
case(test)
1:begin
while (test == 1)
@(t_cpu.pc_addr)
if((t_cpu.pc_addr%2 == 1)&&(t_cpu.fetch == 1))
begin
# 60 PC_addr <= t_cpu.pc_addr-1;
IR_addr <=t_cpu.ir_addr;
# 340  $strobe ("%t  %h   %s   %h  %h",$time ,PC_addr,mnemonic,IR_addr,data);
end
end

2:begin
while (test == 2)
@(t_cpu.pc_addr)
if((t_cpu.pc_addr%2 == 1)&&(t_cpu.fetch == 1))
begin
# 60 PC_addr <= t_cpu.pc_addr-1;
IR_addr <=t_cpu.ir_addr;
# 340  $strobe ("%t  %h   %s   %h  %h",$time ,PC_addr,mnemonic,IR_addr,data);
end
end


3:begin
while (test == 3)
begin
wait(t_cpu.opcode == 3'h1)
$strobe ("%t   %d",$time,t_ram.ram[10'h2]);
wait(t_cpu.opcode != 3'h1);
end
end
endcase

end



//===================================
always #(`PERIOD/2) clock = ~clock;
always @(t_cpu.opcode)
case(t_cpu.opcode)
3'b000:mnemonic ="HLT";
3'H1  :mnemonic= "SKZ";
3'h2  :mnemonic= "ADD";
3'h3  :mnemonic = "AND";
3'h4  :mnemonic = "XOR";
3'h5  :mnemonic ="LDA";
3'h6  :mnemonic = "STO";
3'h7  :mnemonic = "JMP";
default:mnemonic = "???";
endcase
endmodule
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条

X

小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-7-5 18:23 , Processed in 0.012779 second(s), 8 queries , Gzip On, MemCached On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表