优化UVM环境(一)-环境结束靠的是timeout,而不是正常的objection结束

书接上回:

从零开始搭建UVM平台系列

前面搭建的UVM平台已经是一个较为完整的平台,但是环境要想有通用性,还有很多需要优化的地方。

优化一:环境结束优化

问题:现在环境结束靠的是timeout机制,而不是正常的objection结束

原因:driver/monitor里用的是while(1)循环,没有办法正常跳出

解决办法:参考apb_driver。在run_phase或者main_phase里用fork...join_none起两个线程,一个是while(1)无限循环线程,另一个是objection更新线程。

以driver为例,while(1)无限循环线程就负责不断驱动数据;objection更新线程的职责就是:当看到while(1)循环里有数据要驱动时,就raise一个objection,当看到while(1)循环里的数据驱动完成时,就drop这个objection。

需要注意的是,这里update_objection里的objecction个数判断是1个,所以在main_phase里线程1/2之外的代码范围不要再raise/drop_objection了,否则个数会大于1,导致这套机制不会生效,仿真还是会走到timeout才结束。

同理,对scoreboard、model也可以做同样的修改。

相关推荐
编程社区管理员9 小时前
React 发送短信验证码和验证码校验功能组件
前端·javascript·react.js
全马必破三9 小时前
React“组件即函数”
前端·javascript·react.js
三思而后行,慎承诺9 小时前
React 底层原理
前端·react.js·前端框架
座山雕~9 小时前
html 和css基础常用的标签和样式
前端·css·html
灰小猿10 小时前
Spring前后端分离项目时间格式转换问题全局配置解决
java·前端·后端·spring·spring cloud
im_AMBER10 小时前
React 16
前端·笔记·学习·react.js·前端框架
02苏_10 小时前
ES6模板字符串
前端·ecmascript·es6
excel10 小时前
⚙️ 一次性警告机制的实现:warnOnce 源码深度解析
前端
excel10 小时前
Vue SFC 样式编译核心机制详解:compileStyle 与 PostCSS 管线设计
前端
excel10 小时前
🧩 使用 Babel + MagicString 实现动态重写 export default 的通用方案
前端