【EDA/IP专栏】芯华章:统一前端验证平台,面向EDA 2.0

芯思想 2021-12-07 10:32


文章来源:中国战略新兴产业



EDA与中国“芯”愿



芯片设计几乎完全依赖于有高可靠性的计算机辅助设计手段。眼下,中国EDA/IP正迎来最好的时代,多家国产EDA/IP公司已整装待发,期待能以厚积薄发的技术实力快速完善中国集成电路产业链,支持5G、人工智能、云计算等多项未来科技的发展。

为什么说EDA是中国芯片产业链最薄弱的环节?目前中国的EDA/IP发展是否开始得到足够的重视和支持?当前什么制约了自主IP及其复用技术?仿真的飞跃能为芯片行业带来什么好处?芯片制造流程无非是设计、制造、封测,却因为流程间的紧密关联而体现出复杂性。如何理解这种复杂性?本期,我们邀请到几位业内专家,谈谈国产EDA/IP仍然面临着的诸多挑战,而在这些挑战中,我们往往可以窥见巨大的市场机遇,并找到解决方案。


统一前端验证平台,面向EDA 2.0


杨晔


前端验证工具,其共同的验证目标都是针对功能、断言、代码等几种覆盖率,验证过程中也都要给工程师提供调试的手段和验证流程的控制。基于EDA 2.0所提出的下一代EDA开放、智能和平台化的目标,我们可以想到,多种验证工具可以提取共同点、协同工作、规范流程,形成一个统一的验证平台。

从20世纪70年代至今,芯片设计工具经历了计算机辅助设计(CAD)、计算机辅助工程(CAE)和EDA三个阶段。1995-2000年开始形成的电子自动化设计基础,我们可以称之为“EDA 1.0”。

EDA 1.0的大体流程经过过去20多年的发展,虽然已经丰富了很多,但是流程没有本质提高,之后20多年EDA的发展都是在1.0上逐渐增加各种内容,我们可以认为一直到今天我们都处于“EDA 1.x”的发展过程中。

但近年来,芯片设计、验证的复杂度和成本急速上升,现有EDA的发展速度越来越来越跟不上芯片设计规模和需求的快速增长,且面临着种种技术挑战。因此,国内EDA业界逐步提出并明确了未来5-15年达到EDA 2.0的发展目标,主要包括开放和标准化、自动和智能化、平台和服务化这三个方向,其中也特别提出了智能化验证平台的概念,这个概念与芯片的前端验证有很多的联系。

芯片前端设计,主要指芯片设计里的功能实现过程。这个实现过程中的各种测试和确认,就是前端验证。随着芯片越来越复杂,验证的工作量逐渐超过了设计的工作量,当前无论是投入的人力或时间,芯片实现流程中验证工作都占最高比例。因此高质量的前端验证工具,对芯片设计非常重要。

当前芯片验证工具的市场,主要由Synopsys、Cadence和Mentor三家国外EDA厂商占领,特别是Synopsys和Cadence,都有自己完整的全套前端验证软硬件工具集。除了这三家EDA巨头外,国内外仅有少数公司有FPGA原型验证相关的软件或硬件产品。前端验证工具的全球市场规模大约为每年18亿-20亿美元,约占整个EDA市场(包括IP)的15%-20%。国内前端验证工具市场规模约每年4亿-5亿美元。

本文重点面向EDA 2.0的“平台化”目标,聚焦到芯片设计的前端验证环节,从验证的核心目的、常用工具出发,分析在哪些方面可以从“验证工具”发展为“验证平台”,提高验证效率,为芯片设计客户提供更多的价值。


01
前端设计验证的目的和指标


芯片设计的前端部分,最简化流程只需要逻辑描述(写RTL级代码)和逻辑综合两步,就可以生成前端网表(netlist),完成设计过程。但是,如此复杂的硬件芯片逻辑,很难保证逻辑完全正确,也需要确认软硬件能正确配合。因此芯片的前端设计投入,大部分都花在前端设计验证(简称前端验证)上,这已经成为当下整个芯片设计流程中的最大最耗时间的瓶颈。同时,越来越激烈的市场竞争和越来越短的创新周期要求芯片尽量缩短验证时间,越来越高的制造成本又要求尽量提高验证质量。

因此,前端验证的主要目的是尽可能短的时间内,确保设计的逻辑功能正确性和完备性。这种正确性和完备性是如何衡量的?当前的芯片前端验证,已经逐渐形成了覆盖率驱动的验证流程和评价指标。包括检查硬件逻辑实现和软硬件集成系统已经是否达到了应用系统的全部目标功能的“功能覆盖率”、检查逻辑实现有没有超出设计目标之外的错误行为的“断言覆盖率”、检查逻辑实现有没有可触发但没有测试过的代码,或不可触发的冗余代码的“代码覆盖率”,以及“故障覆盖率”,即针对特定类型的芯片如车规芯片,对功能安全要求比较高,还有故障注入测试和故障覆盖率的概念。检查如果出现某些特定物理错误是否会导致系统发生不可接受的后果。

除了可以由工具自动完成的语法检查等基本检查外,上面的四种覆盖率指标其实是测试了“我想要的”“我想到的”“我没想到的”和“我不想要的”这四个层次,达到比较完备的功能性验证目的。




02
前端设计验证需要哪些方法和工具?


仿真模拟验证的方法,首先将输入场景利用软件的方法模型化,或者直接运行目标硬件上的软件,从而模型或目标软件产生测试激励,测试激励输入给运行在EDA仿真工具内的芯片设计。简单来说,就是将输入驱动给设计,验证这边根据具体的功能,也抽象的描述其功能以及预期结果,最后根据模型预期结果和设计输出结果统计前面提到三种覆盖率指标。如下图里的高层次测试用例既可以是UVM事务级模型,也可以是CPU上运行的软件产生的场景数据,最终经过UVM等事务级测试环境转化为信号激励给DUT(待测设计,Device Under Test)。

前端的仿真模拟验证工具,根据仿真原理的区别,一般分为软件仿真工具、FPGA原型仿真工具、硬件仿真加速工具。

软件仿真也叫逻辑仿真,在主机(一般为x86)上通过CPU软件去仿真设计电路的行为,对模块级电路的编译速度快但仿真速度很慢,调试性能好。

FPGA原型仿真基于高性能FPGA芯片和专用软件工具组成,由于FPGA芯片内部电路可重构的特点几乎可以完全映射芯片的逻辑设计,又有高性能芯片高速并行的特性,因此基于FPGA原型工具的仿真性能是最高的,对由真实软件驱动的SoC级软硬件协同仿真特别重要。

硬件仿真加速工具基于硬件平台和专用软件工具,其核心硬件有基于FPGA的也有基于专用ASIC芯片的,与FPGA原型仿真工具的主要区别在于硬件仿真加速保证了更高的可调试性和更大的设计规模,但性能不如FPGA原型仿真。除了RTL仿真加速调试之外,硬件仿真加速与FPGA原型工具一样经常用于软硬件系统集成验证。

此外,近年来基于Accellera PSS(Portable Stimulus Standard)标准和高级语言建模的智能激励生成工具可以高效地针对特定验证场景自动产生测试用例。针对不同的验证平台和验证层级,PSS工具可以生成不同形态、适配多种验证环境的测试用例,配合各种仿真模拟工具进行芯片验证。

形式验证是仿真模拟验证的一种补充,是从数学上完备地证明设计实现方案是否满足了设计规范所描述的功能。其采用基于模型的数学求解方法,针对用户提供的断言和属性,面向目标设计所有可能的输入来进行证明,确定该设计是否与给定的规范功能一致,从而避免在一个极大输入范围内做无数次仿真模拟,针对被测模块直接给出完备的功能和代码覆盖率结论,提升验证的可靠性和效率。

形式验证方法对应的工具一般就是支持模型检查(model checking)的专用形式验证工具,其应用流程包括设计模型化、模型和解空间分析、模型求解、反例输出等,最后要么证明设计是正确的,要么给出能证明设计出错的输入用例。

同时,验证过程中验证工程师还需要对设计和验证进行调试的手段,这包括了电路、波形和代码查看、覆盖率跟踪分析、仿真流程分析、高层次协议分析等功能,业界也有多种相关的验证调试工具。


03
前端验证工具如何进行统一和平台化?


前面提到的五种前端验证工具,其共同的验证目标都是前文提到的几种覆盖率,验证过程中也都要给工程师提供调试的手段和验证流程的控制。基于EDA 2.0所提出的下一代EDA开放、智能和平台化的目标,我们可以想到,多种验证工具可以提取共同点、协同工作、规范流程,形成一个统一的验证平台。

统一的验证平台,其统一性体现在功能模块、数据和流程这三个方面。

统一的前端代码解析。从用户的RTL级设计代码出发,要经过解析、编译、优化、映射等步骤,其中前端的解析、编译和部分优化步骤是与具体运行的硬件无关的,这部分模块可以在各验证工具间共享,实现算法、中间数据和变量命名的统一,这对EDA产品开发和客户调试都有很大的便利。

统一的覆盖率数据库。无论是软件还是硬件仿真,包括形式化验证,都可以输出对应测试模块覆盖率的数据,这些交叉数据必须统一到一个最终的覆盖率数据库和访问接口中,在各工具间共享,才能制定高效的测试计划,避免重复测试。Accellera组织曾发布过UCIS(Unified Coverage Interoperability Standard)这个覆盖率数据交换标准,统一的验证平台应该支持这样的标准化接口,并在各验证工具间统一数据格式。

统一的仿真波形数据库。类似于覆盖率数据库,各种工具仿真的波形结果,也需要有统一的数据库格式,方便各种工具协同。目前除了IEEE1364标准中规定的开放数据格式VCD之外,Synopsys公司的FSDB私有压缩格式数据库也是常见的波形格式。未来国产EDA行业一定会出现更开放性能更好的统一波形数据格式。

统一的智能调试系统。各种验证工具的仿真和求解结果,都只是庞杂的验证数据库,需要给用户提供统一的界面和接口进行设计调试。这种调试包括查看波形、电路、代码覆盖率和功耗等各种数据,并支持用户以灵活的条件组合展示数据,实现智能化分析和追踪设计错误。以不同方式对多种工具收集到的验证数据进行深度数据挖掘,形成一个统一的智能调试系统,辅助加快设计流程。

统一的计算任务管理和计算资源调度。前端验证无论是基于仿真还是基于形式化模型,其本质都是大量的计算任务,底层需要各种计算资源(CPU,GPU,FPGA,memory)的支持。这些任务管理和资源管理,如果采用统一的调度器和资源管理器,不仅可以提高资源利用效率,提高验证的自动化流程,也能更好地利用云计算平台的海量弹性资源。

由于仿真目标一致性和技术实现的相似性,各验证工具也可以基于统一的验证平台实现多种互相协同,以及实现自动化的工作流程,这包括但不限于软件仿真与硬件仿真的协同和加速、硬件仿真和FPGA原型的数据、模型、接口复用、PSS工具自动生成激励并自动输出给仿真工具、形式化验证的覆盖率结果自动替代非必要的仿真用例、PSS、软件仿真及调试工具协同,形成低功耗测试、验证和分析方案等。

统一化的验证平台,不仅仅是五种验证工具的联合使用,它成为了更强大的验证工具,给用户带来更好的易用性、更高的验证效率、更自动化的使用流程、更智能的验证方案。同时,统一验证平台的模块重用、模块开放和接口开放,也给验证工具厂商甚至整个EDA行业减少了“重复造轮子”的工作。

从当前的EDA工具市场看,处于领先的几家国外EDA厂商已经初步启动了前端验证工具的协同,在2019-2021年时间段内纷纷推出了“验证平台”的概念,特别是在同一公司内的工具之间共享覆盖率和波形数据方面。但是几大EDA厂商之间的数据协同还基本不存在,同时在更高层次的流程、任务、资源管理的统一性上还有所欠缺。国产EDA工具方面,目前只有个别厂商可以完全覆盖前端验证全流程工具,我们希望能尽快看到国内的验证工具EDA厂商研发出自己的国产化统一验证平台。

EDA是一个宽泛的概念,对应了非常长的工具链和产业链,这个链条上的每个主要环节都有自己的特点和需求国产EDA要达到尽快发展、追赶先进水平的目的,就要对EDA的每一个环节进行深耕,弥补不足,发挥优势。EDA 2.0提出了下一代EDA发展的整体目标,但具体到EDA的环节,需要每个EDA厂商结合自己的产品领域,细化出更具体的EDA 2.0实现路径。


作者简介

杨晔,芯华章科技产品和市场规划总监,曾就职于英特尔、新思科技与思华科技

等公司。

芯思想 中国半导体正能量传播平台。为中国半导体产业服务,我们都是中国半导体产业腾飞的见证人。新闻分析,精彩评论,独家数据,为您定制信息,欢迎拍名片回复,和行业精英交流。
评论
  • 我的一台很多年前人家不要了的九十年代SONY台式组合音响,接手时只有CD功能不行了,因为不需要,也就没修,只使用收音机、磁带机和外接信号功能就够了。最近五年在外地,就断电闲置,没使用了。今年9月回到家里,就一个劲儿地忙着收拾家当,忙了一个多月,太多事啦!修了电气,清理了闲置不用了的电器和电子,就是一个劲儿地扔扔扔!几十年的“工匠式”收留收藏,只能断舍离,拆解不过来的了。一天,忽然感觉室内有股臭味,用鼻子的嗅觉功能朝着臭味重的方向寻找,觉得应该就是这台组合音响?怎么会呢?这无机物的东西不会腐臭吧?
    自做自受 2024-12-10 16:34 136浏览
  • 智能汽车可替换LED前照灯控制运行的原理涉及多个方面,包括自适应前照灯系统(AFS)的工作原理、传感器的应用、步进电机的控制以及模糊控制策略等。当下时代的智能汽车灯光控制系统通过车载网关控制单元集中控制,表现特殊点的有特斯拉,仅通过前车身控制器,整个系统就包括了灯光旋转开关、车灯变光开关、左LED前照灯总成、右LED前照灯总成、转向柱电子控制单元、CAN数据总线接口、组合仪表控制单元、车载网关控制单元等器件。变光开关、转向开关和辅助操作系统一般连为一体,开关之间通过内部线束和转向柱装置连接为多,
    lauguo2013 2024-12-10 15:53 81浏览
  • 一、SAE J1939协议概述SAE J1939协议是由美国汽车工程师协会(SAE,Society of Automotive Engineers)定义的一种用于重型车辆和工业设备中的通信协议,主要应用于车辆和设备之间的实时数据交换。J1939基于CAN(Controller Area Network)总线技术,使用29bit的扩展标识符和扩展数据帧,CAN通信速率为250Kbps,用于车载电子控制单元(ECU)之间的通信和控制。小北同学在之前也对J1939协议做过扫盲科普【科普系列】SAE J
    北汇信息 2024-12-11 15:45 77浏览
  • 时源芯微——RE超标整机定位与解决详细流程一、 初步测量与问题确认使用专业的电磁辐射测量设备,对整机的辐射发射进行精确测量。确认是否存在RE超标问题,并记录超标频段和幅度。二、电缆检查与处理若存在信号电缆:步骤一:拔掉所有信号电缆,仅保留电源线,再次测量整机的辐射发射。若测量合格:判定问题出在信号电缆上,可能是电缆的共模电流导致。逐一连接信号电缆,每次连接后测量,定位具体哪根电缆或接口导致超标。对问题电缆进行处理,如加共模扼流圈、滤波器,或优化电缆布局和屏蔽。重新连接所有电缆,再次测量
    时源芯微 2024-12-11 17:11 74浏览
  • 近日,搭载紫光展锐W517芯片平台的INMO GO2由影目科技正式推出。作为全球首款专为商务场景设计的智能翻译眼镜,INMO GO2 以“快、准、稳”三大核心优势,突破传统翻译产品局限,为全球商务人士带来高效、自然、稳定的跨语言交流体验。 INMO GO2内置的W517芯片,是紫光展锐4G旗舰级智能穿戴平台,采用四核处理器,具有高性能、低功耗的优势,内置超微高集成技术,采用先进工艺,计算能力相比同档位竞品提升4倍,强大的性能提供更加多样化的应用场景。【视频见P盘链接】 依托“
    紫光展锐 2024-12-11 11:50 47浏览
  • 天问Block和Mixly是两个不同的编程工具,分别在单片机开发和教育编程领域有各自的应用。以下是对它们的详细比较: 基本定义 天问Block:天问Block是一个基于区块链技术的数字身份验证和数据交换平台。它的目标是为用户提供一个安全、去中心化、可信任的数字身份验证和数据交换解决方案。 Mixly:Mixly是一款由北京师范大学教育学部创客教育实验室开发的图形化编程软件,旨在为初学者提供一个易于学习和使用的Arduino编程环境。 主要功能 天问Block:支持STC全系列8位单片机,32位
    丙丁先生 2024-12-11 13:15 49浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-10 16:13 105浏览
  • 全球知名半导体制造商ROHM Co., Ltd.(以下简称“罗姆”)宣布与Taiwan Semiconductor Manufacturing Company Limited(以下简称“台积公司”)就车载氮化镓功率器件的开发和量产事宜建立战略合作伙伴关系。通过该合作关系,双方将致力于将罗姆的氮化镓器件开发技术与台积公司业界先进的GaN-on-Silicon工艺技术优势结合起来,满足市场对高耐压和高频特性优异的功率元器件日益增长的需求。氮化镓功率器件目前主要被用于AC适配器和服务器电源等消费电子和
    电子资讯报 2024-12-10 17:09 87浏览
  • 【萤火工场CEM5826-M11测评】OLED显示雷达数据本文结合之前关于串口打印雷达监测数据的研究,进一步扩展至 OLED 屏幕显示。该项目整体分为两部分: 一、框架显示; 二、数据采集与填充显示。为了减小 MCU 负担,采用 局部刷新 的方案。1. 显示框架所需库函数 Wire.h 、Adafruit_GFX.h 、Adafruit_SSD1306.h . 代码#include #include #include #include "logo_128x64.h"#include "logo_
    无垠的广袤 2024-12-10 14:03 69浏览
  • 概述 通过前面的研究学习,已经可以在CycloneVGX器件中成功实现完整的TDC(或者说完整的TDL,即延时线),测试结果也比较满足,解决了超大BIN尺寸以及大量0尺寸BIN的问题,但是还是存在一些之前系列器件还未遇到的问题,这些问题将在本文中进行详细描述介绍。 在五代Cyclone器件内部系统时钟受限的情况下,意味着大量逻辑资源将被浪费在于实现较大长度的TDL上面。是否可以找到方法可以对此前TDL的长度进行优化呢?本文还将探讨这个问题。TDC前段BIN颗粒堵塞问题分析 将延时链在逻辑中实现后
    coyoo 2024-12-10 13:28 101浏览
  • RK3506 是瑞芯微推出的MPU产品,芯片制程为22nm,定位于轻量级、低成本解决方案。该MPU具有低功耗、外设接口丰富、实时性高的特点,适合用多种工商业场景。本文将基于RK3506的设计特点,为大家分析其应用场景。RK3506核心板主要分为三个型号,各型号间的区别如下图:​图 1  RK3506核心板处理器型号场景1:显示HMIRK3506核心板显示接口支持RGB、MIPI、QSPI输出,且支持2D图形加速,轻松运行QT、LVGL等GUI,最快3S内开
    万象奥科 2024-12-11 15:42 68浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦