我遇到了一个问题,即我的模拟中的缓冲区无法按预期工作。我尝试了一些测试并得到了以下结果。我在 Verilog 中创建了以不同方式生成两个缓冲区的代码:
module buffer(
input wire clk,
input wire ena,
output wire buffer,
output wire buffer2
);
reg buffer_reg = 1'b0;
reg buffer_next = 1'b0;
reg buffer2_reg = 1'b0;
assign buffer = buffer_reg;
assign buffer2 = buffer2_reg;
always @(*) begin
buffer_next = ena;
end
always @(posedge clk) begin
buffer_reg <= buffer_next;
buffer2_reg <= ena;
end
endmodule
然后我使用以下测试台在 Modelsim 中对其进行模拟:
`timescale 1ns / 1ns
module buffer_tb();
localparam CLK_CYCLE = 8;
reg clk;
reg ena;
wire buffer;
wire buffer2;
buffer dut(
.clk(clk),
.ena(ena),
.buffer(buffer),
.buffer2(buffer2)
);
// Clock generation
initial begin
clk = 1'b0;
end
always #(CLK_CYCLE/2) clk = ~clk;
// Test sequence
initial begin
// Initialize signals
ena = 0;
// change ena values based on the posedge clk
@(posedge clk) ena = 1;
@(posedge clk) ena = 0;
repeat(5) @(posedge clk);
@(posedge clk) ena = 1;
@(posedge clk) ena = 0;
repeat(2) #CLK_CYCLE;
// change ena values based on the CLK_CYCLE
#(CLK_CYCLE) ena = 1;
#CLK_CYCLE ena = 0;
repeat(5) #CLK_CYCLE;
#CLK_CYCLE ena = 1;
#CLK_CYCLE ena = 0;
// Allow simulation to run for a while
#50 $stop; // Stop simulation
end
endmodule
我在模拟中得到了以下结果:
有人能解释一下为什么buffer2
当我使用posedge clk
和使用时会得到不同的结果吗CLK_CYCLE
?
该问题是由于测试台代码中的 Verilog 模拟竞争条件造成的。
buffer
如果您想要模拟同步行为,则需要以与驱动设计中的信号相同的方式来驱动设计输入信号,即:@(posedge clk)
<=
)更改测试平台代码: