[心得] IC驗證工程師工作經驗分享
工作五年了 從剛畢業的小菜鳥 到現在也經歷了不少Project
發現版上對於IC驗證工程師的資料很少
來分享一下自己的工作經驗
希望能讓更多人知道IC驗證工程師的工作內容
如果各位有任何問題歡迎指教及討論
以下 Digital Designer(簡稱DE)
指稱主要工作是用HDL(台灣多用Verilog)設計數位IC電路的工程師
Digital Verification Engineer(簡稱DV)
工作相關技能:
1. Linux + shell script
2. scipt language (Perl, Python, Tcl, ...)
3. simulator (IUS, VCS, ModelSim)
4. debugger (通常是Verdi)
5. SystemVerilog/VMM/UVM
6. FPGA
7. 各種Protocal(AMBA, SPI, I2C, SDIO, ...)
IC驗證工程師的工作內容說白了很單純
怎麼確定RTL設計是對的?
這也是很多公司不重視DV的原因
驗證是種概念
DE把RTL寫出來當然會想辦法驗證自己寫的東西是否正確
為什麼還需要DV呢?
我們分兩個層面來看 IP level和system level
以IP level來說 例如32bit加法器(a+b=c含overflow bit)
這個design超簡單的吧
但是要測試完所有的組合是不太可能的
a, b 各有 32bits 組合接近 2^64 種
每秒跑一百萬組測資要跑超過50萬年......
基本上很多DE就是隨便寫幾組測資試試看
那要跑多少測試資料才算夠呢?跑一百萬組應該很多了吧
以DV的角度來看這題 重點不是測資數量的多寡
而是用coverage的數據來說話
包含 code coverage, toggle coverage, branch coverage, functional coverage
例如就算跑了一百萬組測資 如果有幾個bit一直都是0
有可能 input 1 時會發生錯誤但是沒有發現
我的經驗是DV的價值在於「如何制訂計畫,在有限時間內提高IC設計的可靠度」
執行的技能是其次 就算DE自己寫verilog testbench驗證
只要觀念正確也可以有很好的效果
DV可以協助DE突破盲點 也可以提供技術讓驗證更有效率
從system level來看 驗證的複雜度就更高了
通常每個IP都有自己的owner 系統又會由另外一個人整合
有做過design的都知道 就算每個IP測試都是正確的 整合完還是常常發生問題
就算系統運作正常 還可能有效能不足的問題
這通常是因為各個IP間該如何溝通 定義不清楚或是不完整
所以做系統驗證必須要對整個系統架構有足夠了解
當然 有人會認為做系統整合的工程師也可以做到這件事
某種程度上來說沒錯 只要系統整合的工程師是超人
以上工作內容都能吃下來的話
為了效率 另外找DV來做這件事
除了平行展開做事會比較快 專業分工也可以做得更深入
總結來說 DV的工作內容大概就是
1. 了解數位設計內容
2. 制訂驗證計畫
3. 建立自動化驗證環境並執行
以上是個人經驗分享
如果對驗證有興趣的話
可以找《SystemVerilog for Verification》這本書來參考看看
希望台灣的IC設計公司能多重視驗證一點...
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 123.195.203.107
※ 文章網址: https://www.ptt.cc/bbs/Tech_Job/M.1477695484.A.74C.html
推
10/29 07:25, , 1F
10/29 07:25, 1F
推
10/29 07:40, , 2F
10/29 07:40, 2F
推
10/29 07:50, , 3F
10/29 07:50, 3F
推
10/29 07:53, , 4F
10/29 07:53, 4F
推
10/29 07:58, , 5F
10/29 07:58, 5F
推
10/29 07:59, , 6F
10/29 07:59, 6F
→
10/29 08:00, , 7F
10/29 08:00, 7F
推
10/29 08:21, , 8F
10/29 08:21, 8F
推
10/29 08:23, , 9F
10/29 08:23, 9F
推
10/29 08:26, , 10F
10/29 08:26, 10F
推
10/29 08:38, , 11F
10/29 08:38, 11F
推
10/29 08:39, , 12F
10/29 08:39, 12F
推
10/29 08:39, , 13F
10/29 08:39, 13F
推
10/29 08:51, , 14F
10/29 08:51, 14F
→
10/29 08:53, , 15F
10/29 08:53, 15F
推
10/29 08:55, , 16F
10/29 08:55, 16F
推
10/29 09:01, , 17F
10/29 09:01, 17F
推
10/29 09:06, , 18F
10/29 09:06, 18F
推
10/29 09:10, , 19F
10/29 09:10, 19F
推
10/29 09:35, , 20F
10/29 09:35, 20F
→
10/29 09:35, , 21F
10/29 09:35, 21F
推
10/29 10:07, , 22F
10/29 10:07, 22F
推
10/29 10:21, , 23F
10/29 10:21, 23F
推
10/29 10:24, , 24F
10/29 10:24, 24F
推
10/29 10:33, , 25F
10/29 10:33, 25F
推
10/29 10:40, , 26F
10/29 10:40, 26F
→
10/29 10:42, , 27F
10/29 10:42, 27F
推
10/29 10:55, , 28F
10/29 10:55, 28F
推
10/29 11:06, , 29F
10/29 11:06, 29F
推
10/29 11:08, , 30F
10/29 11:08, 30F
推
10/29 11:09, , 31F
10/29 11:09, 31F
推
10/29 11:15, , 32F
10/29 11:15, 32F
→
10/29 13:04, , 33F
10/29 13:04, 33F
推
10/29 13:19, , 34F
10/29 13:19, 34F
推
10/29 13:24, , 35F
10/29 13:24, 35F
推
10/29 13:30, , 36F
10/29 13:30, 36F
推
10/29 13:30, , 37F
10/29 13:30, 37F
推
10/29 14:19, , 38F
10/29 14:19, 38F
推
10/29 15:59, , 39F
10/29 15:59, 39F
推
10/29 16:12, , 40F
10/29 16:12, 40F
推
10/29 17:02, , 41F
10/29 17:02, 41F
推
10/29 22:09, , 42F
10/29 22:09, 42F
→
10/29 22:10, , 43F
10/29 22:10, 43F
推
10/29 23:20, , 44F
10/29 23:20, 44F
推
10/30 07:17, , 45F
10/30 07:17, 45F
→
10/30 07:18, , 46F
10/30 07:18, 46F
→
10/30 07:19, , 47F
10/30 07:19, 47F
→
10/30 07:21, , 48F
10/30 07:21, 48F
→
10/30 07:22, , 49F
10/30 07:22, 49F
推
10/30 08:47, , 50F
10/30 08:47, 50F
推
10/30 08:50, , 51F
10/30 08:50, 51F
推
10/30 10:51, , 52F
10/30 10:51, 52F
推
10/31 05:52, , 53F
10/31 05:52, 53F
推
10/31 19:47, , 54F
10/31 19:47, 54F
討論串 (同標題文章)