lec(logic equivalence check)--cadence 等价性检查工具理解

2024-06-16 09:08

本文主要是介绍lec(logic equivalence check)--cadence 等价性检查工具理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1. lec是独立的,不基于任何指定的综合工具。
  • key point mapping
    • ummapped points有三类
  • formal functional comparison algorithms
    • 两种comparison方式
  • 2. setup mode 和 lec mode
  • 3. blackbox
    • set
    • report
  • 4. unreachable key points
    • 设置选项,尽量避免unreachable报告,因为很多情况都是不需要检查逻辑等价性的。
  • 5. HDL rule
  • 6. 工程debug经验
  • 补充(genus15.20.000版本)
    • genus有模板脚本
    • genus官方文档里推荐两步式lec
  • 这篇ppt不错【debug方法参考111~120页码】

1. lec是独立的,不基于任何指定的综合工具。

key point mapping

ummapped points有三类

key point是各个module的输入输出端口、DFF、blackbox等关键点,用于lec检查。

  • extra unmapped points;只存在一种设计中,要么golden,要么revised。
  • unreachable unmapped points;无法找到一个可观察点,比如没有功能意义的flop端口。
  • not-mapped unmapped key points;一般是因为name rule导致的RTL与netlist无法映射成功。(因为map的方式,默认情况,首先是利用name映射,如果不成功就利用function映射)

formal functional comparison algorithms

两种comparison方式

  • hierachical(gold或者revised,有1个RTL版本的话,适合hierachical)
  • flattened(一般用于两个门级设计的比较。)

2. setup mode 和 lec mode

3. blackbox

set

  • 例如ram、模拟ip等,设置为黑盒子。不检查内部的逻辑等价性。
add notranslate module module_name -library -both
  • 如果想对某个特定module设置为黑盒子。
    建议去掉module描述段,改为空module,只定义input、output端口,内容为空。这样做完善,因为不去掉module描述内容,那么output端口的逻辑值可能会被固定,影响lec的验证精度。
    利用命令,可以生成一个空module,但是端口方向需要手动修改。
write design <filename> -bbox [-gold | -revised]

report

report black box

4. unreachable key points

设置选项,尽量避免unreachable报告,因为很多情况都是不需要检查逻辑等价性的。

比如大多数unreachable的情况,都是spare flops,就是空闲的触发器。没实际功能意义的触发器。

5. HDL rule

这个设置很重要,直接影响lec对门级网表进行design analysis,elaboration,RTL construction过程。如果设置不准确,会影响lec对门级网表的识别,导致出现mismatch的错误。



6. 工程debug经验

  • 不要使用lec编写脚本;而是推荐用dofile作为lec配置脚本。
  • 可以设置session;
  • RC(RTL Compiler)支持LEC更好一些。因为RC有命令write_do_lec。但DC+LEC的流程,user guide也有介绍,是可以解决的。
  • 不等价原因一
    lec设置的时候,对dft/test_mode没有设置常值;这种情况是因为RTL没有DFT,netlist有DFT,所以无法等价,必须去掉DFT相关的逻辑等价性对比检查。
  • 不等价原因二
    一般错误,通过gui界面的diagnosis、不等价点;再通过RTL去分析源代码,很容易debug。
  • 不等价原因三
    name rule不一致导致unmapped point,从而产生不等价的结果。注意报告的错误点,其层次路径是否特殊,比如有些generate块,实例名称带[]。这样的RTL和netlist做等价性检查会出不等价的错误。修改lec的name rule就可以解决。
    如果是RTL/netlist做lec,那么name rule推荐:
    • DC综合+LEC,那么lec的name rule要保持与DC的name rule一致;
    • RC综合+LEC,那么lec的name rule要保持与RC的name rule一致;
    • 综合和lec里的uniquify命令(命名唯一化),也要保持一致。如果lec和综合工具的name rule一致,并且uniquify的话,按道理讲,RTL与netlist的module名称、instance名称都应该对应起来。

具体解决实例如下图所示:
这里写图片描述
这里写图片描述

  • 如上方案都解决不了,可以检查代码版本、比较综合的中间网表版本、比较下一层次的网表等方法。
    其中,比较综合的中间网表版本,也是一种常见方法。因为综合的中间网表,与RTL和最终网表,map会更容易;lec更容易检查。RTL与综合的中间网表做lec;最终网表与综合的中间网表做lec;两步骤后,可以认为RTL与最终网表是等价的。
    比如:DC/RC综合netlist和RTL,做lec检查。
    RC和lec属于一家公司,所以切合度很高,容易PASS。
    但是DC和lec,有可能会出现问题。这时,可以利用综合的中间版本网表,作为桥梁。也许会有意想不到的debug效果。(Conformal_User.pdf里有专门的DC综合与lec的流程介绍)

参考文档:

  • Conformal_User.pdf
  • Conformal_Ref .pdf
  • ConformalHDL_Ref.pdf
  • cadence LEC_basic.pdf(cadence的PPT,360云盘里)

补充(genus15.20.000版本)

genus有模板脚本

参考
Cadence Genus userguide阅读笔记 - 个人笔记:not for everyone - 博客频道 - CSDN.NET
http://blog.csdn.net/u011729865/article/details/53912787

genus官方文档里推荐两步式lec

利用genus模板,在综合过程中,会产生两个lec脚本文件(相关的genus命令是write_hdlwrite_do_lec)。

  1. rtl2intermediate.lec.do
  2. intermediate2final.lec.do
    分别对应rtl与map后的网表、map后的网表与综合优化后的最终网表。

这篇ppt不错【debug方法参考111~120页码】

http://www.doc88.com/p-9703790400188.html

debug步骤:

  1. unmapped一定要解决;
  2. 利用电路视图,显示反标的值,很好追。我记得,lec不能追到根源点,formality能追到根源点,不知道是不是这样,反正formality追到根源点的思路,更适合我,很好用。

这篇关于lec(logic equivalence check)--cadence 等价性检查工具理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1066037

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

超强的截图工具:PixPin

你是否还在为寻找一款功能强大、操作简便的截图工具而烦恼?市面上那么多工具,常常让人无从选择。今天,想给大家安利一款神器——PixPin,一款真正解放双手的截图工具。 想象一下,你只需要按下快捷键就能轻松完成多种截图任务,还能快速编辑、标注甚至保存多种格式的图片。这款工具能满足这些需求吗? PixPin不仅支持全屏、窗口、区域截图等基础功能,它还可以进行延时截图,让你捕捉到每个关键画面。不仅如此

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

分布式系统的个人理解小结

分布式系统:分的微小服务,以小而独立的业务为单位,形成子系统。 然后分布式系统中需要有统一的调用,形成大的聚合服务。 同时,微服务群,需要有交流(通讯,注册中心,同步,异步),有管理(监控,调度)。 对外服务,需要有控制的对外开发,安全网关。