專用集成電路(ASIC)的設計規(guī)模不斷擴大、復雜度不斷攀升,這對芯片開發(fā)者的能力和所使用的工具都提出了更高的要求。
在之前的文章中,我們探討過數十億門級ASIC所面臨的跨時鐘域(CDC)和跨復位域(RDC)挑戰(zhàn),今天我們將共同探討第三大挑戰(zhàn)──靜態(tài)代碼校驗。
高效的代碼校驗
讓芯片開發(fā)周期左移
代碼校驗,即對源代碼進行自動檢查以排查錯誤,是硬件開發(fā)生命周期中非常重要的一環(huán)。如果能在RTL開發(fā)的早期階段就開始代碼校驗工作,評估代碼質量以及一旦代碼錯誤會對設計流程的后續(xù)環(huán)節(jié)造成哪些影響,這對開發(fā)者來說將會大大提升開發(fā)效率,并最終實現開發(fā)周期的左移。
現在的代碼校驗已經遠遠超出了RTL語義規(guī)則檢查的范疇,擴展到了綜合能力檢查、結構分析以及網表/電氣規(guī)則檢查。為實現左移,芯片開發(fā)者希望能夠在開發(fā)流程早期階段就完成許多復雜的任務,比如在 RTL 內執(zhí)行更復雜的檢查,以及確保 RTL 與下游合成引擎更加一致等等。開發(fā)者還希望 RTL 對各種仿真器“友好”并可進行互操作,同時兼容等價性檢查器。這些要求都不簡單,而這其中真正的挑戰(zhàn)就在于如何從源代碼中尋找并修復漏洞。
如果把這些挑戰(zhàn)放大到數十億門級ASIC的設計中,可以想想代碼校驗會有多復雜,因此為了在設計規(guī)模和復雜度不斷攀升的情況下,依舊實現將開發(fā)周期左移,就需要更強大的代碼校驗工具來幫助芯片開發(fā)者們高效完成代碼的預先排查工作。
管理規(guī)則集
代碼校驗工具需要使用規(guī)則集運行,開發(fā)者需要創(chuàng)建、管理和編策這些規(guī)則集。這些都是非常專業(yè)的技能,其中涉及的專業(yè)知識通常是小公司不具備的或者想要引入的,所以對小公司而言,入門級的做法就是購買現成的軟件包。而大型公司一般有自己的內部代碼校驗規(guī)則集,這些內部規(guī)則集對公司來說都是重要的投資。
第三方或行業(yè)標準規(guī)則集可以降低準入門檻,幫助小規(guī)模的設計團隊加速代碼校驗工作流程。新思科技的GuideWare方法學文檔和規(guī)則集正是為了這一目的而開發(fā)的,旨在幫助開發(fā)者快速開始采用此技術,并根據需要進一步制定規(guī)則。
GuideWare的目標是能夠在至少80%的用例中實現RTL移交,從而更大限度地減少創(chuàng)建、管理和編策相關規(guī)則所需的專業(yè)知識。對小型設計團隊而言,GuideWare絕對是一個福音,他們的設計可以實現質的飛躍,生產力也會大幅提升。
新思科技會對GuideWare定期進行更新,以確保規(guī)則集的復雜性始終處于行業(yè)領先地位。新思科技的IP均已通過代碼校驗認證,開發(fā)者們可以選擇新思科技的IP以及GuideWare中的設計復用合規(guī)性檢查功能,做出符合行業(yè)標準的設計。
如何處理無用代碼?
無用代碼或無法訪問的代碼在開發(fā)階段通常都會存在,有些甚至會保留到流片階段。為什么會這樣呢?
設計的復雜性在開發(fā)過程中也會不斷演進,開發(fā)者會隨時進行漏洞修復、增加功能、集成可復用的模塊等等,有時還會為了實現功耗和性能目標做全面的代碼優(yōu)化,這樣就會導致最初寫的一些代碼變?yōu)闊o用代碼。但是由于產品交付時間并沒有因為設計變復雜而延后,迫于時間壓力,很多時候開發(fā)者沒有時間去清理這些無用代碼。雖然保留這些代碼并不會影響下個代碼的正常運行,但是如果追求精簡設計,這些代碼就必須要處理。
使用代碼校驗工具來清理無用代碼是非常有必要的,有些開發(fā)者對工具是否好用持懷疑態(tài)度,他們可能會為了以防萬一就保留相關代碼,但大多數都會秉持“零違例”準則,即“要么修復,要么放棄”。因此,代碼校驗工具能夠準確識別無用代碼并知道如何處理它們是非常重要的。
新思科技的靜態(tài)代碼校驗工具VC SpyGlass Lint采用形式引擎,在識別無用代碼上效率非常出眾。但開發(fā)者通常會有以下幾種操作選項:
更新RTL代碼從而移除無用代碼:這應該是能把無用代碼清理的最干凈的解決方案,還能夠有效移除覆蓋率分析中的覆蓋率空洞。但這一方法需要重新構思代碼,并進行功能驗證,所以比較花時間。
把無用代碼注釋掉并為了以后參考附上相關信息的注釋:雖然這種方法也還需要進行功能驗證,但它也能提供一個干凈的代碼并移除覆蓋率空洞。
棄用代碼校驗 waiver 文件中的無用代碼:僅確認無用代碼的安全性,不對其進行清理,RTL代碼庫保持不變。覆蓋空洞將仍然存在。
了解設計復雜性
越復雜的設計所包含的漏洞也就越復雜。但開發(fā)者在設計中通常都會追求精簡、直觀、一看就懂且易于維護的代碼結構。不過隨著時間的推移,在開發(fā)者不斷debug修正代碼的過程中,代碼的整體質量與最初相比會有所下降,他們可能還會突然發(fā)現RTL代碼怎么好像越改越復雜了,邏輯也越來越難理解了。
衡量并可視化呈現代碼的復雜性可以幫助開發(fā)者“看見”代碼中變得復雜的部分,他們可以利用這一信息對積攢的復雜代碼進行評估和推演。針對復雜性風險過高的代碼區(qū),開發(fā)者會在性能和功能之間做一些權衡,并對部分代碼進行重構。
通過同行評議保證魯棒性很有用,且是一項所有設計團隊都應采用的最佳實踐,但新思科技的VC SpyGlass Lint有一個獨特的優(yōu)勢是其他工具無法比擬的,就是可以衡量代碼的復雜性,為開發(fā)者提供非常有用的建議。VC SpyGlass Lint利用形式引擎提供功能分析及代碼復雜性分析,并通過儀表板呈現結果。
永遠存在的誤報問題
在CDC和RDC的文章中,我們討論過誤報問題,這一問題在代碼校驗過程中同樣存在。在數十億門級的設計中,勢必會產生大量違例,數量過大就會有遺漏風險。開發(fā)者們希望的是,工具可以幫助他們直觀地看到有意義的信息、準確評估信息、正確標記違例、對違例進行分類等等,從而提高處理違例的效率和準確性。
VC SpyGlass Lint利用形式引擎來有效解決誤報問題。開發(fā)者們無需知道形式驗證,也無需具備這方面的專業(yè)知識,所有形式驗證都將在后臺完成。這一工具內置了5000多項檢查,而且新思科技仍在不斷地對檢查項目進行添加和完善。
功能校驗,加快簽核
借助一鍵式形式驗證的功能校驗,開發(fā)者們可以在驗證平臺可用前就對功能和覆蓋率問題進行測試,從而節(jié)省時間并實現左移。功能校驗在檢查以下控制問題時非常有用:
FSM死鎖
無法訪問狀態(tài)的檢查
覆蓋率問題(如常值信號)
無用代碼檢查
數組邊界違例
總結來說,如果開發(fā)者們能夠盡早知道復雜的RTL代碼是否能夠實現預期的設計結果,他們就可以在設計開發(fā)后續(xù)流程中節(jié)省很多時間和精力,不僅實現開發(fā)周期的左移,還可節(jié)約成本。新思科技的VC SpyGlass Lint等工具可以完美解決這一問題,它利用形式引擎實現功能分析,可有效幫助開發(fā)者們盡早判斷他們的RTL代碼質量是否滿足設計需求,最終加速簽核。
文章出處:【微信公眾號:新思科技】歡迎添加關注!文章轉載請注明出處。
-
芯片
+關注
關注
456文章
51016瀏覽量
425321 -
集成電路
+關注
關注
5390文章
11588瀏覽量
362498 -
asic
+關注
關注
34文章
1205瀏覽量
120600 -
新思科技
+關注
關注
5文章
801瀏覽量
50372
發(fā)布評論請先 登錄
相關推薦
評論