基于SystemC的系統(tǒng)級(jí)芯片設(shè)計(jì)方法研究
為了支持寄存器傳輸級(jí)的并行描述,SystemC還采用了與傳統(tǒng)硬件描述語言基本相同的調(diào)度模型基于Δ(delta)延遲。一個(gè)Δ周期包括求值和更新2個(gè)階段,在一個(gè)時(shí)間點(diǎn)上,這樣的Δ周期會(huì)出現(xiàn)直到再求值前后的結(jié)果不再發(fā)生變化。而在宏觀上,時(shí)間并沒有前進(jìn)。SystemC 2.01調(diào)度模型中,在初始化階段(相當(dāng)于時(shí)間0點(diǎn)),所有進(jìn)程包括方法進(jìn)程和線程都將執(zhí)行一次。不同的是,在SystemC中,所有的信號(hào)和變量的初始化工作在構(gòu)造函數(shù)中進(jìn)行,他比其他函數(shù)先執(zhí)行,避免了像Verilog HDL中由于初始化順序不同引起的不同仿真器仿真結(jié)果的不一致。
本文引用地址:http://2s4d.com/article/83115.htm為了支持進(jìn)程同步和通信細(xì)化,SystemC支持用戶自定義的接口,端口和通道。接口是方法的集合,但不具體實(shí)現(xiàn)這些方法,在C++語法中,他們都是純虛函數(shù)。通道具體實(shí)現(xiàn)一個(gè)或者多個(gè)接口。端口定義了他能夠連接的具體的接口類型,只能被用于連接實(shí)現(xiàn)了該類型接口的通道。在有些情況下,進(jìn)程可以直接讀寫通道而不必通過端口,而其他情況下則必須通過端口進(jìn)程才能讀寫通道。
在SystemC中,進(jìn)程只調(diào)用通道提供的接口方法。雖然接口方法是在通道中實(shí)現(xiàn)的,然而他是在進(jìn)程上下文中被執(zhí)行的。這被稱作接口方法調(diào)用(InteRFaceMethodCall,IMC),接口方法調(diào)用和支持不同抽象級(jí)別的混合建模是通信細(xì)化的基礎(chǔ)。
4 基于SystemC的設(shè)計(jì)思想和設(shè)計(jì)流程
用SystemC可以在抽象層次的不同級(jí)描述系統(tǒng)。在系統(tǒng)最高層的系統(tǒng)級(jí)可以用C/C++描述系統(tǒng)的功能和算法。在系統(tǒng)的硬件實(shí)現(xiàn)部分可以在行為級(jí)到RTL級(jí)用SystemC 的類來描述,系統(tǒng)的軟件部分自然可以用C/C++語言描述。而且,系統(tǒng)的不同部分可以在不同的抽象層次描述,這些描述在系統(tǒng)仿真時(shí)可以協(xié)同工作。并且,用SystemC不但可以描述要開發(fā)的系統(tǒng)本身,還可以描述系統(tǒng)的測(cè)試平臺(tái)Testbench,以提供測(cè)試信號(hào)用于系統(tǒng)的仿真。
SystemC由一組描述類的頭文件和一個(gè)包含仿真核的連接庫Link Library所組成,在用戶的建模描述程序中必須包括相應(yīng)的頭文件,然后可以用通常的C++編譯器編譯該程序。在連接Link時(shí)要調(diào)用SystemC的連接庫產(chǎn)生可執(zhí)行的系統(tǒng)仿真程序。利用SystemC建模的思想如圖2所示。
基于SystemC的設(shè)計(jì)流程與以前的設(shè)計(jì)流程的本質(zhì)區(qū)別在于,使用一種語言就可以完成從系統(tǒng)到RTL、從軟件到硬件的全部設(shè)計(jì),整個(gè)設(shè)計(jì)的軟硬件可以協(xié)同設(shè)計(jì)和仿真,恰好彌補(bǔ)了傳統(tǒng)設(shè)計(jì)方法中的這些不足。
基于SystemC的設(shè)計(jì)流程如圖3所示。
5 應(yīng)用實(shí)例
下面給出一個(gè)基于SystemC設(shè)計(jì)的實(shí)例:RS(15,9)的設(shè)計(jì)詳細(xì)地說明整個(gè)設(shè)計(jì)流程。
RS(Reed-Solomon)[4]糾錯(cuò)碼是目前最有效、應(yīng)用最廣泛的差錯(cuò)控制編碼之一,是一類具有很強(qiáng)糾錯(cuò)能力的多進(jìn)制的線性分組碼,RS(15,9)碼編碼器,主要應(yīng)用于移動(dòng)通信系統(tǒng)的差錯(cuò)控制,由于該編碼器小巧、靈活,糾錯(cuò)性能好,對(duì)于移動(dòng)通信系統(tǒng)可靠性的提高、復(fù)雜度的降低有至關(guān)重要的作用[5]。整個(gè)系統(tǒng)如圖4所示。
整個(gè)設(shè)計(jì)從用SystemC為整個(gè)系統(tǒng)建模開始,同時(shí)為模塊建立Testbench。然后使用VC ++6.0和Modelsim進(jìn)行功能仿真,接著在SystemC可綜合子集的范圍內(nèi)對(duì)代碼進(jìn)行約束,使用支持SystemC的綜合工具SCC(SystemC Compiler)完成綜合,SystemC的綜合實(shí)際上還是靠綜合HDL語言文件得到的網(wǎng)表,而SCC這個(gè)工具是SystemC和HDL之間的一個(gè)橋梁,因此對(duì)于SystemC的綜合首先是將SystemC描述的RTL級(jí)電路通過SCC綜合,綜合的結(jié)果是生成相應(yīng)的Verilog文件,在這個(gè)轉(zhuǎn)變過程中,模塊的整體結(jié)構(gòu)被保存,如每一個(gè)sc _module被轉(zhuǎn)換成獨(dú)立的Verilog模塊,并存放在module_namev文件中;每一個(gè)進(jìn)程(SC_METHOD)被轉(zhuǎn)換成帶進(jìn)程名的always塊;變量和端口也以同樣的名字在Verilog文件中生成。因此,后續(xù)流程就與傳統(tǒng)設(shè)計(jì)語言設(shè)計(jì)的FPGA流程連接上了。
本文選用Xilinx的SPARTAN2系列的FPGA XC2S50PQ28對(duì)本設(shè)計(jì)進(jìn)行驗(yàn)證。軟件平臺(tái)主要使用的是Xilinx的集成開發(fā)環(huán)境ISE。其中第三方工具使用了綜合工具FPGA CompilerⅡ,布局布線工具選用的是ISE中的Webpack suite。
pic相關(guān)文章:pic是什么
c語言相關(guān)文章:c語言教程
c++相關(guān)文章:c++教程
評(píng)論