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

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

3天内不再提示

形式验证及其在芯片工程中的应用

冬至子 来源:长点芯 作者:SJ66 2023-10-20 10:46 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一:形式验证的基本概念

-> 广义上的形式验证?

形式验证不仅仅是芯片领域中的一个概念。正如文章开头提到过,形式验证强调使用严格的数学推理和形式化技术,以确保系统的行为是否符合预期的性质和规格。所以说只要是可以通过量化方式构建数学模型的系统,都可以使用形式验证来check其功能性以及其他可量化特性。比如:

  1. 软件工程:就拿区块链举个例子。形式验证不仅适用于智能合约本身,还适用于与智能合同交互的去中心化应用。这可以帮助确保整个应用的安全性和正确性。
  2. 金融领域:金融交易的验证是非常重要的,特别是在高频交易和算法交易领域。形式验证可以确保交易的正确性和合规性,防止错误交易和潜在的风险。

-> 芯片工程里的形式验证?

这里拿计数器举一个简单的形式验证示例。请注意,这只是一个简化的示例,实际的形式验证可能涉及更复杂的设计和性质。

假设有一个4位的计数器电路,可以从0计数到15。我们想要验证以下性质:当计数器的值达到最大值15时,下一个计数值应该是0。

设计:计数器电路有一个4位的计数器寄存器,可以递增。当计数器值达到15时,下一个时钟周期应该将计数器重置为0。

形式验证属性:我们使用SystemVerilog的属性规约 (SVA) 来表达这个性质。(一般形式验证的case都使用SVA来编写)以下是一个简化的属性规约示例:

property reset_at_max;
  @(posedge clk) disable iff (!rst_n)
    (count == 4'b1111) |= > (next_count == 4'b0000);
endproperty

assert property (reset_at_max);

在这个属性规约中,我们定义了一个属性 reset_at_max ,它表达了当计数器值为15时,下一个计数值应为0。这个属性在时钟上升沿触发时进行检查。如果属性不满足,将会产生一个验证错误。

在这个示例中,使用仿真进行验证可能需要执行多个时钟周期来验证所有可能的计数序列。但是,使用形式验证可以直接进行数学推理,验证属性在所有可能的情况下是否成立.

除此之外,与基于仿真的验证不同,基于仿真的验证会使用各种输入情景来测试设计以确保其正确行为,形式验证涉及数学分析以验证设计的属性。这些属性可以包括功能正确性、安全性、安全性以及某些类型错误的缺失(例如,竞态条件、死锁等)。

二:形式验证的优势

从上述的例子看来,那么形式验证要优于基于仿真的验证?看似高性能的形式验证,要将它发挥得淋漓尽致也是需要代价的。

其实不然,形式验证也面临着挑战。它可能计算成本高昂,需要专门的专业知识来制定属性并设置验证过程。通常与其他验证技术(如仿真和测试)结合使用,以提供全面的验证策略。形式验证和基于仿真的验证各有其优势和局限性,没有绝对的优劣之分。选择哪种验证方法取决于具体的设计需求、时间和资源限制以及设计的复杂性。

形式验证VS动态仿真

->形式验证的特点:

  1. 高度可靠性 :形式验证提供了数学证明的可靠性,如果设计通过了形式验证,那么可以有很大的信心认为设计是正确的。
  2. 全面性 :形式验证可以覆盖所有可能的状态,从而捕获设计中的所有潜在错误,包括一些难以通过仿真检测到的问题。
  3. 对于复杂设计 :对于复杂的设计,特别是关键性能的设计,形式验证可以帮助发现隐藏的问题和时序错误。

->动态仿真验证的特点:

  1. 易于实施 :基于仿真的验证通常比形式验证更容易实施,可以快速验证设计的基本功能和常见情况。
  2. 资源效率高 :在一些情况下,形式验证可能需要更多的计算资源和时间,而基于仿真的验证可能更具资源效率。
  3. 快速迭代 :基于仿真的验证允许设计团队迅速进行修改和验证,特别适用于快速迭代的设计流程。

可见,trade-off的概念在芯片领域里面处处可见。鱼与熊掌不可得兼。

三:在芯片验证中实现形式验证

形式验证主要由以下几个部分组成:

  1. 性质(Properties) :这些是描述设计所需属性和规格的语句,例如时序关系、状态转换、约束等。常用的
  2. 规约语言 :通常使用形式规约语言,如 SystemVerilog Assertions(SVA)、Property Specification Language(PSL)等,来编写性质和约束。
  3. 定理证明器(Theorem Provers) :这些工具用于推理和证明性质是否成立。它们基于形式化逻辑和推理规则来验证性质。
  4. 模型检查器(Model Checkers) :这些工具用于穷举系统状态空间,检查是否存在满足性质的状态序列。

在电子设计自动化 EDA 工具中,许多主要的形式验证工具已经集成到综合工具链中,以帮助硬件工程师验证他们的设计。这些工具通常基于硬件描述语言 (如Verilog或VHDL)

比如:

1. Cadence JasperGold :JasperGold是一个集成式形式验证平台,支持属性规约和模型检查,广泛应用于验证硬件设计。

2. Synopsys VC Formal :VC Formal是Synopsys的形式验证工具,用于验证功能、时序和系统级性质。

四:形式验证的未来

最近几年,学术界

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

    关注

    31

    文章

    5588

    浏览量

    129054
  • 芯片设计
    +关注

    关注

    15

    文章

    1128

    浏览量

    56443
  • 计数器
    +关注

    关注

    32

    文章

    2306

    浏览量

    97568
  • 形式验证
    +关注

    关注

    0

    文章

    8

    浏览量

    5831
  • SVA
    SVA
    +关注

    关注

    1

    文章

    19

    浏览量

    10340
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    国内首个汽车芯片标准验证平台启用,“消费芯片”再难上车?

    [首发于智驾最前沿微信公众号]10月28日,国内首个国家级汽车芯片标准验证中试服务平台深圳正式投入使用。该平台由国家及行业相关机构共同推动建设,旨在满足车规级芯片在环境与可靠性、失效
    的头像 发表于 10-29 15:17 427次阅读
    国内首个汽车<b class='flag-5'>芯片</b>标准<b class='flag-5'>验证</b>平台启用,“消费<b class='flag-5'>芯片</b>”再难上车?

    芯片抗单粒子性能研究及其商业卫星测传一体机的应用

    成功率的关键因素。本文聚焦于芯片抗单粒子效应(SEU/SEL)的研究,深入探讨其物理机制、设计优化策略以及实验验证方法。通过详细分析国科安芯推出的ASM1042S通信芯片与ASP4644S电源管理
    的头像 发表于 08-14 17:03 726次阅读

    降低adc不同PCB上的噪声,如何做到接近AD4134验证板噪声水平?

    我设计的复杂多片AD4134的大型数字系统,噪声水平Nrms无法控制到预期水平。希望能够找到关键的影响因素。还请各位大师指点。 根据验证版及数据手册的布局方式,不对ADC的下方地
    发表于 08-11 08:24

    有哪些芯片工程师才懂的梗?

    今天聊点有意思的,就是芯片行业那些梗。下面这些“梗”,只有Fab、EDA、IP、SoC、验证、后端、封测等各个细分岗位上摸爬滚打过的人,才能秒懂,外行听了恐怕只会一脸黑人问号。1.DFT不是离散
    的头像 发表于 07-25 10:03 523次阅读
    有哪些<b class='flag-5'>芯片</b><b class='flag-5'>工程</b>师才懂的梗?

    CYW43907系列ModusToolbox的工程是否可以移植到Keil uVision

    CYW43907系列ModusToolbox的工程是否可以移植到Keil uVision,看见了官方推出的移植文档,但是不知道是否支持此芯片
    发表于 07-08 06:48

    Veloce Primo补全完整的SoC验证环境

    芯片构建之前完成。虽然硬件加速器和桌面原型板是这项验证两个众所周知的参与者,但企业原型同样具备重要的意义。 尽管仿真设计的早期阶段占据主导地位,但由于性能的原因,其更多的适用于模
    的头像 发表于 06-12 14:39 1171次阅读
    Veloce Primo补全完整的SoC<b class='flag-5'>验证</b>环境

    超大规模芯片验证:基于AMD VP1902的S8-100原型验证系统实测性能翻倍

    引言随着AI、HPC及超大规模芯片设计需求呈指数级增长原型验证平台已成为芯片设计流程验证复杂架构、缩短迭代周期的核心工具。然而,传统原型
    的头像 发表于 06-06 13:13 1093次阅读
    超大规模<b class='flag-5'>芯片</b><b class='flag-5'>验证</b>:基于AMD VP1902的S8-100原型<b class='flag-5'>验证</b>系统实测性能翻倍

    CAN芯片逻辑响应验证测试

    CAN芯片研发阶段,需要做诸多涉及通讯错误管理验证的问题。ISO-16845国际标准,规定完善的测试标准,如错误帧检测,传输帧相关检测
    的头像 发表于 04-30 18:24 604次阅读
    CAN<b class='flag-5'>芯片</b>逻辑响应<b class='flag-5'>验证</b>测试

    FPGA EDA软件的位流验证

    位流验证,对于芯片研发是一个非常重要的测试手段,对于纯软件开发人员,最难理解的就是位流验证FPGA芯片研发
    的头像 发表于 04-25 09:42 2058次阅读
    FPGA EDA软件的位流<b class='flag-5'>验证</b>

    MATLAB工程的应用

    电子发烧友网站提供《MATLAB工程的应用.pdf》资料免费下载
    发表于 04-19 16:54 8次下载

    芯华章以AI+EDA重塑芯片验证效率

    近日,作为国内领先的系统级验证EDA解决方案提供商,芯华章分别携手飞腾信息技术、中兴微电子IC设计验证领域最具影响力的会议DVCon China进行联合演讲,针对各个场景下验证
    的头像 发表于 04-18 14:07 1342次阅读
    芯华章以AI+EDA重塑<b class='flag-5'>芯片</b><b class='flag-5'>验证</b>效率

    模拟示波器电路设计与调试的应用

    模拟示波器电路设计与调试的应用主要体现在以下几个方面:一、电路设计阶段 信号验证电路设计阶段,设计师可以通过模拟示波器观测电路
    发表于 03-31 14:07

    软件芯片设计中有什么作用

    ,软件是汽车的驾驶系统”。硬件提供了基础设施和功能,而软件则控制和指挥硬件去完成具体的任务。 1. 软件芯片设计的作用: (1)验证芯片
    的头像 发表于 02-09 09:43 1420次阅读

    负载箱电力系统测试的应用与优势

    ,帮助工程师测试发电机满载、部分负载以及突加载荷下的表现。通过这种测试,可以确保发电机实际运行能够稳定供电,避免因负载波动导致的电力中断。 变压器负载能力
    发表于 02-05 16:39

    英诺达发布全新静态验证产品,提升芯片设计效率

    了重要一步,将为中国芯片产业的发展注入新的活力。 静态验证作为一种业界普遍使用的验证方法,通过对设计的源代码进行深入分析,能够发现设计的潜在问题。与动态仿真
    的头像 发表于 12-24 16:53 1159次阅读