码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 极简UVM RAL示例(PART2--通过rsp返回给regmodel)


    为了让RAL使用rsp来返回read结果,做如下修改。

    变化点1:driver

    相对于part1,driver改用put_response(rsp)

    代码

    class driver extends uvm_driver #(reg_tr);
    virtual reg_if drv_if;
    `uvm_component_utils(driver)
    function new(string name=“”,uvm_component parent=null);
    super.new(name,parent);
    endfunction
    extern virtual function void build_phase(uvm_phase phase);
    extern task main_phase(uvm_phase phase);
    endclass

    function void driver::build_phase(uvm_phase phase);
    super.build_phase(phase);
    uvm_config_db#(virtual reg_if)::get(this,“”,“drv_if”,drv_if);

    endfunction

    task driver::main_phase(uvm_phase phase);
    drv_if.wr <= 1’b0;
    drv_if.rd <= 1’b0;
    drv_if.din <= 0;
    drv_if.addr <= 0;
    @(posedge drv_if.rstn);
    while(1) begin
    seq_item_port.get_next_item(req);
    rsp = new(“rsp”);
    rsp.set_id_info(req);
    rsp.wr = req.wr;
    rsp.rd = req.rd;
    rsp.addr = req.addr;
    rsp.din = req.din;
    //drive access
    @(drv_if.cb);
    drv_if.addr <= req.addr;
    if(req.wr) begin
    drv_if.wr <= 1’b1;
    drv_if.din <= req.din;
    @(drv_if.cb);
    drv_if.wr <= 1’b0;
    end
    if(req.rd) begin
    drv_if.rd <= 1’b1;
    @(drv_if.cb);
    rsp.dout <= drv_if.dout;
    drv_if.rd <= 1’b0;
    end
    @(drv_if.cb);
    seq_item_port.put_response(rsp);
    seq_item_port.item_done();
    end
    endtask

    变化点2: class tests

    相对于part1,tests 增加配置provides_responses = 1’b1;

    代码

    adp = new("adp");
    adp.provides_responses = 1'b1;
    
    • 1
    • 2
  • 相关阅读:
    Allatori工具混淆jar包class
    第63天:服务攻防-框架安全&CVE 复现&Django&Flask&Node.JS&JQuery
    选错毕业第一份工作,我白干半年
    【图像分类损失】PolyLoss:一个优于 Cross-entropy loss和Focal loss的分类损失
    中英文双语言海外微盘交易源码 微盘交易源码 虚拟币微盘交易系统源码 支持产品数据
    HDR和泛光
    2024年CSP-J暑假冲刺训练营(1):枚举
    时间复杂度和空间复杂度
    RocketMQ 延迟消息解析——图解、源码级解析
    BuyVM 拉斯维加斯 VPS 测评
  • 原文地址:https://blog.csdn.net/zt5169/article/details/126561474
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号