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

    文章

    5363

    浏览量

    121027
  • 芯片设计
    +关注

    关注

    15

    文章

    1028

    浏览量

    54984
  • 计数器
    +关注

    关注

    32

    文章

    2261

    浏览量

    94923
  • 形式验证
    +关注

    关注

    0

    文章

    8

    浏览量

    5707
  • SVA
    SVA
    +关注

    关注

    1

    文章

    19

    浏览量

    10147
收藏 人收藏

    评论

    相关推荐

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

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

    LIMS系统芯片实验室的应用

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

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

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

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

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

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

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

    SSID和密码是否以加密形式存储ESP8266

    1.) SSID和密码是否以加密形式存储ESP8266。如果是,加密格式是什么? 2.) 芯片的唯一MAC ID是否加密?
    发表于 07-22 07:35

    机器学习的交叉验证方法

    机器学习,交叉验证(Cross-Validation)是一种重要的评估方法,它通过将数据集分割成多个部分来评估模型的性能,从而避免过拟合或欠拟合问题,并帮助选择最优的超参数。本文将详细探讨几种
    的头像 发表于 07-10 16:08 1419次阅读

    继电器的常见封装形式及其特点

    继电器作为电气控制系统不可或缺的关键元件,其封装形式不仅关系到继电器本身的性能和使用寿命,还对整个系统的稳定性和可靠性有着重要影响。随着电子技术的不断发展和应用领域的不断拓展,继电器的封装形式也日益多样化。本文将对继电器的常见
    的头像 发表于 05-21 18:26 2628次阅读

    芯片测试和芯片验证的区别

    这是芯片在设计过程的一个环节,主要通过EDA(电子设计自动化)工具进行仿真检验。它的主要目的是芯片生产之前,验证
    的头像 发表于 05-08 16:52 2288次阅读

    振弦采集仪岩土工程监测的精度验证与校准方法研究

    振弦采集仪岩土工程监测的精度验证与校准方法研究 河北稳控科技振弦采集仪是一种常用的岩土工程监测仪器,用于测量地下水位、土壤压力和地表位移
    的头像 发表于 05-08 13:55 284次阅读
    振弦采集仪<b class='flag-5'>在</b>岩土<b class='flag-5'>工程</b>监测<b class='flag-5'>中</b>的精度<b class='flag-5'>验证</b>与校准方法研究

    岩土工程监测振弦采集仪隧道工程的监测与应用

    工程的监测与应用以及其优点和局限性等方面进行阐述。 岩土工程监测振弦采集仪隧道工程
    的头像 发表于 04-09 13:13 302次阅读
    岩土<b class='flag-5'>工程</b>监测振弦采集仪<b class='flag-5'>在</b>隧道<b class='flag-5'>工程</b><b class='flag-5'>中</b>的监测与应用

    555集成芯片的封装形式

    555集成芯片的封装形式主要有DIP8封装、SOP8封装以及金属封装和环氧树脂封装等。其中,DIP8封装是555芯片的经典封装形式,包含了芯片
    的头像 发表于 03-26 14:44 1358次阅读

    fpga原型验证平台与硬件仿真器的区别

    FPGA原型验证平台与硬件仿真器芯片设计和验证过程各自发挥着独特的作用,它们之间存在明显的区别。
    的头像 发表于 03-15 15:07 1209次阅读

    fpga验证和uvm验证的区别

    FPGA验证和UVM验证芯片设计和验证过程中都扮演着重要的角色,但它们之间存在明显的区别。
    的头像 发表于 03-15 15:00 1760次阅读

    功率放大器声波截面梯度场的重建及其声波场处理的应用

      实验名称:电压放大器声波截面梯度场的重建及其声波场处理的应用   实验内容:水下声信号传播过程中会引起介质折射率的变化,当激光穿
    发表于 03-08 17:45