uvm 监控方法 & run_phase
uvm monitor methodology & run_phase
我想知道我是否对监视器 run_phase 任务的 uvm 方法有误解。 DUT 发出多个时钟,其中包含监视器正在观察和检查的数据,使不同的时钟域保持分离。所以我的 运行 阶段任务看起来像
forever begin
fork
begin @(posedge clk1) begin
..code to capture data..
end end
begin @(posedge clk2) begin
..code to capture data in this domain...
end end
join_any
disable fork;
我的 'problem' 如果 clk1 和 clk2 对齐,则只会执行一个 posedge 语句。此外,如果我希望我的监视器在第三个异步域上执行一些其他操作,比如 clk1 或 clk2 的倍数,那么当第三个域与 clk1 或 clk2 对齐时就会出现问题。
监视器如何在其 运行 相位永远循环中在多个时钟域中工作?
通常在监视两个不同的时钟域时,它们被保持为单独的永远循环线程。可能存在您想有条件地禁用其他时钟域的情况,但我怀疑这是您的意图。
fork
forever @(posedge clk1) begin
..code to capture data..
end
forever @(posedge clk2) begin
..code to capture data in this domain...
end
join // or join_none
我想知道我是否对监视器 run_phase 任务的 uvm 方法有误解。 DUT 发出多个时钟,其中包含监视器正在观察和检查的数据,使不同的时钟域保持分离。所以我的 运行 阶段任务看起来像
forever begin
fork
begin @(posedge clk1) begin
..code to capture data..
end end
begin @(posedge clk2) begin
..code to capture data in this domain...
end end
join_any
disable fork;
我的 'problem' 如果 clk1 和 clk2 对齐,则只会执行一个 posedge 语句。此外,如果我希望我的监视器在第三个异步域上执行一些其他操作,比如 clk1 或 clk2 的倍数,那么当第三个域与 clk1 或 clk2 对齐时就会出现问题。
监视器如何在其 运行 相位永远循环中在多个时钟域中工作?
通常在监视两个不同的时钟域时,它们被保持为单独的永远循环线程。可能存在您想有条件地禁用其他时钟域的情况,但我怀疑这是您的意图。
fork
forever @(posedge clk1) begin
..code to capture data..
end
forever @(posedge clk2) begin
..code to capture data in this domain...
end
join // or join_none