《電子技術應用》
您所在的位置:首頁 > 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亚洲国产精品_日韩亚洲一区二区
欧美色中文字幕| 国产精品色午夜在线观看| 亚洲午夜精品国产| 日韩网站在线观看| 亚洲三级国产| 亚洲经典自拍| 亚洲国产视频直播| 亚洲国产高清自拍| 久久精品99无色码中文字幕| 亚洲欧美制服另类日韩| 亚洲欧美日韩视频二区| 亚洲欧美日韩天堂一区二区| 亚洲欧美国产不卡| 亚洲综合社区| 亚洲欧美日韩国产综合| 香蕉视频成人在线观看| 久久国内精品视频| 亚洲激情第一区| 亚洲精选大片| 亚洲视频1区| 亚洲一区视频| 中文日韩电影网站| 亚洲在线成人精品| 亚洲欧美另类中文字幕| 香蕉久久夜色精品国产| 欧美一区二区三区四区在线| 欧美影视一区| 久热精品在线| 欧美日本一区二区三区| 欧美三级视频在线观看| 国产精品视频久久久| 国产亚洲毛片| 亚洲高清在线观看| 99精品欧美一区二区三区综合在线| 宅男精品视频| 午夜精品久久久久久| 久久激情综合| 夜夜嗨一区二区三区| 亚洲一区二区精品在线| 欧美一区二区三区在线观看| 久久久精品日韩| 欧美黄色aa电影| 国产精品久久久久久久电影 | 亚洲一区国产| 欧美在线电影| 欧美国产日韩二区| 国产精品青草久久| 尤物99国产成人精品视频| 亚洲久久在线| 欧美亚洲综合在线| 99在线精品观看| 欧美中文字幕在线| 欧美—级a级欧美特级ar全黄| 国产精品福利在线观看网址| 国产综合色产在线精品| 亚洲日本欧美在线| 午夜国产不卡在线观看视频| 亚洲欧洲另类| 欧美一级网站| 欧美极品色图| 国模一区二区三区| 99热精品在线| 亚洲国产精品123| 亚洲欧美日韩国产综合在线 | 午夜精品视频在线观看| 免费毛片一区二区三区久久久| 国产精品sss| 在线不卡a资源高清| 亚洲一区二区三区四区在线观看| 亚洲成人自拍视频| 午夜影院日韩| 欧美激情一区二区三区在线视频| 国产视频精品免费播放| 日韩一级二级三级| 亚洲国产cao| 欧美在线看片| 欧美性猛交视频| 亚洲黄色成人网| 久久精品国产亚洲高清剧情介绍| 亚洲免费一区二区| 欧美韩日一区二区三区| 韩国av一区| 亚洲欧美日本国产有色| 一区二区三区精品在线| 欧美bbbxxxxx| 一区在线播放| 性欧美激情精品| 性欧美大战久久久久久久免费观看| 欧美黄色精品| 一区二区在线看| 久久av一区| 欧美一级淫片aaaaaaa视频| 欧美日韩亚洲高清| 亚洲国产精品一区二区www在线 | 亚洲欧美在线磁力| 欧美视频手机在线| 最新高清无码专区| 亚洲人午夜精品免费| 久久久久综合网| 国产日韩欧美在线观看| 亚洲午夜精品国产| 亚洲已满18点击进入久久| 欧美日本一区| 亚洲精品久久久蜜桃| 亚洲国产三级在线| 狼人天天伊人久久| 黄色成人av网站| 久久成人资源| 久久视频免费观看| 韩国福利一区| 久久精品五月婷婷| 久久这里有精品15一区二区三区| 国产一区二区无遮挡| 性色av一区二区三区红粉影视| 香蕉成人久久| 国产欧美日韩专区发布| 午夜视频精品| 久久久久久久久久久久久久一区| 国产一区二区三区高清在线观看 | 久久成人一区二区| 久久蜜桃资源一区二区老牛| 黄色成人在线网站| 亚洲高清免费| 欧美aⅴ一区二区三区视频| 亚洲第一黄色网| 亚洲日本欧美天堂| 欧美激情欧美激情在线五月| 亚洲精品美女91| 一片黄亚洲嫩模| 欧美色另类天堂2015| 在线视频一区观看| 香蕉久久精品日日躁夜夜躁| 国产欧美精品久久| 欧美在线播放| 蜜桃久久精品一区二区| 亚洲日本aⅴ片在线观看香蕉| 国产精品99久久久久久久女警| 欧美午夜欧美| 亚洲欧美在线观看| 久久综合色8888| 亚洲精品日韩在线观看| 亚洲伊人久久综合| 国产日韩精品入口| 亚洲高清一二三区| 欧美精品久久天天躁| 一区二区不卡在线视频 午夜欧美不卡' | 亚洲一区二区在线视频| 欧美一区三区三区高中清蜜桃| 国产欧美日韩一区二区三区在线观看 | 国产精品久久久久av免费| 亚洲自啪免费| 久久久夜色精品亚洲| 亚洲国产精品成人一区二区| 亚洲视频中文字幕| 国产三区二区一区久久| 91久久精品日日躁夜夜躁欧美| 欧美人与性动交α欧美精品济南到| 中文精品99久久国产香蕉| 久久www成人_看片免费不卡| 影音先锋欧美精品| 亚洲午夜电影| 国际精品欧美精品| 一本色道久久88综合亚洲精品ⅰ | 欧美久久久久久久久| 亚洲一级免费视频| 久久婷婷成人综合色| 日韩一区二区精品葵司在线| 久久精品女人| 亚洲精品三级| 久久国产直播| 亚洲精品午夜| 久久久91精品国产| 999亚洲国产精| 久久天堂av综合合色| 亚洲美女一区| 久久婷婷色综合| 亚洲无亚洲人成网站77777| 免费成人性网站| 亚洲淫性视频| 欧美伦理一区二区| 欧美一区网站| 欧美午夜视频在线| 亚洲日本欧美在线| 国产婷婷一区二区| 亚洲午夜一区二区三区| 一色屋精品视频在线看| 午夜久久tv| 亚洲日本久久| 久久天天躁狠狠躁夜夜爽蜜月| 欧美高清在线一区二区| 免费在线观看日韩欧美| 亚洲素人在线| 欧美黄色大片网站| 久久经典综合| 国产伦理精品不卡| 亚洲色在线视频| 亚洲激情成人| 久久综合网色—综合色88| 亚洲欧美高清| 国产精品久久福利|