朝阳市网站建设_网站建设公司_导航易用性_seo优化
2025/12/24 4:03:48 网站建设 项目流程

文章目录

  • 原始代码及log
  • 📌 UVM-TLM1最小可运行示例:APB读-改-写流程概述
    • 🧩 核心组件与角色定位
    • 🧠 代码级深度解析
      • 1. APB事务对象:`apb_rw.sv`(封装操作细节)
      • 2. TLM发起方:`initiator.sv`(发起读改写)
      • 3. TLM目标方:`target.sv`(响应读写请求)
      • 4. 测试环境:`tb_env.sv`(组件连接)
    • 🚀 执行流程与数据变化
      • 序列图展示
      • 步骤说明
    • 🔑 关键概念速览
    • ⚠️ 潜在问题与改进建议
    • 📝 课后思考与答案
    • 🌟 IC验证场景扩展:集成寄存器模型
      • 1. 寄存器类与寄存器块
      • 2. APB→寄存器适配器
      • 3. 环境中集成寄存器模型
      • 4. 测试用例:前门访问寄存器
    • ✅ 总结

原始代码及log

classapb_rwextends uvm_sequence_item;typedefenum{READ,WRITE}kind_e;rand bit[31:0]addr;rand logic[31:0]data;rand kind_e kind;`uvm_object_utils_begin(apb_rw)`uvm_field_int(addr,UVM_ALL_ON|UVM_NOPACK);`uvm_field_int(data,UVM_ALL_ON|UVM_NOPACK);`uvm_field_enum(kind_e,kind,UVM_ALL_ON|UVM_NOPACK);`uvm_object_utils_end functionnew(string name="apb_rw");super.new(name);endfunction function stringconvert2string();return$sformatf("kind=%s addr=%0h data=%0h",kind,addr,data);endfunction endclass:apb_rwclassinitiatorextends uvm_component;uvm_tlm_b_initiator_socket#(apb_rw)sock;`uvm_component_utils(initiator)functionnew(string name="initiator",uvm_component parent=null);super.new(name,parent);sock=new("sock",this);endfunction//// Execute a simple read-modify-write//virtualtaskrun_phase(uvm_phase phase);apb_rw rw;uvm_tlm_time delay=new;phase.raise_objection(this);rw=apb_rw::type_id::create("rw",,get_full_name());rw.kind=apb_rw::READ;rw.addr=32'h0000_FF00;sock.b_transport(rw,delay);// Ok to reuse the same RW instancerw.kind=apb_rw::WRITE;rw.data=~rw.data;sock.b_transport(rw,delay);phase.drop_objection(this);endtask endclassclasstargetextends uvm_component;local bit[31:0]m_data;uvm_tlm_b_target_socket #(target,apb_rw)sock;`uvm_component_utils(target)functionnew(string name="target",uvm_component parent=null);super.new(name,parent);sock=new("sock",this);m_data=32'hDEADBEEF;endfunction taskb_transport(apb_rw rw,uvm_tlm_time delay);case(rw.addr)32'h0000_FF00:beginif(rw.kind==apb_rw::READ)rw.data=m_data;elsem_data=rw.data;end endcase #5;endtask functionvoidstart_of_simulation_phase(uvm_phase phase);`uvm_info("TRGT/RPT/START",$sformatf("m_data: 'h%h",m_data),UVM_NONE)endfunction functionvoidreport_phase(uvm_phase phase);`uvm_info("TRGT/RPT/FINAL",$sformatf("m_data: 'h%h",m_data),UVM_NONE)endfunction endclassclasstb_envextends uvm_component;`uvm_component_utils(tb_env)initiator master;target slave;functionnew(string name="tb_env",uvm_component parent=null);super.new(name,parent);endfunction functionvoidbuild_phase(uvm_phase phase);master=initiator::type_id::create("master",this);slave=target::type_id::create("slave",this);endfunction functionvoidconnect_phase(uvm_phase phase);master.sock.connect(slave.sock);endfunction endclass import uvm_pkg::*;`include"uvm_macros.svh"`include"apb_rw.sv"`include"initiator.sv"`include"target.sv"`include"tb_env.sv"program tb_run;initial beginstatictb_env env=new("env");run_test();end endprogram----------------------------------------------------------------**

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询