在做這個項目的過程中,IC君一直在反思,工作7年以來,為什么絕大部分的項目都很忙?每到tapeout的時候總是手忙腳亂?為什么有些項目出來的結果會失敗?
《窮查理寶典》
巴菲特的搭檔查理芒格認為凡事要反過來想:
“如果要明白人生如何得到幸福,首先是研究人生如何才能變得痛苦;要研究企業如何做強做大,首先研究企業是如何衰敗的。”要想做一個成功的項目,首先是研究如何做一個“失敗”的IC項目。
這兒定義的失敗,是指項目執行的過程很混亂,大家做得辛苦,但是最后出來芯片的bug卻很多,甚至完全不能工作。
至于芯片生產出來之后,市場定位準不準確、好不好賣或者賺不賺錢不在我們的討論之列。
我們IC的項目流程往往如下所示:
這個圖的步驟分類比較粗獷,具體各部分的功能以前的文章也說過新入職IC工程師必備技能——數模混合篇。比較細致的流程可以參考之前的文章一個前端數字IC工程師的一天。下面就從這幾個步驟探討一下如何做一個“失敗”的項目。
1
架構設計決定了一個芯片的功能和設計劃分,是最重要的一環,它決定了我們以后的努力方向。如果努力的方向錯了,做得越多,錯的越多!
想把項目搞失敗,這一步最容易。
比如項目執行的過程中,架構不停地變換,但是tapeout的日期沒變:
-
本來想做高速芯片,后面突然想把功耗做到最低;
-
起初想做一顆很小的芯片,后面變成一顆很大的芯片,期間添加了無數的功能。tapeout前添加的功能最容易出問題哦!
-
某個中等模塊的風險一開始沒有評估充分,做到后面發現冒出來的bug越來越多。如果徹底解決需要改動很多block,最后只能修修補補;
-
對spec的理解發生錯誤,項目執行的中后期發現了這個問題,為了實現正確的spec需要改動很多電路;
-
沒有正確評估封裝的可行性,比如做到后面突然發現8SOP封裝包不進去,pad位置需要大改,之前做的很多評估工作完全白做。
架構設計主要是在項目leader主導下完成,當然有些東西也不完全由leader決定,老板很多時候也會參與其中。有時候架構的變化是市場導致的,果斷的改架構可能對公司而言是一個正確的決定。比如某段時間穿戴式產品的興起,低功耗突然變成大家迫切需要的特性,對于speed不太那么care。
架構的改變對于IC工程師而言,只能接受并做出更多仿真來確保架構的改動是沒問題的。不管是基于何種原因,頻繁的改動架構是最容易導致項目失敗的!
2
小模塊的設計和仿真驗證就是廣大的IC工程師的工作內容,做好自己負責的部分。對于一個失敗的項目而言,這一步的危害性相對于架構設計小很多。如果你想把項目做失敗,可以通過以下方法來實現:
-
負責的模塊經過自己評估之后,發現工作量巨大或者難度巨高,但是又希望完全通過自己的努力去完成它,默默的做了幾個月而沒有及時向leader highlight這些問題;
-
在沒有搞清楚電路功能的情況下,隨意修改繼承項目的電路。以前的項目怎么做得這么笨啊,不行我要改改它,讓它的gate數目少一點,面積更小prefect!
-
實現功能的時候沒有想清楚各種意外case,只是簡單的實現spec的功能;
-
時序檢查的時候沒有留下足夠的margin,在post layout仿真的時候很容易出錯;
-
有些模塊可能要跑所有的工藝角,實際做的時候只跑了一個TT 工藝,后續芯片級驗證的時候也不可能跑所有的工藝,有可能芯片的工藝稍微飄一飄就不能正常工作了。比如你做了一個RC的delay在TT工藝下是5ns,但是工藝飄一飄就到15ns了,有可能電路就fail了;
-
設計沒有冗余,自認為將面積做到了最小。tapeout前期修改電路的時候根本沒有gate讓你用。這也是IC君容易犯的錯誤。
-
不遵守一些既定的設計規則。比如在電路綜合的時候,不希望出現latch,必須遵守特定的RTL代碼寫法。
3
芯片仿真就是把所有模塊都包含進來的仿真驗證。通常整合之后,會發現很多小模塊設計時沒考慮的問題。這一步通常會有多位工程師參與,所以前一步的問題很多在這邊能cover掉,項目想要失敗似乎也沒那么容易。
-
仿真環境和電路實際工作環境不match,不帶dspf沒有任何寄生效應,看起來工作的棒棒的,tapeout出來之后fail了;
-
行為模型編寫錯誤,你看到的仿真行為根本和實際芯片不一致,驗證結果很完美,實際結果沒法看。這個危害真的挺大的;
-
由于芯片仿真也是由不同的人負責的,所以如果負責人沒有按照既定的flow 驗證一些該check的東西,遺漏了很多情況,就加大了失敗的概率;
-
負責check的人不夠資深,即使看到錯誤的仿真結果仍然發現不了問題;
-
仿真時間特別長,沒有使用提高仿真速度的方法,做一次仿真需要很長時間,等你仿真結果出來黃花菜都涼了。如何避免這個問題,可以參考我們之前的文章如何減少IC設計和驗證的仿真時間。
4
寄生參數仿真(layout后仿真)就是考慮實際的layout提取寄生參數后,進行的仿真。
這一步通常跟做第二步的是同一批的人,如果項目要做失敗,可能是以下原因導致的:
-
根本就沒有做寄生參數的仿真,前仿的時候電路的節點根本沒有寄生的RC,仿真結果看起來特別好,但是layout有可能走了很長的金屬線,有可能setup時間就違例了;
-
對抽取寄生參數的工具使用不當:比如使用calibre的工具去抽寄生參數,有很多option需要設置。有可能寄生結果的提取比實際layout過重或者過輕,導致仿真結果的不正確;
-
沒有做layout檢查,有些模塊需要特殊的layout比如電流鏡、bandgap、放大器等等;還有一些特殊的走線(特殊線寬),也需要做layout檢查,以確保tapeout的版本跟你仿真的版本一致。
5
其它原因主要是指一些跟工廠相關的問題,以前的文章也提到過一部分聊一聊tapeout失敗的事。這些問題通常都很嚴重,一招致命的類型:
-
mask給你出錯了,少出了一層或者拿成前一版的;
-
某些器件用得好好的,突然建議你不要用了;
-
工廠產能不夠,需要換工藝或者換工廠。
-
和PAD直接連接的電路不考慮ESD的問題
-
每家公司可能都有tapeout的checklist,tapeout前沒有check這些規則,很可能就會fail。
我只想知道將來我會死在什么地方,這樣我就不去那兒了。
由于個人知識有限,上面列舉了一些項目失敗的原因,大家還可以在微信文章或者知乎文章留言,IC君會對文章進行修改和補充。
最后希望大家在項目執行過程中不要犯這些錯誤,輕松愉快地流片成功!
-
集成電路
+關注
關注
5389文章
11572瀏覽量
362224
原文標題:如何做一個”失敗”的IC項目
文章出處:【微信號:icstudy,微信公眾號:跟IC君一起學習集成電路】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論