4.5使用rsp-response_handler与put_response(不使用get_response)

1.为什么需要response_handler?

(1) get_response与put_response一一对应.当在sequence中启动get_response时,进程会阻塞,一直到sequence的response_queue里放入新的记录.

(2) 如果driver能马上将response通过put_response的方式传回sequence, sequence被阻塞的进程就会得到释放,可以接着发送下一个transaction给driver.

(3) 如果driver需要延时较长的一段时间才能将transaction传回,同时driver又希望能够从sequence得到新的transaction并驱动它. 但由于sequence被阻塞,不能发出新的transaction.

出现这种情况的原因是sequence中发送transaction与get_response在同一进程中执行. 如果将二者分开,上述问题就可以解决.这种情况下,需要使用response_handler.

2.response_handler的使用

2.1 enable response handler功能

2.2重载虚函数response_handler

(1) 经过这样设置,在sequence的body task中,就可以不用使用get_response函数了; 这样,就不存在阻塞,每当driver put_response后,sequencer的put_response会调用response_handler函数进行处理;

(2) sequencer的put_response调用response_handler的相关code及简单说明;

(2.1) sequencer的put_response函数先根据rsp的sequence_id找到对应的seq并检查其是否例化;

(2.2) sequencer的put_response函数检查sequence是否enable response_handler功能,如果enable,则调用sequence的response_handler函数对rsp进行处理;

 

 

 

posted on 2021-10-17 11:34  知北游。。  阅读(492)  评论(0)    收藏  举报

导航