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进行处理;


浙公网安备 33010602011771号