- 設(shè)計(jì)一個(gè)自己專用處理器該怎么完成?
為了實(shí)現(xiàn)定制指令(對(duì)原有指令集進(jìn)行擴(kuò)展),Cadence(Tensilica)設(shè)計(jì)了一種專用的描述語(yǔ)言:Tensilica Instruction Extension (TIE) language。由于Xtensa處理器有一個(gè)基本的架構(gòu)模板,使用TIE語(yǔ)言對(duì)它進(jìn)行擴(kuò)展是有一定的限制,不是說(shuō)你想做的指令和架構(gòu)改動(dòng)都能夠?qū)崿F(xiàn)。
Synopsys提供的工具直接就叫ASIP designer,ASIP(Application-Specific Processor)專用處理器設(shè)計(jì)工具。和Tensilica的可擴(kuò)展處理器不同,ASIP designer支持從零開始設(shè)計(jì)和實(shí)現(xiàn)一個(gè)專用處理器。相應(yīng)的,它比Tensilica可擴(kuò)展處理器有更高的靈活性。你可以非常自由的設(shè)計(jì)指令集和微結(jié)構(gòu),覆蓋從Extensible processor,到Application-specific uP/DSP,到Programmable datapath這樣一個(gè)更大的架構(gòu)空間,如下圖所示。這里也可以看出,這個(gè)工具的目標(biāo)并不是設(shè)計(jì)通用處理器。
轉(zhuǎn)自synopsys.com
下圖是這個(gè)工具完整的方法學(xué)。
轉(zhuǎn)自synopsys.com
它的輸入就是兩個(gè),算法(C/C++代碼)和處理器模型(Processor Model),輸出則是一個(gè)處理器相關(guān)的所有設(shè)計(jì)和工具鏈。從輸入到輸出的過(guò)程同樣是自動(dòng)化完成的。當(dāng)然,這個(gè)過(guò)程并不像看起來(lái)那么簡(jiǎn)單,處理器建模的門檻不低。而且,工具賦予你的靈活性越高,掌握這種工具的門檻也越高。ASIP designer的處理器建模需要使用一種專門的語(yǔ)言,即nML,對(duì)處理器的指令集和架構(gòu)進(jìn)行高層次建模;此外還需要很多和編譯器相關(guān)的設(shè)計(jì),(具體的信息大家可以訪問(wèn)synopsys網(wǎng)站)。所以,即使你能買得起,要玩好這套工具,還得具備兩個(gè)條件:第一,是你必須熟悉處理器架構(gòu)和編譯方面知識(shí);第二,是要學(xué)習(xí)這套建模語(yǔ)言和工具。
總的來(lái)說(shuō),如果你有專用處理器設(shè)計(jì)的需求,足夠的資金和學(xué)習(xí)的耐心,可以考慮引入這類輔助設(shè)計(jì)工具。在經(jīng)歷過(guò)一定的學(xué)習(xí)周期后,你不僅可以完成一個(gè)設(shè)計(jì),還能獲得快速、高效設(shè)計(jì)處理器的能力。
窮玩法
看了上面的介紹,你是不是也對(duì)“自動(dòng)”設(shè)計(jì)專用處理器的方法很眼饞呢?可惜,你可能沒有足夠的資金來(lái)購(gòu)買這樣的工具,或者是你的目標(biāo)收益還不值得做出這樣的投資。這種情況下,我建議你從開源的處理器(或者指令集)開始做你自己的專用處理器。其實(shí)這也算是廢話吧。所以還是得給個(gè)具體的例子,假設(shè)你想在RSIC-V的基礎(chǔ)上做定制處理器。RSIC-V是現(xiàn)在一個(gè)相對(duì)成熟的開源處理器指令,已經(jīng)有很多相關(guān)實(shí)現(xiàn)和非常活躍的社區(qū)。相信大家都聽說(shuō)過(guò),就不科普了。這里得說(shuō)明一下,我并沒有對(duì)RISC-V進(jìn)行過(guò)深入的研究和嘗試,以下的說(shuō)法基本上是紙上談兵,不對(duì)的地方請(qǐng)大家批評(píng)指正。
首先,你要好好學(xué)習(xí)一下RISC-V指令集手冊(cè)中的“Chapter 10 Extending RISC-V”,這里明確介紹了給RISC-V指令集增加指令的規(guī)則。
第二,在現(xiàn)有的RISC-V的硬件實(shí)現(xiàn)基礎(chǔ)上,增加新指令對(duì)應(yīng)的硬件??赡苄枰黾訉S玫?a href="http://m.1cnz.cn/tags/寄存器/" target="_blank">寄存器,運(yùn)算單元,pipeline寄存器,控制信號(hào)等等。或者,你可以按照新的指令集(假設(shè)叫“RISC-V++ ISA”)自己做完整的硬件實(shí)現(xiàn)。其實(shí)我覺得第二種方法還更靠譜一點(diǎn)。很多時(shí)候,修改別人的東西,要比自己做困難的多。
第三,在RISC-V原有的工具鏈(比如GNU或者LLVM的編譯器)基礎(chǔ)上做出修改,支持新的指令。相對(duì)來(lái)說(shuō),這項(xiàng)工作是有比較完善的規(guī)則的,只要按照編譯工具的規(guī)則就可以把新增的指令加進(jìn)去。當(dāng)然,如果你增加的指令比較特殊,比如是向量操作,那么工具鏈的設(shè)計(jì)會(huì)困難很多。這種情況下的一個(gè)選擇是在高級(jí)程序語(yǔ)言的編譯器中不增加對(duì)新指令的支持,這些新的指令以匯編或者intrinsic的方法實(shí)現(xiàn)。
最后,這套方法是不是也能支持在第二節(jié)中所說(shuō)的快速design space exploration呢?基本的思路也是差不多的。你可以先用基本指令集來(lái)仿真你的算法;根據(jù)profiling的結(jié)果(比如性能指標(biāo),指令效率,code size等)考慮對(duì)指令集進(jìn)行的修改;然后更新相應(yīng)的硬件實(shí)現(xiàn)和工具鏈,再編譯和仿真你的算法,并不斷迭代?,F(xiàn)在你實(shí)現(xiàn)這個(gè)過(guò)程沒有自動(dòng)化工具的幫忙,可能需要更長(zhǎng)的時(shí)間才能完成,特別是需要對(duì)功耗面積等implementation結(jié)果進(jìn)行優(yōu)化的情況。當(dāng)然,如果現(xiàn)在RSIC-V的生態(tài)中已經(jīng)有了輔助設(shè)計(jì)工具,那么可能情況會(huì)輕松一些。
這種方法看起來(lái)行的通,不過(guò)中間的坑非常多,要求你對(duì)基礎(chǔ)處理器(比如RISC-V)非常熟悉。適合那些已經(jīng)完整的做過(guò)RISC-V實(shí)現(xiàn)的玩家嘗試。否則,也許有的坑你根本過(guò)不去。
最后,我寫這篇文章并不是想鼓勵(lì)大家都自己做專用處理器,而是希望大家清楚做這件事情要付出的代價(jià)。
非常好我支持^.^
(0) 0%
不好我反對(duì)
(0) 0%
相關(guān)閱讀:
- [電子說(shuō)] 怎樣解決霍爾搖桿耗電量大的問(wèn)題?揭秘霍爾芯片的選型要求 2023-10-24
- [電子說(shuō)] Blackwell GB100能否在超級(jí)計(jì)算機(jī)和AI市場(chǎng)保持領(lǐng)先優(yōu)勢(shì)? 2023-10-24
- [電子說(shuō)] 淺析BUCK芯片在電路中的應(yīng)用及特點(diǎn) 2023-10-24
- [處理器/DSP] Codasip發(fā)布適用于定制計(jì)算的新一代RISC-V處理器系列產(chǎn)品 2023-10-24
- [電子說(shuō)] OTA語(yǔ)音芯片NV040C在智能電動(dòng)牙刷的應(yīng)用 2023-10-24
- [電子說(shuō)] 新思科技面向臺(tái)積公司N5A工藝技術(shù)推出領(lǐng)先的廣泛車規(guī)級(jí)IP組合 2023-10-24
- [電子說(shuō)] 使用半大馬士革工藝流程研究后段器件集成的工藝 2023-10-24
- [電子說(shuō)] 國(guó)產(chǎn)運(yùn)放和溫度傳感器介紹 2023-10-24
( 發(fā)表人:方泓翔 )