版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
6.黑盒一、例化黑盒二、復制Verilog文件三、內(nèi)聯(lián)Verilog文件四、inout端口
目錄2一、例化黑盒3例化黑盒1.1背景Chisel的功能相對Verilog來說還不完善,設計人員在當前版本下無法實現(xiàn)的功能,就需要用Verilog來實現(xiàn)。向Chisel代碼提供用Verilog設計的電路的接口(Verilog)BlackBoxChisel接口Chisel接口4例化黑盒假設有一個外部的Verilog模塊,端口列表聲明如下:
按照Verilog的語法,例化代碼如下:
在Chisel模塊里例化另一個模塊,生成Verilog代碼時,端口名字里會增加“io_”。1.2例化黑盒Dutu0(.a(u0_a),.clk(u0_clk),.reset(u0_reset),.b(u0_b))5moduleDut(input[31:0]a,inputclk,inputreset,output[3:0]b)例化黑盒
倘若將上述Verilog模塊聲明成普通的Chisel模塊,然后直接例化使用,例化的Verilog代碼就會變成:
思考:這樣做在Chisel層面上會成功嗎?不允許模塊內(nèi)部連線為空Dutu0(.io_a(io_u0_a),.io_clk(io_u0_clk),.io_reset(io_u0_reset),
.io_b(io_u0_b))6classUseDutextendsModule{
valio=IO(newBundle{
valtoDut_a=Input(UInt(32.W))
valtoDut_b=Output(UInt(4.W))
})
valu0=Module(newDut)
u0.io.a:=io.toDut_a
u0.io.clk:=clock
u0.io.reset:=reset
io.toDut_b:=u0.io.b
}例化黑盒定義Dut類時,不繼承自Module,而繼承自BlackBox。無需給黑盒的端口名加上“io_”classDutextendsBlackBox{
valio=IO(newBundle{
vala=Input(UInt(32.W))
valclk=Input(Clock())
valreset=Input(Bool())
valb=Output(UInt(4.W))
})
}7例化黑盒
1.3
Map[String,Param]
BlackBox的構(gòu)造方法可以接收一個Map[String,Param]類型的參數(shù)。
作用:使得例化外部的Verilog模塊時具有配置模塊的“#(參數(shù)配置)”。映射的鍵固定是字符串類型,對應Verilog里聲明的參數(shù)名。映射的值對應傳入的配置參數(shù),可以是字符串,也可以是整數(shù)和浮點數(shù)。8importchisel3.experimental._
classDutextendsBlackBox(Map("DATA_WIDTH"->32,
"MODE"->"Sequential",
"RESET"->"Asynchronous")){
valio=IO(newBundle{
vala=Input(UInt(32.W))
valclk=Input(Clock())
valreset=Input(Bool())
valb=Output(UInt(4.W))
})
}例化黑盒實例
單例對象chisel3.experimental里定義了相應的隱式轉(zhuǎn)換,可以把BigInt、Int、Long、Double和String轉(zhuǎn)換成對應的Param類型9例化黑盒
1.4動態(tài)定義模塊的名字10classCoffeeextendsBlackBox{
valio=IO(newBundle{
valI=Input(UInt(32.W))
valO=Output(UInt(32.W))
})
overridedefdesiredName="Tea"
}
classSaltextendsModule{
valio=IO(newBundle{})
valdrink=Module(newCoffee)
overridedefdesiredName="SodiumMonochloride"
}使用重寫的desiredName方法將Salt改為SodiumMonochloride使用重寫的desiredName方法將Coffee改為Tea在轉(zhuǎn)成Verilog時的模塊名不使用定義的類名,而是使用重寫的desiredName方法的返回字符串二、復制Verilog文件11復制Verilog文件如果在黑盒類里混入這個特質(zhì),并且在src/main/resources文件夾里有對應的Verilog源文件,則在Chisel轉(zhuǎn)換成Verilog時,就會把Verilog文件一起復制到目標文件夾。2.1復制方式一chisel3.util包里有一個特質(zhì)HasBlackBoxResource12classDutextendsBlackBoxwithHasBlackBoxResource{
valio=IO(newBundle{
vala=Input(UInt(32.W))
valclk=Input(Clock())
valreset=Input(Bool())
valb=Output(UInt(4.W))
})
}
addResource("/dut.v")//注意路徑寫成"./dut.v"是不對的。
}復制Verilog文件。2.2實例方法的入?yún)⑹荲erilog文件的相對地址,即相對src/main/resources的地址13復制Verilog文件2.3復制方式二chisel3.util包里還有一個特質(zhì)HasBlackBoxPath如果在黑盒類里混入這個特質(zhì),并且在任意文件夾里有對應的Verilog源文件,那么在Chisel轉(zhuǎn)換成Verilog時,就會把Verilog文件一起復制到目標文件夾。14classDutextendsBlackBoxwithHasBlackBoxPath{
valio=IO(newBundle{
vala=Input(UInt(32.W))
valclk=Input(Clock())
valreset=Input(Bool())
valb=Output(UInt(4.W))
})
addPath("./src/main/scala/dut.v")
}復制Verilog文件2.4實例此時的路徑是相對于chisel-template這個工程文件夾的路徑,我們需要提供相對路徑或者全路徑。15三、內(nèi)聯(lián)Verilog文件16內(nèi)聯(lián)Verilog文件目標文件夾里就會生成一個單獨的Verilog文件,復制內(nèi)嵌的代碼。該方法適合小型Verilog設計!3.1內(nèi)聯(lián)Verilog文件
chisel3.util包里有一個特質(zhì)HasBlackBoxInline調(diào)用特質(zhì)里的方法:17setInline(blackBoxName:String,blackBoxInline:String)classDutextendsBlackBoxwithHasBlackBoxInline{
valio=IO(newBundle{
vala=Input(UInt(32.W))
valclk=Input(Clock())
valreset=Input(Bool())
valb=Output(UInt(4.W))
})
setInline("dut.v",
"""
|moduledut(input[31:0]a,
|inputclk,
|inputreset,
|output[3:0]b);
|……
|assignb=b_temp;
|endmodule
""".stripMargin)
}內(nèi)聯(lián)Verilog文件實例:
字符串中的“|”表示文件的邊界18四、inout端口19inout端口NOTE:要用“chisel3.experimental._”進行導入。4.1
inoutChisel目前只支持在黑盒中引入Verilog的inout端口。Bundle中使用“Analog(位寬)”聲明Analog類型的端口Verilog的inout端口編譯20classInoutIOextendsBundle{
vala=Analog(16.W)
valb=Input(UInt(16.W))
valsel=Input(Bool())
valc=Output(UInt(16.W))}
classInoutPortextendsBlackBoxwithHasBlackBoxInline{
valio=IO(newInoutIO)
setInline("InoutPort.v",
"""
|moduleInoutPort(inout[15:0]a,……output[15:0]c);
|assigna=sel?'bz:b;
|endmodule
""".stripMargin)
}
classMakeInoutextendsModule{
valio=IO(newInoutIO
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年佳木斯職業(yè)學院高職單招職業(yè)適應性測試參考題庫帶答案解析
- 2026年朔州職業(yè)技術學院高職單招職業(yè)適應性測試備考試題帶答案解析
- 2026年遼寧石化職業(yè)技術學院單招職業(yè)技能筆試備考試題帶答案解析
- 2026年長沙航空職業(yè)技術學院高職單招職業(yè)適應性考試備考試題帶答案解析
- 2026年鄭州科技學院單招職業(yè)技能筆試模擬試題帶答案解析
- 2026年浙江工業(yè)職業(yè)技術學院單招職業(yè)技能筆試備考試題帶答案解析
- 2025年茂名廣電集團人事類筆試及答案
- 2025年沙坪壩區(qū)人事考試及答案
- 2025年山東經(jīng)貿(mào)綜評筆試真題及答案
- Unit5FunClubsSectionAa-d課件人教版英語七年級上冊
- 有限空間大型污水井作業(yè)工崗位考試試卷及答案
- 車險組長年終工作總結(jié)
- 電商售后客服主管述職報告
- 2025昆明市呈貢區(qū)城市投資集團有限公司及下屬子公司第一批招聘(12人)筆試考試參考試題及答案解析
- 上海證券有限責任公司校招職位筆試歷年參考題庫附帶答案詳解
- 保安員冬季安全知識培訓課件
- 智慧園區(qū)項目合作協(xié)議書
- 遺體火化師招聘考核試卷及答案
- 2025年大學消防指揮專業(yè)題庫- 火災現(xiàn)場搜救與救援
- 2024-2025學年山東省聊城市臨清市七年級(上)期末數(shù)學試卷(含答案)
- GB/T 10454-2025包裝非危險貨物用柔性中型散裝容器
評論
0/150
提交評論