书接上回:
从零开始搭建UVM平台(一)-只有uvm_driver的验证平台
从零开始搭建UVM平台(五)-加入transaction机制
从零开始搭建UVM平台(九)-加入reference model
加入field automation机制
前面我们在对transaction操作的过程中,自己定义了display/copy/compare函数,但是uvm机制中实现了field automation机制来帮助我们实现了一套print/copy/compare等函数的代码,这样只需要调用即可,帮我们节省了很多的代码量。
第一步:在transaction里用宏实现field automation机制并去掉自己定义的display/copy/compare函数
注意这里pload是动态数组,所以要用`uvm_field_array_int
第二步:去掉环境里手动调用display/copy/compare函数,直接调用field automation机制提供的函数
打印结果:
红框部分内容就是调用field automation机制提供的print函数打印出的内容格式。
第三步:field automation机制不仅提供了print/copy/compare函数,还提供了pack_bytes()和unpack_bytes()函数,这给driver和monitor节省了很多代码量。
注意:这里pack_bytes的输入参数是一个类型为byte unsigned的动态数组,这个动态数组是打包后的tr要存储的动态数组,返回数据类型是int,表示的是tr的bit流长度。
Unpack_bytes函数的输入参数和输出参数含义和pack_bytes一样。