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

    文章

    5440

    浏览量

    125012
  • 芯片设计
    +关注

    关注

    15

    文章

    1091

    浏览量

    55733
  • 计数器
    +关注

    关注

    32

    文章

    2292

    浏览量

    96564
  • 形式验证
    +关注

    关注

    0

    文章

    8

    浏览量

    5792
  • SVA
    SVA
    +关注

    关注

    1

    文章

    19

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

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

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

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

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

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

    引言随着AI、HPC及超大规模芯片设计需求呈指数级增长原型验证平台已成为芯片设计流程验证复杂架构、缩短迭代周期的核心工具。然而,传统原型
    的头像 发表于 06-06 13:13 ?610次阅读
    超大规模<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 ?271次阅读
    CAN<b class='flag-5'>芯片</b>逻辑响应<b class='flag-5'>验证</b>测试

    FPGA EDA软件的位流验证

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

    MATLAB工程的应用

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

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

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

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

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

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

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

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

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

    LIMS系统芯片实验室的应用

    高速发展的芯片行业芯片实验室作为技术创新和产品验证的核心部门,面临着诸多挑战与问题。这些问题不仅影响了实验室的工作效率,还可能对
    的头像 发表于 11-07 17:59 ?881次阅读

    三星电容的封装形式有哪些选择?

    三星电容提供多样化的封装形式,这些形式的选择主要取决于电容的类型、物理尺寸以及其特定应用的需求。为了满足不同场景下的使用要求,三星电容采
    的头像 发表于 10-25 14:23 ?842次阅读

    FPGA算法工程师、逻辑工程师、原型验证工程师有什么区别?

    ,共同进步。 欢迎加入FPGA技术微信交流群14群! 交流问题(一) Q:FPGA的FPGA算法工程师、FPGA逻辑工程师、FPGA原型验证工程
    发表于 09-23 18:26

    形式验证如何加速超大规模芯片设计?

    引言随着集成电路规模的不断扩大,从设计到流片(Tape-out)的全流程验证环节的核心地位日益凸显。有效的验证不仅是设计完美的基石,更是确保电路实际应用
    的头像 发表于 08-30 12:45 ?978次阅读
    <b class='flag-5'>形式</b><b class='flag-5'>验证</b>如何加速超大规模<b class='flag-5'>芯片</b>设计?

    芯片失效分析中常见的测试设备及其特点

    芯片失效分析,常用的测试设备种类繁多,每种设备都有其特定的功能和用途,本文列举了一些常见的测试设备及其特点。
    的头像 发表于 08-07 17:33 ?1999次阅读
    <b class='flag-5'>芯片</b>失效分析中常见的测试设备<b class='flag-5'>及其</b>特点