LEC/FORMAL --- PARTI 原理介绍

2024-02-09 07:30
文章标签 介绍 原理 lec formal parti

本文主要是介绍LEC/FORMAL --- PARTI 原理介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LEC:lec(logic equivalence checking)又叫formal check,是对ic design的综合,PR前后的设计进行逻辑对比检查的工具/手段,保证综合不改变rtl原始的logic function。目前用的较多的就是C家的formal工具。接下来介绍一下lec的原理和流程

在这里插入图片描述

1. Lec 原理介绍:

之所以搞这个lec,是因为在rtl实现的过程中,会进行各种的优化逻辑操作,有时候为了优化面积或者timing,把一些工具认为不必要的逻辑进行了优化,那优化后的逻辑是否真正的仍然是rtl的需求呢?就需要做一个对比的验证。
在验证过程中,通过对比所有的key point pairs的方式,将整个design进行对比验证。对比过程中,把更靠近设计上游的design认为是golden的,把另一个design认为是revised的。

1.1 key points

当我们的design的instance变成20万,100万时候,不可能把所有的小的逻辑单元拿出来一个个的对比,这样可能会跑上个很久很久很久。为了加速这种对比,通过设定key points的方式。如下图所示,无论是golden还是revised design,都可以设置为key points加上logic cones的方式进行。我们只需要对两者design中对应的key points点进行比较,因为logic cones只是组合逻辑内容,不会影响到结果。这样会大大的加快对比的速度,也能保证准确性。

在这里插入图片描述

Key point上都有那些:
Primary inputs (PI) /Primary outputs (PO) /D flip-flop /D latches
Blackboxes (BBOX)/TIE-Z gates /TIE-E gates/CUT gates

1.2 Mapping

在做compare之前,需要进行一个mapping 操作,何为map?其实就是把golden和revised design的key points点一一对应上,首先要保证我们的输入键是正确的,我们比较的两个点的位置是正确的,才能保证结果是正确的。那工具是如何把两个design的key points互相对上的呢?其实在进行map的时候,会有name based map和func-based map,这个要根据项目情况和综合情况,自行组合选择。

1.3 Compare

当上一步骤的map完成之后,接下来就是要进行compare步骤了。
那么compare对于时序逻辑如DFF是怎么处理的呢?如下图所示,并不把这个DFF当成是一个正常的功能逻辑,而是分开,D端口作为比较的点,而Q端口作为下个比较点的输入。

在这里插入图片描述

那都有哪些点进行比较呢?其实主要还是从key points中的内容。比较的点包含了逻辑堆的汇聚点,Primary outputs, cut gates, DFFs, D-latches, and blackboxes。
虽然此刻比较的是一些key points点,但是实际还是对逻辑堆的比较,因为工具所比较的内容是从key points点经过逻辑堆,再到key points点才进行的check,正确与否和中间经过的逻辑关系密切。

这篇关于LEC/FORMAL --- PARTI 原理介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.