说说收集coverage这件事

路科验证 2021-11-18 12:17

本来以为coverage这件事情很多人会写文章讲,结果在公众号上搜了一圈也没找到几篇,那么今天就和大家聊聊coverage。

早期的验证方法学是通过direct test去保证设计的质量。这个阶段是directed-test driven的,但是随着设计规模和复杂度变大,这种直接测试导向会遗漏掉很多问题。于是验证方法学发展到了第二个阶段coverage driven。

Coverage driven这里的coverage主要有功能覆盖率(function coverage) 和代码覆盖率(code coverage)。功能覆盖率覆盖点(coverage point)和断言覆盖率(assertion coverage),代码覆盖率分为行覆盖(linecoverage),翻转覆盖(toggle coverage),分支覆盖(branch coverage),条件覆盖(condition coverage),状态机覆盖(FSM coverage)等。这也是目前大部分公司在执行的验证策略。实际 coveragedrive能够覆盖到大部分问题,但是有些可能因为设计有漏掉,然后写function coverage的时候也有漏掉,导致规格书上有些部分没有真正实现。

所以第三代验证方法学推出Metric driven,这种方法学是将验证过程中收集到的coverage数据反标到spec中,从而得到一个可视化的验证结构,保证验证的完备性,目前这种方法学应用还比较少。

验证工程师很大一部分工作在收集coverage,对于80%的coverage我们可能通过几个基本的test就能打到,但是剩下的20%会花很长的时间去打。

为此我们需要建立regression的环境,创造随机的test,跑大量的regression去补齐最后20%的部分。

别看只有20%,对于大的设计,去review code 会发现几万行的代码没有打到。所以这个时候靠regression是非常有必要的。但是我们经常会发现一个奇怪的现象,随着coverage的提升,regression能打到的点越来越少。这表现在虽然每周都在进行regression,但是coverage却越涨越慢,甚至到后期都不涨了。一般到这个时候,运气好的话coverage能到了90%了。

接下来将是一个非常痛苦的过程,很多公司的做法就会去review code,如果DV的能力比较强,看懂code自己补test,但是到最后发现还是有补不完的。designer的参与就非常有必要了,designer会帮忙一起review,然后几个轮回的造test跑simulation把coverage补齐。

有时候好不容易把coverage收到99%了,突然designer说要改动一个feature,完蛋,前面的工作又得再走一遍,特别是之前调好了针对某段代码设计的direct test因为时序改变,又得重新调,如果在短时间内,coverage database 没有产生,原来的coverage database 又和现在的设计不匹配,系统推送给project leader的周报告显示coverage 分数掉下来,被leader追杀那叫一个胆战心惊。
实际上我们跑regression的test大部分都在撞击同一段代码,因此很多test跑2遍和跑100遍的效果是一样,对于没有cover到部分可能要某只test跑几万次才能撞到,这一点也不夸张,当你去看function coverage里面coverage bin被撞到的次数,你就会明显看到这个现象,因此随机的regression不一定是收集coverage的有效方式,有时适当的direct test 更加有帮助。在这方面很多人也在研究,比如让一次regression的结果作为下次regression的输入去约束一些随机值,从而使设计的覆盖率快速收敛。

当然目前也有很多公司采用一些tool去收集coverage,比如用formal去验证某些代码是无法被覆盖到的,这样就省去人力去看,这种方法非常高效。


对于收集coverage这件事情,你们还遇到过什么问题,都有哪些小技巧,欢迎留言讨论。



路科验证 专注于数字芯片验证的系统思想和前沿工程领域。路桑是Intel资深验证专家,主持验证架构规划和方法学研究,担任过亿门级通信芯片的验证经理角色。在工程领域之外,他在西安电子科技大学和西安交通大学客座讲授芯片验证课程。著有书籍《芯片验证漫游指南》。
评论
  • Supernode与艾迈斯欧司朗携手,通过Belago红外LED实现精准扫地机器人避障;得益于Belago出色的红外补光功能,使扫地机器人能够大大提升其识别物体的能力,实现精准避障;Belago点阵照明器采用迷你封装,兼容标准无铅回流工艺,适用于各种3D传感平台,包括移动设备、物联网设备和机器人。全球领先的光学解决方案供应商艾迈斯欧司朗(瑞士证券交易所股票代码:AMS)近日宣布,与国内领先的多行业三维视觉方案提供商超节点创新科技(Supernode)双方联合推出采用艾迈斯欧司朗先进Belago红
    艾迈斯欧司朗 2024-12-20 18:55 145浏览
  • 耳机虽看似一个简单的设备,但不仅只是听音乐功能,它已经成为日常生活和专业领域中不可或缺的一部分。从个人娱乐到专业录音,再到公共和私人通讯,耳机的使用无处不在。使用高质量的耳机不仅可以提供优良的声音体验,还能在长时间使用中保护使用者听力健康。耳机产品的质量,除了验证产品是否符合法规标准,也能透过全面性的测试和认证过程,确保耳机在各方面:从音质到耐用性,再到用户舒适度,都能达到或超越行业标准。这不仅保护了消费者的投资,也提升了该公司在整个行业的产品质量和信誉!客户面临到的各种困难一家耳机制造商想要透
    百佳泰测试实验室 2024-12-20 10:37 239浏览
  • ALINX 正式发布 AMD Virtex UltraScale+ 系列 FPGA PCIe 3.0 综合开发平台 AXVU13P!这款搭载 AMD 16nm 工艺 XCVU13P 芯片的高性能开发验证平台,凭借卓越的计算能力和灵活的扩展性,专为应对复杂应用场景和高带宽需求而设计,助力技术开发者加速产品创新与部署。随着 5G、人工智能和高性能计算等领域的迅猛发展,各行业对计算能力、灵活性和高速数据传输的需求持续攀升。FPGA 凭借其高度可编程性和实时并行处理能力,已成为解决行业痛点的关
    ALINX 2024-12-20 17:44 143浏览
  • 光耦合器,也称为光隔离器,是用于电气隔离和信号传输的多功能组件。其应用之一是测量电路中的电压。本文介绍了如何利用光耦合器进行电压测量,阐明了其操作和实际用途。使用光耦合器进行电压测量的工作原理使用光耦合器进行电压测量依赖于其在通过光传输信号的同时隔离输入和输出电路的能力。该过程包括:连接到电压源光耦合器连接在电压源上。输入电压施加到光耦合器的LED,LED发出的光与施加的电压成比例。光电二极管响应LED发出的光由输出侧的光电二极管或光电晶体管检测。随着LED亮度的变化,光电二极管的电阻相应减小,
    腾恩科技-彭工 2024-12-20 16:31 145浏览
  •                                                窗        外       年底将近,空气变得格外寒冷,估计这会儿北方已经是千里
    广州铁金刚 2024-12-23 11:49 101浏览
  • 百佳泰特为您整理2024年12月各大Logo的最新规格信息。——————————USB▶ 百佳泰获授权进行 USB Active Cable 认证。▶ 所有符合 USB PD 3.2 标准的产品都有资格获得USB-IF 认证——————————Bluetooth®▶ Remote UPF Testing针对所有低功耗音频(LE Audio)和网格(Mesh)规范的远程互操作性测试已开放,蓝牙会员可使用该测试,这是随时测试产品的又一绝佳途径。——————————PCI Express▶ 2025年
    百佳泰测试实验室 2024-12-20 10:33 153浏览
  • 国产数字隔离器已成为现代电子产品中的关键部件,以增强的性能和可靠性取代了传统的光耦合器。这些隔离器广泛应用于医疗设备、汽车电子、工业自动化和其他需要强大信号隔离的领域。准确测试这些设备是确保其质量和性能的基本步骤。如何测试数字隔离器测试数字隔离器需要精度和正确的工具集来评估其在各种条件下的功能和性能。以下设备对于这项任务至关重要:示波器:用于可视化信号波形并测量时序特性,如传播延迟、上升时间和下降时间。允许验证输入输出信号的完整性。频谱分析仪:测量电磁干扰(EMI)和其他频域特性。有助于识别信号
    克里雅半导体科技 2024-12-20 16:35 116浏览
  • 随着工业自动化和智能化的发展,电机控制系统正向更高精度、更快响应和更高稳定性的方向发展。高速光耦作为一种电气隔离与信号传输的核心器件,在现代电机控制中扮演着至关重要的角色。本文将详细介绍高速光耦在电机控制中的应用优势及其在实际工控系统中的重要性。高速光耦的基本原理及优势高速光耦是一种光电耦合器件,通过光信号传递电信号,实现输入输出端的电气隔离。这种隔离可以有效保护电路免受高压、电流浪涌等干扰。相比传统的光耦,高速光耦具备更快的响应速度,通常可以达到几百纳秒到几微秒级别的传输延迟。电气隔离:高速光
    晶台光耦 2024-12-20 10:18 189浏览
  • 光耦固态继电器(SSR)作为现代电子控制系统中不可或缺的关键组件,正逐步取代传统机械继电器。通过利用光耦合技术,SSR不仅能够提供更高的可靠性,还能适应更加复杂和严苛的应用环境。在本文中,我们将深入探讨光耦固态继电器的工作原理、优势、挑战以及未来发展趋势。光耦固态继电器:如何工作并打破传统继电器的局限?光耦固态继电器通过光电隔离技术,实现输入信号与负载之间的电气隔离。其工作原理包括三个关键步骤:光激活:LED接收输入电流并发出与其成比例的光信号。光传输:光电传感器(如光电二极管或光电晶体管)接收
    腾恩科技-彭工 2024-12-20 16:30 121浏览
  • 汽车行业的变革正愈演愈烈,由交通工具到“第三生活空间”。业内逐渐凝聚共识:汽车的下半场在于智能化。而智能化的核心在于集成先进的传感器,以实现高等级的智能驾驶乃至自动驾驶,以及更个性、舒适、交互体验更优的智能座舱。毕马威中国《聚焦电动化下半场 智能座舱白皮书》数据指出,2026年中国智能座舱市场规模将达到2127亿元,5年复合增长率超过17%。2022年到2026年,智能座舱渗透率将从59%上升至82%。近日,在SENSOR CHINA与琻捷电子联合举办的“汽车传感系列交流会-智能传感专场”上,艾
    艾迈斯欧司朗 2024-12-20 19:45 197浏览
我要评论
2
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦