《電子技術應用》
您所在的位置:首頁 > EDA與制造 > 業界動態 > 芯片開發語言:Verilog在左,Chisel在右

芯片開發語言:Verilog在左,Chisel在右

2021-07-25
來源:半導體行業觀察
關鍵詞: Verilog Chisel 芯片

  老石按:在傳統的數字芯片開發里,絕大多數設計者都會使用諸如Verilog、VHDL或者SystemVerilog的硬件描述語言(HDL)對電路的行為和功能進行建模。但是在香山處理器里,團隊選擇使用Chisel作為主要開發語言。這是基于怎樣的考慮?

  Chisel是基于Scala這個函數式語言來擴展出來的,我們可以把它看做是一個用來描述電路的領域專用語言,它和Verilog還是有很大區別的。

事實上,我們自己也做過兩種語言的對比。在2016年,我們整個團隊開始決定用RISC-V去實現標簽化體系結構,也在那個時候開始接觸Chisel。最早的時候我們重用了UC伯克利開發了的名叫Rocket的開源內核。這是個順序執行的小核,我們在它上面加上了我們的標簽機制,這期間其實就有很多的一些開發體會。

微信圖片_20210725101543.png

  Rocket chip generator的系統架構圖

  前面提到我們的同學原來對Verilog很熟,但是用Chisel以后就會有一種愛不釋手的感覺。有好多的通信,特別是年輕的同學,他們都愿意去嘗試使用Chisel。有一個北大的研究生,他在做報告的時候講,你用了Chisel以后就再也回不去了。

  其實,我們自己還做過量化的評估。在2018年,我們團隊里有兩個本科生和一個工程師做過一個實驗。這個實驗是要開發一個L2 Cache,但是要集成到RISC-V的內核里。我們的工程師是用Verilog來開發的,他對Cache非常熟悉。他把OpenSPARC里面的Cache、還有Xilinx提供的Cache等等都研究過,代碼都讀得很透。所以他用Verilog開發,并且接到RISC-V里面去。當時他花了應該是6個星期開發,包括測試框架等等,一共寫了5000多行代碼。即便這樣,后面還是有一些問題和Bug。

  另外,我們當時有一位大四的本科生,現在也是香山的核心成員,他懂一些計算機體系結構,使用Chisel有9個月的時間。同樣的任務,他用Chisel開發只花了三天時間就寫出來了。把設計接到RISC-V核里面之后,還能夠正常工作。之后又進一步就把DMA調通了,就能夠支持像網卡這樣的一些DMA的數據的傳輸。這個給我們留下了很深刻的印象。

微信圖片_20210725101546.png

  表格來源:《芯片敏捷開發實踐:標簽化RISC-V》

  我們覺得,本科生使用Chisel做的設計,哪怕是性能或者各方面差了一些,但他只用了三天時間。這樣我們就可以快速去驗證,并且實現我們的想法。

  當然這個只是第一組實驗。我們當時有一個群,在群里面吵的還是挺不可開交的,因為我們的工程師那個時候很不服氣,他就覺得他的代碼各方面都質量更高。所以我們后來又有另外一位中國科學院大學的大四本科生,他懂Verilog、但是沒學過Chisel,所以他做的事情就是讀我們工程師的Verilog代碼,并把核心代碼一行一行翻譯成Chisel,最后要通過工程師寫的測試。也就是說,翻譯后的Chisel和Verilog實現的邏輯功能是完全一致的。

  翻譯完之后,再在同一個FPGA上面評估,看設計的PPA、 頻率、功耗,還有使用的資源等等。這樣下來的話,你就會看到其實出來的指標上面,大多數的指標實際都是Chisel還反而更好一些,代碼量也會比他要小。

  這還只是第一個階段。后面我們的本科生又在博士生的指導下,把Chisel里面的高級特性給它加進去,結果一下子就完全超越Verilog的版本了,代碼量大概只有Verilog的1/4~1/5,有些邏輯資源可以減少百分之六七十。所以那時候這組數據出來以后,工程師就他也覺得服氣了。

微信圖片_20210725101550.jpg

  表格來源:《芯片敏捷開發實踐:標簽化RISC-V》

  Chisel vs 高層次綜合

  老石按:在FPGA里高層綜合是一個非常熱、非常流行的一個研究方向。但是我知道Chisel和高層次綜合可能并不是一回事。在Chisel官網上也明確的指出:我不是高層次綜合。但在我看來,它們背后的思維方式、或者是大的方向是有共同之處的,也就是讓硬件開發更加的快速、更加敏捷。也就是像您剛才說的,從想法到實現,周期更加縮短。

  但是從高層綜合的角度來看,雖然學術界一直在講高層次綜合已經很多年的時間,它實際的商業化可能還是需要特別突破性的進展。現在業界的這些設計,比如大的網絡設計、還有數據中心加速器的這些設計,仍然是基于SystemVerilog/Verilog/VHDL這樣的RTL語言。這主要是因為高層次綜合有這么幾個問題:

  第一個就是HLS可能并不能覆蓋掉的全部應用領域,也就是說它可能適合于某些應用領域,但是對于這種吞吐量比較大的、或者高速數據包處理這些應用,它可能就不那么適合。

  另外一個就是它的驗證。因為它相當于在RTL頂上加了一層額外的高層次語言,等它綜合或者處理完了以后,還是生成底層的RTL語言,然后再走原來的FPGA的這些開發流程。所以在驗證過程中,增加額外的這層可能會給驗證工作造成很大的問題。所以關于這兩點您怎么看?

  我想其實它的通用性方面是沒有問題的。Chisel本身是一個硬件描述語言,所以從它的這種完備性來看的話,它跟Verilog是一樣的。也就是說,Verilog能干什么事,Chisel也能干什么事,這兩個是沒有什么區別的,它只不過是另外一種語法表達而已。

  調試是很多人都擔心的一個問題。因為Chisel它現在其實是一個源到源的翻譯,是首先是基于Scala這套語法去寫一個硬件的描述。然后通過FIRRTL進行翻譯。再往后走的話,其實是用Verilog那套流程去做,最后生成GDSII版圖。

  所以在這個過程當中,其實是明顯的分成兩個階段了。前面一個階段Chisel到Verilog,第二階段就是Verilog到GDSII版圖。

  我們用Chisel已經流過三顆芯片,有大的芯片、有的小的芯片,有單核的有8核的。在早期的時候,我們其實也遇到過這樣的一些問題。比如你用Chisel寫的代碼生成了Verilog,Verilog里面有一些變量,你那邊在Chisel里面改一行代碼,那它這個變量就全部重新改變。后來其實仔細分析以后,我們發現這些問題都是可以有一些辦法來解決的,或者說它不是阻礙可調試性的最根本的問題。所以后面我們在做香山的時候,我們在這些方面已經處理得比較好了。

  就像我們有同學,他自己開發了一個工具,可以把電路波形直接轉變成一個上層的高級的事件。這個時候他其實就用了Chisel和FIRRTL里面的特性。

  因為FIRRTL它有點像LLVM,它可以放很多的這樣自己設計的模塊,FIRRTL也可以定義自己需要的功能。這個在LLVM里叫pass,在FIRTEL里叫transformer。

  有了這些工具,就可以讓Chisel源碼和下面波形建立起聯系,讓調試的過程甚至比原來用Verilog還要方便。

  除了這個工具,同學們還自定義和擴展了一些printf,讓我們在調的時候很多時候根本不用去看波形。這些都得益于Chisel的強大和開放。




電子技術圖片.png

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品欧美在线| 亚洲精品国产精品国自产观看| 久久久中精品2020中文| 欧美一级黄色网| 亚洲香蕉在线观看| av成人免费在线| 一本色道久久综合精品竹菊| 亚洲精品麻豆| 亚洲人永久免费| 亚洲青色在线| 亚洲国产欧美日韩另类综合| 亚洲第一免费播放区| 亚洲高清免费在线| 亚洲第一在线视频| 久久精品视频播放| 亚洲黄色视屏| 日韩视频免费观看高清完整版| 亚洲欧洲一区二区在线播放| 亚洲国产精品www| 亚洲高清一二三区| 亚洲国产日韩欧美一区二区三区| 亚洲国产三级| 亚洲美女黄色| 亚洲一区二区精品在线| 亚洲欧美www| 久久99伊人| 久久三级福利| 欧美mv日韩mv国产网站| 欧美激情视频网站| 欧美午夜精品久久久久久久| 国产精品拍天天在线| 国产麻豆精品视频| 韩日精品在线| 亚洲精品123区| 夜夜嗨av一区二区三区四区 | 在线电影国产精品| 亚洲国产精品久久久久婷婷老年 | 99精品欧美一区二区三区综合在线| 在线视频亚洲| 欧美一区二区精品久久911| 久久精品视频在线播放| 日韩一区二区精品视频| 亚洲欧美精品在线观看| 久久久久久久一区二区三区| 免费成人高清| 国产精品进线69影院| 国产一区二区三区四区三区四| 尤物网精品视频| av成人老司机| 欧美一站二站| 夜夜爽夜夜爽精品视频| 欧美一区二区女人| 欧美成人精品三级在线观看| 欧美日韩在线综合| 国产一在线精品一区在线观看| 亚洲人精品午夜在线观看| 亚洲一区二区毛片| 亚洲第一搞黄网站| 亚洲婷婷综合色高清在线 | 久久久精品tv| 欧美日韩一二区| 国产中文一区二区| 亚洲美女啪啪| 欧美一级黄色录像| 在线视频你懂得一区| 久久久精品国产免费观看同学| 欧美区日韩区| 国内精品伊人久久久久av影院| 99re热这里只有精品视频| 欧美在线免费观看视频| 一区二区欧美日韩| 久久综合久色欧美综合狠狠| 欧美吻胸吃奶大尺度电影| 国产真实乱偷精品视频免| 日韩午夜在线电影| 亚洲国产精品尤物yw在线观看 | 亚洲盗摄视频| 亚洲欧美国产另类| 一本色道久久88亚洲综合88| 久久久久久久一区| 国产精品久久久久99| 亚洲国产精品va在线观看黑人| 亚洲一区二区三区777| 亚洲剧情一区二区| 久久人人爽国产| 国产精品视频一二| 日韩视频在线免费观看| 91久久在线观看| 久久精品国产96久久久香蕉| 欧美亚一区二区| 亚洲国产一成人久久精品| 欧美一区二区三区精品 | 午夜在线精品偷拍| 欧美日韩的一区二区| 一区在线观看| 性欧美videos另类喷潮| 亚洲自拍电影| 欧美日韩一区二区免费在线观看| 亚洲第一页在线| 亚洲国产精品激情在线观看| 久久av资源网| 国产精品一区免费在线观看| 国产精品99久久久久久有的能看 | 国产午夜精品福利| 亚洲亚洲精品在线观看 | 牛夜精品久久久久久久99黑人 | 久久阴道视频| 国产在线拍揄自揄视频不卡99 | 久久久之久亚州精品露出| 国产伦精品一区| 亚洲一区二区三区四区视频| 亚洲天堂偷拍| 欧美视频精品在线| 亚洲精品国产精品久久清纯直播 | 亚洲三级影片| 9久草视频在线视频精品| 欧美大胆a视频| 亚洲国产va精品久久久不卡综合| 亚洲高清激情| 欧美成人首页| 91久久精品网| 日韩亚洲精品视频| 欧美噜噜久久久xxx| 亚洲精品美女91| 在线一区二区三区四区| 欧美日韩精品免费在线观看视频| 亚洲人www| 在线视频日韩| 国产精品美女久久久免费| 亚洲视频福利| 欧美在线|欧美| 国产亚洲成av人片在线观看桃| 欧美一区二区精品在线| 久久亚洲精选| 亚洲国产二区| 一二三四社区欧美黄| 欧美日韩午夜精品| 亚洲视频导航| 久久国产精品99国产精| 国产综合一区二区| 亚洲欧洲在线观看| 欧美精选一区| 宅男精品导航| 久久久久久噜噜噜久久久精品| 激情久久久久久久| 日韩视频在线一区二区| 欧美视频精品在线观看| 亚洲综合日韩在线| 久久亚洲色图| 亚洲精品在线电影| 亚洲欧美视频一区| 国内精品免费在线观看| 亚洲美洲欧洲综合国产一区| 欧美特黄一级大片| 欧美一区二区啪啪| 欧美激情第9页| 中文av一区二区| 久久久久久综合| 最新国产乱人伦偷精品免费网站| 亚洲尤物影院| 激情婷婷久久| 中国成人亚色综合网站| 国产欧美日韩一区| 亚洲精品社区| 国产欧美一区二区三区久久| 亚洲黄色在线视频| 欧美视频网址| 久久国产欧美精品| 欧美日韩一区二区三区免费看| 亚洲欧洲av一区二区| 欧美激情按摩| 欧美亚洲一区二区三区| 欧美精品粉嫩高潮一区二区 | 久久久久久久综合狠狠综合| 亚洲精品一区在线观看香蕉| 欧美自拍偷拍| 亚洲美洲欧洲综合国产一区| 久久爱另类一区二区小说| 亚洲国产欧美在线人成| 午夜性色一区二区三区免费视频| 在线电影欧美日韩一区二区私密| 亚洲视频综合| 亚洲电影av| 欧美一区二区私人影院日本| 最新69国产成人精品视频免费| 久久精品欧洲| 一区二区三区日韩精品| 欧美**字幕| 性伦欧美刺激片在线观看| 欧美三级资源在线| 亚洲国产日韩欧美在线图片| 国产毛片一区二区| 在线亚洲伦理| 1024亚洲| 久久久中精品2020中文| 亚洲一级黄色av| 欧美日韩妖精视频| 亚洲人成绝费网站色www| 国产欧美一区视频| 亚洲一区二区在线免费观看|