UVM中uvm_sequence的方法总结

类声明

virtual class uvm_sequence #(
  type REQ = uvm_sequence_item,
  type RSP = REQ
) extends uvm_sequence_base

变量

变量 说明
rsp 此sequence包含被称为rsp请求类型的字段
req 此sequence包含被称为req响应类型的字段

方法

方法 说明
new 创建并初始化一个新的sequence对象
send_request 这个方法将sequence item发送给sequencer,sequencer将把它转发给driver。
get_current_item 返回当前被sequencer执行的request item。
get_response 默认情况下,sequence必须通过调用get_response回收响应。

变量
req
REQ req
此sequence包含被称为req请求类型的字段。如果需要,用户可以使用这个字段或创建另外一个字段使用。默认的do_pirnt将打印这个字段。

rsp
RSP rsp
此sequence包含被称为响应类型的字段。如果需要,用户可以使用这个字段或创建另外一个字段使用。默认的do_print将打印这个字段。

方法
new
function new (string name = "uvm_sequence")
创建并初始化一个新的sequence对象。

send_request

function void send_request(
  uvm_sequence_item request,
  bit rerandomize = 0
)

这个方法将发送request item给sequencer, sequencer转发它给driver。如果设置了rerandomize位,此item将在被发送给driver之前随机化。 send_request函数只能在uvm_sequence_base::wait_for_grant返回后调用。

get_current_item
function REQ get_current_item()
返回当前被sequencer执行的request item。如果sequencer不是正在执行一个item,此方法将返回null。sequencer从调用get_next_item或peek的时间开始执行一个项,直到调用get或item_done的时间。注意,一个只调用get的driver将永远不会显示当前项,因为该项在被请求的同时被完成。

get_response

virtual task get_response(
  output RSP response,
  input int transaction_id = -1
)

默认情况下,sequence必须通过调用get_response来回收响应。如果没有指定transaction_id, 这个任务将返回发送给这个sequence的下一个响应。如果在响应队列中没有可以利用的响应,此方法将会阻塞,直到收到一个响应。
如果transaction_id参数被指定,此任务将会阻塞,直到在响应队列中这个transaction_id被收到。
响应队列默认大小是8。get_response方法必须尽快被调用,从而避免响应队列的溢出,防止响应被删除。
如果一个响应在响应队列中被删除,将会报告一个错误,除非错误报告通过set_response_queue_error_report_disabled禁用。

你可能感兴趣的:(UVM,uvm_sequence)