uvm中的field_automation主要实现了class中的基础元素的copy,compare等函数,

    实现方式分为两种:1)用户注册,field系列宏;uvm内部调用static status container中的function;

                2)用户自己实现do_copy,do_print等函数,调用static printer内的函数;

      

uvm_object中实现了print,sprint等函数,实现调度接口,调度status_container和do_function;

            status_container中的function在进行filed注册的时候,被实现出来;

            do_print等函数,留下对用户的hook;

            不调用filed macros的class,需要在自己内部实现;

这样所有的extend的class,都包含这些general的一些function;

comparer等class中具体实现了针对不同类型的filed的操作;int,string,object,time等;

status_container,在object内部是一个static变量,内部包含comparer,printer等class的变量,所以可以在prj 任何class调用;

          从而可以在用户进行filed macros register的时候,实现filed function;

总之,print等函数,实现都在相应的printer实现,但是调用分为了两种,用户自己实现do_function,或者调用field macros;

printer的实现:

    内部实现了cfg与function的颗粒度分解,knobs中定义了很多打印选型,mcd表示打印输出STDOUT等;

                                     object depths,是否打印所有的children,默认都是打开的;

                                     object callback,打印object之前对header或者footer调用自定义函数;

                                     type_name,prefix,field_size,决定是否打印这些附加信息;

                      function中,定义了各个类型的print实现;      

        

knobs并没有被extend,printer被extend了三个,基本的print function不变,只是更新了omit函数,规定了自己的格式;

    默认的printer,为table_printer,在uvm内部被显示的new之后,typedef为default printer;

    三种printer,之间可以相互重载,单独封装,相互替代,这种在设计模式中,也被称为strategy,或policy;

一个最重要的变量:

    1)uvm_printer_row_info  m_rows[$],结构体类型,内部包含:level,name,type_name,size,value信息;

      每次调用各个print_int等函数,都会将信息,push_back到该queue中;

一个最重要的function:

    2)emit函数,返回值string,首先打印格式,其次遍历m_row,更新自己的返回值

      被uvm_object的print函数调用;

comparer的实现:

    comparer更加简单一些,config的变量更少,所以直接做在一个class中,比较之后,主要需要选择性打印信息;

    config:policy,默认都是default的,reference,表示只比较指针;

                     uvm_deep,表示uvm的deep_copy的方式进行比较;

                     uvm_shallow,表示sv默认的copy方式进行比较,class内的class直接copy指针;

         show_max,verbosity,severity,表示report时的配置;默认使用uvm_root的report调用;

         check_type,在compare object的时候,来表示是否要比较object的类型,还是只需要值相同,默认打开;

      

record和pack不在描述;

copy更加简单,没有相应的控制器来实现,直接调用field_automation和do_copy函数;

    field_automation实现时,会区分UVM_COPY和UVM_REFERENCE,reference,直接指针赋值;

                                     no_reference,进行clone操作;

        其中的clone函数,调用的是create函数,做创建;所有的object都必须重载该函数;

还有set_xx_local的操作,可以直接调用相应函数,set local var的值;函数定义在uvm_object,调用在field_automation;

相应的macros:

    uvm_field_utils_begin(T):function __M_uvm_field_automation的定义;

    uvm_field_utils_end:endfunction __m_uvm_field_automation的结束定义;

    uvm_field_xx_xx(ARG,FLAG):根据uvm_action,定义case...endcase来实现copy,print,compare等函数,调用相应comparer等;

  uvm automation的action包括:

      

应用:在class中不做field的宏调用,显示定义自己的do_function:

      

uvm设计分析——field automation的更多相关文章

  1. uvm设计分析——reg

    项目中的reg_model一般只有一份,set到reg_sequence上,所以多个sequence并行启动结束的时候,reg model会成为一个共享资源. uvm_reg_field中的volat ...

  2. uvm设计分析——factory

    uvm的factory机制,通过实例一个static类型default factory,并且通过宏将所有例化extend出来的object,component register到该factory的内部 ...

  3. uvm设计分析——tlm

    tlm模块,用来在不同模块之间实现实时通信,主要基于两个定义在通信双方的port类来实现. 两个port之间,通过connect函数,来拿到双方的class指针,进而调用对方的function. 但是 ...

  4. uvm设计分析——callback

    uvm_callback,设计者在进行class的function设计时,有意留下的一些hook,总是遍历某个pool中的对象: 使用者在使用时,将实现添加到某个pool中: callback中,最重 ...

  5. uvm设计分析——report

    uvm_report实现中的类图,如下: 1)uvm_component均从uvm_report_object extend而来,其中定义了report_warning,error,info,fata ...

  6. (转)UVM挑战及概述

    UVM的调度也具有其独特的挑战,尤其是在调试的领域.其中的一些挑战如下: 1. Phase的管理:objections and synchronization 2. 线程调试 3. Tracing i ...

  7. UVM挑战及概述

    UVM的调度也具有其独特的挑战,尤其是在调试的领域.其中的一些挑战如下: 1. Phase的管理:objections and synchronization 2. 线程调试 3. Tracing i ...

  8. (转)UVM内容梗概

    1. 类: 面向对象基础传统的面向对象编程与systemverilog类的特点,类的定义,成员与方法,构造函数,对象的复制和深/浅拷贝,父类/子类关系,类的继承,作用域的规则,对象的句柄以及赋值,方法 ...

  9. 深入浅出Automation Anywhere

    Automation Anywhere是基于CLIENT-SERVER架构(control room和客户端),客户端主要是Bot Creator 和 BotRunner 主要构成: 1.WEBCR: ...

随机推荐

  1. html select控件的jq操作

    html select控件的jq操作 1.判断select选项中 是否存在Value="paraValue"的Item $("#selectid option[@valu ...

  2. Altium Designer 绘图流程及快捷键

    1.Shift+Ctrl+g 设置栅格捕捉大小 2.Q 切换单位 3.E+N +点击字体 改变字体大小 4.自动布线前需在Mechanical 层和keepout层添加一个边框 5.打过孔实现双面走线 ...

  3. 完整OSW安装方法

    完整OSW安装方法(如果数据库是rac,一定要记得第5步,要不收集不到私网的信息): OSW介质见附件 1.上传介质到 /home/oracle 2.oracle用户将压缩包解压到归档arch目录下( ...

  4. 虚拟机VirtualBox与CentOS 7安装

    一.VirtualBox 我们电脑的操作系统一般都是Windows,如果我们要学习Linux,那么可以在我们的电脑上装个虚拟机,然后在这虚拟机上安装Linux.虚拟机可以用VirtualBox 或者 ...

  5. 那些年读过的书《Java并发编程的艺术》一、并发编程的挑战和并发机制的底层实现原理

    一.并发编程的挑战 1.上下文切换 (1)上下文切换的问题 在处理器上提供了强大的并行性就使得程序的并发成为了可能.处理器通过给不同的线程分配不同的时间片以实现线程执行的自动调度和切换,实现了程序并行 ...

  6. Matlab中导入文本文件中的数据 矩阵合并 以及C++中删除文件操作

    今天用到了Matlab读取文本文件中按照一定格式存储好的数据,然后进行后续的分析计算等,因此涉及到Matlab的文件读取,记录在这里,供以后查阅: fid = fopen('train.set', ' ...

  7. javascript面向对象中继承实现?

    面向对象的基本特征有:封闭.继承.多态. 在javascript中实现继承的方法: 1.原型链(prototype chaining) 2.call()/apply() 3.混合方式(prototyp ...

  8. php 7 新特性整理小结

    php 7 比php 5 性能提升了很多,php 7 新特性主要表现在:1.变量存储字节减小,减少内存占用,提升变量操作速度:2.改善数组结构,数组元素和hash映射表被分配在同一块内存里,降低了内存 ...

  9. mysql批量插入数据

    建表 create table `dept`( `id` ) unsigned NOT NULL AUTO_INCREMENT, `deptno` mediumint() unsigned ', `d ...

  10. vue中computed和watch的用法

    computed用来监控自己定义的变量,该变量不在data里面声明,直接在computed里面定义,然后就可以在页面上进行双向数据绑定展示出结果或者用作其他处理: computed比较适合对多个变量或 ...