0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

怎么用Vivado做覆盖率分析

FPGA开源工坊 来源:FPGA开源工坊 2024-01-03 12:34 次阅读

在做仿真的时候往往会去做代码覆盖率和功能覆盖率的分析,来保证仿真是做的比较充分完备的。

在Vivado里面也支持我们做这项操作,现在就来看一下流程吧。

第一步:选择设置

58af3c34-a9ed-11ee-8b88-92fbcf53809c.png

第二步:在仿真选项里面依次找到下面的设置选项,默认vivado是没有打开覆盖率分析这个选项的。

58c1b9e0-a9ed-11ee-8b88-92fbcf53809c.png

第三步:做如下设置,其中cover是我们想要设置的覆盖率的名字,这个可以自己设置,./是覆盖率信息放置的位置,这两项都可以根据自己的使用来设置。sbct是设置想要收集哪些覆盖率信息,s是行覆盖率,b是分支覆盖率,c的条件覆盖率,t是翻转覆盖率。设置完成之后点击Apply保存设置就可以了。这样在我们仿真的时候就会进行覆盖率的收集了。

59b1a798-a9ed-11ee-8b88-92fbcf53809c.png

第四步:点击仿真,跑一个测试用例

然后就可以看到在对应的仿真目录下生成一个xsim.codeCov的目录,因为我设置的./所以生成的信息放在了这个目录下。

59cd980e-a9ed-11ee-8b88-92fbcf53809c.png

点进去的话,会发现是一个xsim.CCInfo文件,之后就需要我们处理一下,把他变成可读的html文件。

59e0e9e0-a9ed-11ee-8b88-92fbcf53809c.png

第五步:在TCL里面输入下面的命令

xcrg.exe -cc_report E:/myreport1 -cc_db cover -cc_dir E:/fpga_image_sim/fpga_image_sim.sim/sim_1/behav/xsim/xsim.codeCov/

就可以看到vivado在帮我们生成相应的报告

59f44e22-a9ed-11ee-8b88-92fbcf53809c.png

生成的报告:

5a04a79a-a9ed-11ee-8b88-92fbcf53809c.png

然后点击dashboard.html查看报告。

5a22b7b2-a9ed-11ee-8b88-92fbcf53809c.png

就可以看到相应的报告了,我仿真就跑了很短的时间所以覆盖率很低。

并且我们可以按模块来查看相应的报告

5a331cba-a9ed-11ee-8b88-92fbcf53809c.png

每个模块内部的报告也可以看到:

5a4cec3a-a9ed-11ee-8b88-92fbcf53809c.png

然后可以根据详细的报告去构造特殊的测试案例来提升覆盖率。

5a6570b6-a9ed-11ee-8b88-92fbcf53809c.png

最后解释一下刚刚那句命令的含义:

这个参数用来控制生成的报告放到哪个目录下
-cc_report E:/myreport1  
后面的cover就是我们在设置界面所设置的名字
-cc_db cover 
这个是生成的覆盖率信息的路径,我设置的./所以vivado生成到了sim目录下
-cc_dir E:/fpga_image_sim/fpga_image_sim.sim/sim_1/behav/xsim/xsim.codeCov/

关于这个命令更多的信息可以参见:

5a788fde-a9ed-11ee-8b88-92fbcf53809c.png

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 仿真
    +关注

    关注

    50

    文章

    3872

    浏览量

    132165
  • 命令
    +关注

    关注

    5

    文章

    638

    浏览量

    21849
  • 代码
    +关注

    关注

    30

    文章

    4556

    浏览量

    66800
  • Vivado
    +关注

    关注

    18

    文章

    790

    浏览量

    65105

原文标题:怎么用Vivado做覆盖率分析

文章出处:【微信号:FPGA开源工坊,微信公众号:FPGA开源工坊】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    请问如何获得RM48芯片的失效率λ?故障覆盖率

    本帖最后由 一只耳朵怪 于 2018-5-22 14:58 编辑 最近有RM48芯片的产品,需要对它的可靠性进行评估,但是如何获得它的失效率λ故障覆盖率呢?只知道这个芯片满足SIL3等级,SIL3PFD 10-4~10-3PFH10-8~10-7
    发表于 05-22 07:30

    请问依靠RM48系列MCU的自身资源是否可以实现对时钟的高覆盖率诊断?

    本帖最后由 一只耳朵怪 于 2018-5-22 16:25 编辑 MCU型号:RM48目标功能:实现对时钟的高覆盖率诊断背景描述:1. 根据IEC61508-2:2010对时钟高覆盖率诊断
    发表于 05-22 01:58

    为什么覆盖率分析师没有证明电阻器已经过测试?

    您好,我对Coverage Analyst有疑问。我使用的是Coverage Analyst版本5.21p。覆盖率分析师完成覆盖率报告确定(html文件),但我对报告中显示的结果有疑问: -
    发表于 01-07 16:06

    如何改善5G覆盖率

    改善5G覆盖率的方法
    发表于 12-15 07:52

    如何增加板级互连的故障诊断覆盖率

    在边界扫描机制引入电路设计的前提下,如何增加板级互连的故障诊断覆盖率
    发表于 04-26 06:37

    如何提高DFT设计测试覆盖率

    提高DFT设计测试覆盖率的有效方法是什么
    发表于 05-07 06:37

    怎么提高非随机图形设计的故障覆盖率

    怎么提高非随机图形设计的故障覆盖率?为LBIST设计提高故障检测能力的技术是什么?
    发表于 05-08 07:11

    VCO中的子带覆盖率是否跟开关电容的取值有关?

    仿真VCO时候,开关电容阵列中开关电容的值取30fF,子带呈现不规律变化。当取100fF时,子带才呈现比特位控制那样规律变化,但这样子带覆盖率会存在问题。求遇到过同样问题的大神解答下!感谢!
    发表于 06-25 06:19

    嵌入式仿真平台SkyEye的覆盖率分析相关资料下载

    代码执娜行覆盖情况的功能,来检测代码中未执行覆盖情况。在覆盖率分析时需要分析嵌入式软件的指令覆盖率
    发表于 12-17 07:27

    关于SpinalHDL中的验证覆盖率收集简单说明

    在做RTL仿真验证时,覆盖率收集往往是我们在验证中需要注意的地方,本篇就SpinalHDL中的验证覆盖率收集做一个简单说明。sbt配置在SpinalHDL里进行仿真验证时,我们的待测试代码会生
    发表于 06-24 15:56

    重点厘清覆盖率相关的概念以及在芯片开发流程中跟覆盖率相关的事项

    有误;更多的分析可以得出更详细的结论。下面会对这两种覆盖率分别展开阐述,最后再补充一下例通过(Pass rate)和计划覆盖率(Plan
    发表于 09-14 11:57

    Systemverilog覆盖率的合并和计算方式

      在systemverilog中,对于一个covergroup来说,可能会有多个instance,我们可能需要对这些instance覆盖率进行操作。  只保存covergroup type的覆盖率
    发表于 03-21 14:24

    Verilog代码覆盖率检查

    Verilog代码覆盖率检查是检查验证工作是否完全的重要方法,代码覆盖率(codecoverge)可以指示Verilog代码描述的功能有多少在仿真过程中被验证过了,代码覆盖率分析包括以
    发表于 04-29 12:35 7945次阅读

    覆盖率的Verilog代码的编写技巧

    设计工程师需要关心的主要有行覆盖率(Block),条件覆盖率(Expression),翻转覆盖率(Toggle),状态机覆盖率。本文从ASIC设计的角度上来讨论,如何写出高
    的头像 发表于 05-26 17:30 3727次阅读

    多少和什么样的覆盖率分析才足够

      软件测试和分析可以被认为是由许多相互依赖的部分组成的整体活动。其中包括需求跟踪、静态和动态分析、编码标准合规性等,包括覆盖范围分析。归根结底,
    的头像 发表于 11-11 15:02 361次阅读