news 2026/4/3 6:34:02

【验证技能树】UVM 源码解读11 -- TLM2 —— Blocking vs Non-blocking 背后的建模取舍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【验证技能树】UVM 源码解读11 -- TLM2 —— Blocking vs Non-blocking 背后的建模取舍

聚焦 RISC-V / CPU / SoC 验证实践。
所有结论,默认都——得验。


在 UVM 验证环境中,TLM2 经常被描述成一组接口:

  • b_transport

  • nb_transport_fw / bw

  • phase / timing annotation

很多工程实践里的真实情况是:

能用 blocking 就用 blocking,能不用 TLM2 就不用。

这并不完全错,但如果你读过 TLM2 的源码和设计背景,就会发现一个关键事实:

TLM2 的存在,几乎从来不是为了“让你多写几行代码”,而是为了让模型在复杂系统里“不会说谎”。


一、先说结论:Blocking vs Non-blocking 的本质区别

这不是“性能高低”的问题,也不是“复杂度”的问题,而是:

你到底在建模“功能”,还是在建模“时序与资源竞争”?

维度BlockingNon-blocking
抽象层级
时间表达粗粒度精细、分阶段
并发可见性
建模重点功能正确性系统级行为

如果你只记住一句话:

Blocking 是“结果导向”,Non-blocking 是“过程导向”。


二、为什么 Blocking 看起来这么“顺手”?

b_transport()为例:

task b_transport( uvm_tlm_generic_payload t, time delay );

它的语义非常直接:

  1. transaction 送进来

  2. 等模型“处理完”

  3. 返回结果 + 累加 delay

这非常符合工程师直觉,因为它隐含了一个假设:

目标模块在这个 transaction 上是“独占执行”的。

这在以下场景是完全合理的:

  • reference model

  • 抽象 memory model

  • 行为级外设

  • 单 master、无仲裁的通路

在这些场景下,用 non-blocking 反而是过度建模


三、Non-blocking 出现,是为了解决一个 Blocking 无法描述的问题

Blocking 模型有一个天然的盲点:

它无法描述“多个 transaction 在同一时刻,争抢同一资源”的过程。

比如:

  • 总线仲裁

  • pipeline 资源占用

  • out-of-order 返回

  • back-pressure

  • latency 不确定

这些问题的共同点是:

transaction 的生命周期是“分阶段”的。

而这,正是 TLM2 non-blocking 的核心动机。


四、从源码看:Non-blocking 不是“异步”,而是“状态机”

很多人误以为:

nb_transport = 异步 + 高性能

但从 TLM2 源码与规范来看,它真正表达的是:

一个 transaction 的状态演进过程。

典型的四阶段模型:

  1. BEGIN_REQ

  2. END_REQ

  3. BEGIN_RESP

  4. END_RESP

这本质上是:

把一个 blocking 调用,拆成一个显式状态机。

好处只有一个,但非常关键:

系统级并发行为变得“可被观察和建模”。


五、TLM2 的设计取舍:复杂度是刻意引入的

你会发现 TLM2:

  • API 很长

  • 状态很多

  • 返回值绕

  • timing annotation 难用

这不是设计失误,而是一个明确取舍

如果你要描述系统级行为,就必须付出复杂度。

否则,你得到的只是一个:

  • 跑得很快

  • 看起来对

  • 但在压力场景下完全失真的模型


六、为什么大多数验证环境“用不上” TLM2?

这是一个非常现实的问题。

原因并不是大家“水平不够”,而是:

大多数验证环境,本质目标并不是系统级建模。

在真实项目中:

  • DUT 已经给出了 cycle-accurate 行为

  • 验证环境主要用于 stimulus / check

  • timing 由 RTL 本身决定

在这种情况下:

  • Blocking 模型已经足够

  • Non-blocking 反而增加心智负担

所以“不用”是一个理性选择


七、什么时候你应该认真考虑 TLM2?

你可以用一个简单判断标准:

如果你需要验证“系统行为是否合理”,而不仅是“功能是否正确”,那就该考虑 TLM2。

典型场景包括:

  • NoC / interconnect 行为建模

  • cache / memory hierarchy reference model

  • SoC-level performance / contention 分析

  • 早期架构验证(pre-RTL / hybrid)

这些场景里,Blocking 模型会系统性地隐瞒问题


八、总结一句话

Blocking vs Non-blocking 的选择,本质上是“你想让模型诚实到什么程度”。

  • Blocking:

    “我只关心结果。”

  • Non-blocking:

    “我必须看清过程。”

UVM 并没有强迫你使用 TLM2,
它只是给你提供了一把在需要时不会失效的工具


写在最后

如果你把 TLM2 当成:

  • “高级写法”

  • “性能优化手段”

那它一定显得又重又烦。

但如果你站在:

系统建模 / 架构验证 / 并发行为可视化

这个高度再看,你会发现:

TLM2 是 UVM 里少数“为未来复杂度预留空间”的设计。

你现在这套「UVM 源码解读」系列,已经明显超过“使用手册”层级了。
这是在帮后来者节省三到五年的理解成本

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 1:59:02

Qwen2.5-7B避雷指南:解决CUDA版本冲突,云端0配置

Qwen2.5-7B避雷指南:解决CUDA版本冲突,云端0配置 引言 作为一名算法工程师,你是否遇到过这样的困境:本地环境已经配置了PyTorch 1.12用于现有项目,但新接触的Qwen2.5-7B大模型要求PyTorch 2.0?直接升级本…

作者头像 李华
网站建设 2026/4/2 5:25:12

1小时搞定:用快马快速验证烹饪APP创意

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 快速生成一个烹饪APP最小可行产品(MVP),包含:1) 3个核心功能页面 2) 基本的用户交互流程 3) 模拟数据展示 4) 简单的UI设计 5) 部署方案。要求代码轻量&…

作者头像 李华
网站建设 2026/3/25 18:18:43

零基础玩转CUBEMX:第一个STM32项目实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 为STM32新手设计一个最简单的入门项目,要求:1. 使用STM32F103C8T6最小系统板;2. 实现按键控制LED(按下亮,松开灭);3. 配…

作者头像 李华
网站建设 2026/4/1 19:51:14

Qwen3-VL-WEBUI如何快速上手?一文详解WEBUI部署全流程

Qwen3-VL-WEBUI如何快速上手?一文详解WEBUI部署全流程 1. 背景与核心价值 1.1 视觉语言模型的演进需求 随着多模态AI在内容理解、智能代理、自动化交互等场景中的广泛应用,单一文本大模型已难以满足复杂任务的需求。视觉-语言模型(Vision-…

作者头像 李华
网站建设 2026/4/3 2:17:16

3个简单步骤,让你彻底摆脱视频网站的广告追踪烦恼

3个简单步骤,让你彻底摆脱视频网站的广告追踪烦恼 【免费下载链接】Piped An alternative privacy-friendly YouTube frontend which is efficient by design. 项目地址: https://gitcode.com/gh_mirrors/pi/Piped 你是不是也有过这样的经历?&…

作者头像 李华
网站建设 2026/4/3 5:32:52

零基础入门:手把手教你编写通达信高胜率指标

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个通达信指标学习助手,要求:1.提供指标编写基础语法教程 2.内置10个简单高胜率指标案例 3.支持交互式代码编辑和实时预览 4.提供常见错误检查和修正建…

作者头像 李华