Conformal ECO 流程介紹

????????之前聽說過一句話,沒有修過ECO的人生是不完整的。最近就給我整得再次完整了。。。。。。

????????最近趕項目,RTL freeze之后,后仿發現出了bug(還好攔下來了,不然頭更大),于是做了一次function ECO,記錄下流程。。。。項目還是delay了。。。。。永遠記得checklist一定得過!!!!

RTL freeze就是說,從今天起,大家誰也不能再修改RTL了。RTL freeze是一個分水嶺。在freeze之前,你仿真也好,看代碼也好,FPGA驗證也好,發現的任何bug,都可以通過修改RTL的方式進行直接更正。但是freeze之后,被freeze的RTL將會進行綜合,STA,然后送給后端人員,做floor plan,電源綜合,時鐘綜合,布局布線等等。這些后端流程都是極其耗時的,而且通常不可逆的。


????????閑話扯完了,下面進入正題。

????????Conformal是Cadence家的一款形式驗證驅動的等效、低功耗和ECO解決方案,使用可為用戶提供獨立的等效性檢查解決方案,支持從RTL到P&R的最終網表驗證設計。要做ECO的話需要Conformal ECO XL 或 GXL license。目前主要大廠都用它做ECO。(S家的formality主要是我不知道如何自動生成ECO腳本,不過去年好像出了視頻,年后抽空學習一下。。。。)

? ? ? ? ECO的介紹就不多提了,見:

數字后端——ECO_滄海一升的博客-CSDN博客對ECO(engineering change order)進行簡單介紹https://blog.csdn.net/qq_21842097/article/details/121717450? ? ? ???Conformal支持Flattened ECO Flow和Hierarchical?ECO Flow。這里主要說明Flattened ECO Flow,這也是官方推薦的。Flattened下,工具會將 ECO 分析重點放在從平面比較中確定的非等效關鍵點上,且更容易設置,所有 ECO 補丁都可以用一個命令創建。

? ? ? ? FLOW如下:

????????1、使用 SET ECO OPTION -flat 命令(setup mode)指定運行 FEF 流:

SET FLATTEN MODEL -ECO
SET FLATTEN MODEL -ENABLE_ANALYZE_HIER_COMPARE

????????它還會自動將以下選項添加到 ANALYZE HIER_COMPARE 命令

-CONstraints
-NOEXact_pin_match
-FUNCTION_Pin_mapping
-INPUT_OUTPUT_Pin_equivalence
-THRESHOLD 0 //便于工具確定所有模塊邊界

????????2、為ANALYZE HIER_COMPARE命令增加額外指令。

? ? ? ? 3、使用 ADD COMPARE POINTS -all 和 COMPARE 命令開始flatten設計之間的比較。 這里主要是確定非一致性的關鍵點。

? ? ? ? 4、使用 COMPARE ECO HIERARCHY 命令根據模塊邊界(由步驟 1 確定)將非一致性點(在步驟 2 中確定)分解為其子模塊。

? ? ? ? 5、使用 ANALYZE ECO -hierarchical 命令創建所有必要的patches。

? ? ? ? 6、分別使用 APPLY PATCH 和 OPTIMIZE PATCH 命令應用和優化patches。


? ? ? ? 下面主要說下function ECO(pre-mask)的流程,這次我跑的就是這個,只能說不幸中的萬幸吧。。。?流程如下:

? ? ? ? ?1、將舊 RTL 與舊網表進行比較。應該結果是等價的,這里需要通過添加掃描約束來禁用掃描。

? ? ? ? 2、綜合修改后的RTL。一般來說用與創建舊網表相同的綜合工具、版本和腳本。 盡量減少任何更改。

? ? ? ? 3、將新?RTL 與新網表進行比較。應該結果是等價的。

? ? ? ? 4、將舊 RTL 與新 RTL 進行比較。結果是不等價的。這里需要注意的是,新的RTL讀入為Golden design,舊的RTL讀入為Revised design。

????????5、比較舊網表和新網表。

? ? ? ? 6、使用舊網表和新網表創建 ECO patch文件。在驗證了第 5 步中的所有非等價點都是由功能更改引起的之后,使用 Conformal 為每個非等價模塊創建一個patch文件。?在此步驟中使用的任何 ADD ECO PIN 命令也必須用于第 7 步和第 8 步。如果在創建 ECO patch 文件期間進行了任何展平,則必須對第 7 步和第 8 步執行相同的展平。

? ? ? ? 7、應用patch并寫出 ECO 網表。在分析所有 ECO 模塊后使用patch文件創建 ECO 網表,然后寫出尚未映射或優化的網表。

? ? ? ? 8、優化補丁。這一步有點類似綜合。

? ? ? ? 9、ECO網表進行等價性檢查。一致性檢查必不可少。

? ? ? ? 還是看腳本比較直接。ANALYZE ECO 命令會為每個非等價模塊創建patch文件。 patch文件定義了一個patch模塊并包含將改變設計功能的更改。 patch模塊名稱是附加了 _eco 的原始非等價模塊名稱。我這里主要是對比了兩個網表,然后進行處理:

set log file eco.log -replaceset flatten model -eco
set flatten model -gated_clock
set flatten model -enable_analyze_hier_compareread library xxx.lib -replace -libertyread design r2.v -golden -replace
read design r1.v -revised -replace
//===================================
//等價的寫法
//set x conversion e -both
//read design r1.v -golden -replace
//read design r2.v -revised -replace
//===================================report design data
report black boxuniquify -all -nolibrary -revised
add module attribute mod* -eco_module -noflatten -bothset system mode lec
analyze hier -eco_aware
add compare point -all
compare
compare eco hierarchy
analyze eco patch.v -preserve_clock -replace -hierarchical
//analyze 有-ecopin_dofile選項來增加eco pins,這次沒用到set system mode setup
apply patch -golden -keephierarchy -auto
optimize_patch -workdir <working_directory> \-library <lib_file_list> \-sdc <sdc_filename> \-instancenaming “ECOinst_%d” \-netnaming “ECOnet_%d” \-sequentialnaming “ECOreg_%s” \-synexec “genus” \-verbose
report eco changes -script -file xxx.script -replace
write eco design -newfile eco.v -replace -report ECOprelogics.rpt

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/253477.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/253477.shtml
英文地址,請注明出處:http://en.pswp.cn/news/253477.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

最新天貓面試題(含總結):線程池+并發編程+分布式設計+中間件

最新天貓面試題&#xff08;含總結&#xff09;&#xff1a;線程池并發編程分布式設計中間件https://my.oschina.net/u/3892...

關于NAND flash的MTD分區與uboot中分區的理解 .

今天做內核移植&#xff0c;準備添加NAND flash的驅動&#xff0c;做到MTD分區時&#xff0c;想起在一本書上看到的一句話&#xff0c;說的是分區時每個區之間沒有間隙&#xff0c;前一個區的結束地址是后一個區的起始地址。可是當我看我的開發板的教程時&#xff0c;分區如下&…

Zabbix discoverer processes more than 75% busy

原文發表于cu&#xff1a;2016-06-22 Zabbix discoverer processes more than 75% busy原因及處理。 一&#xff0e;現象 配置了discovery任務后&#xff0c;zabbix dashboard 告警如下&#xff1a; Zabbix discoverer processes more than 75% busy 二&#xff0e;原因 1. 配置…

Begin()

好&#xff0c;要開始在新的博客里寫東西了&#xff0c;上一個博客的賬號和密碼都忘了... 我開通博客的申請里寫&#xff0c;我博文的內容會以機器學習和控制算法的學習筆記為主。 那我寫的估計是假的申請。 好吧&#xff0c;既然是這樣寫申請的一定程度上也是要兌現承諾的&…

圖像紫邊消除(depurple)

圖像紫邊廣泛存在于目前的手機攝像頭、數碼相機、監控攝像頭等數字成像系統所得圖像中,當我們使用這些設備在逆光、大光圈等條件下拍攝時,所得圖像的局部區域,特別是高反差區域(亮暗對比反差很大的圖像區域,比如天空、燈管與物體相接的邊緣)會比較容易觀察到紫邊,解決圖…

Swift 性能相關

起初的疑問源自于「在 Swift 中的, Struct:Protocol 比 抽象類 好在哪里&#xff1f;」。但是找來找去都是 Swift 性能相關的東西。整理了點筆記&#xff0c;供大家可以參考一下。 一些疑問 在正題開始之前&#xff0c;不知道你是否有如下的疑問&#xff1a; 為什么說 Swift 相…

linux_NandFlash_driver_超詳細分析 .

分類&#xff1a; Linux 驅動 Nand 驅動 2011-11-06 23:16 474人閱讀 評論(0) 收藏 舉報 今天學習了NandFlash的驅動&#xff0c;硬件操作非常簡單&#xff0c;就是這個linux下的驅動比較復雜&#xff0c;主要還是MTD層的問題&#xff0c;用了一下午時間整理出來一份詳細的分析…

HTTPS 路徑配置

1: 首先安裝 fiddlercertmaker.exe 文件2:Tools -> HTTPS 3: Connections 勾中Allow remote computer to connect轉載于:https://www.cnblogs.com/eason-d/p/7492177.html

CMOS圖像傳感器——相位對焦

之前介紹了許多自動對焦的方案 自動對焦方法學習_滄海一升的博客-CSDN博客自動對焦的各類方法學習介紹https://blog.csdn.net/qq_21842097/article/details/121373263 在里面提到了遮蔽像素相位檢測法,原理上算是相位檢測法(Phase Detection Auto Focus,PDAF)的一種。…

51nod 1343 行列式的根

這題分塊搞一搞&#xff0c;算到最后發現結果就是算矩陣J的行列式&#xff0c;要取模m&#xff0c;那個sign消掉了。 參考文獻在這&#xff0c;歐幾里德算法的應用&#xff0c;金斌 代碼還是比較好寫的&#xff0c;python代碼 n,mmap(int,raw_input().split()) a[] for i in ra…

Spring Cloud Config 和Spring Cloud Bus實現配置中心

2019獨角獸企業重金招聘Python工程師標準>>> Spring Cloud是很多組件的集合&#xff0c;Spring將常用的技術框架進行包裝和整合&#xff0c;如mybatis zookeeper rabbitmq redis等等&#xff0c;還有一些科技公司貢獻出來的一些經過生產環境驗證的組件如奈飛公司貢獻…

ARM Linux啟動過程分析

1. 引 言 Linux 最初是由瑞典赫爾辛基大學的學生 Linus Torvalds在1991 年開發出來的&#xff0c;之后在 GNU的支持下&#xff0c;Linux 獲得了巨大的發展。雖然 Linux 在桌面 PC 機上的普及程度遠不及微軟的 Windows 操作系統&#xff0c;但它的發展速度之快、用戶數量的日益…

你有沒有靠譜的基因?一個人靠不靠譜,其實就看這三點:“凡事有交代,件件有著落,事事有回音。”...

你有沒有靠譜的基因&#xff1f;一個人靠不靠譜&#xff0c;其實就看這三點&#xff1a;“凡事有交代&#xff0c;件件有著落&#xff0c;事事有回音。” 故事一、做了就忘了&#xff1f; 一天上班后&#xff0c;我讓小王給上級部門送一個材料。 一個小時過去了&#xff0c;沒…

CMOS圖像傳感器——閃爍(flicker)現象

一、概述 閃爍(Flicker),通常發生在室內場景,曝光時間設置如果不是光源能量周期的整數倍,則圖像不同位置處積累的信號強度不同,并呈周期性變化,這是單幀圖像的情況。在視頻序列上,如果滿足一定條件,視頻會出現條紋模式在垂直方向上緩慢移動。 二、形成原因 1、光源 …

一條命令教你安裝centos下面的pip服務

yum install -y python-pip轉載于:https://blog.51cto.com/12131824/2177874

strcpy,memcpy,memset函數實現

strcpy 實現&#xff0c;只能拷貝字符串 char* strcpy(char* des,const char* source) {char* rdes; assert((des ! NULL) && (source ! NULL));while((*des *source)!\0);return r; } memcpy 實現&#xff0c;注意目的地址和源地址重合的情況&#xff0c;以及強制類…

CMOS圖像傳感器——圖像傳感器噪聲

圖像傳感器噪聲取決于圖像傳感器的制作工藝、內部結構及內部補償技術等原因,噪聲反應了圖像傳感器的內部特性。CMOS圖像傳感器基本原理見: CMOS圖像傳感——概述_滄海一升的博客-CSDN博客_cmos圖像傳感器CMOS圖像傳感器基本介紹https://blog.csdn.net/qq_21842097/article/d…

TI Davinci DM6441嵌入式Linux移植攻略——UBL移植篇

目錄(?)[] 一DM6441的Boot過程簡介二DM6441的UBL移植 CCS文件夾Common文件夾GNU文件夾 移植DDR2移植Nand Flash其它 聲明&#xff1a;本文參考網友zjb_integrated的文章《TI Davinci DM6446開發攻略——UBL移植》和《DAVINCI DM365-DM368開發攻略——U-BOOT-2010.12及UBL的移…

python接口自動化測試(二)-requests.get()

環境搭建好后&#xff0c;接下來我們先來了解一下requests的一些簡單使用&#xff0c;主要包括&#xff1a; requests常用請求方法使用&#xff0c;包括&#xff1a;get&#xff0c;postrequests庫中的Session、Cookie的使用其它高級部分&#xff1a;認證、代理、證書驗證、超時…

從一個Android碼農視角回顧2018GDD大會

兩天的GDD大會結束了&#xff0c;很開心&#xff0c;可以看得出&#xff0c;這次Google真的很用心。不但分享的內容質量很高。而且又有得吃又有得玩&#xff0c;還有許多好看的小姐姐&#xff0c;真不妄我請了兩天年假來參加這個大會。先來幾張圖鎮樓 哈哈&#xff0c;跑題了。…