[英]ListLookUp in CHISEL
我是Scala的新手,我一直在嘗試了解RISC-V架構。 我遇到了這段代碼,我已經盯着看了好幾個小時了,無法理解。
val csignals =
ListLookup(io.dat.inst,
List(N, BR_N , OP1_X , OP2_X , ALU_X , WB_X , REN_0, MEN_0, M_X , MT_X, CSR.N),
Array( /* val | BR | op1 | op2 | ALU | wb | rf | mem | mem | mask | csr */
/* inst | type | sel | sel | fcn | sel | wen | en | wr | type | cmd */
LW -> List(Y, BR_N , OP1_RS1, OP2_IMI , ALU_ADD , WB_MEM, REN_1, MEN_1, M_XRD, MT_W, CSR.N),
LB -> List(Y, BR_N , OP1_RS1, OP2_IMI , ALU_ADD , WB_MEM, REN_1, MEN_1, M_XRD, MT_B, CSR.N),
LBU -> List(Y, BR_N , OP1_RS1, OP2_IMI , ALU_ADD , WB_MEM, REN_1, MEN_1, M_XRD, MT_BU, CSR.N),...
ListLookUp大致等效於軟件編程中的switch()
語句,或Verilog RTL中的casez
語句。
第一個參數( io.dat.inst
)是要匹配的信號。
如果沒有匹配項,則第二個參數是默認值。
第三個參數是“鍵”->“值”元組的數組。 將io.dat.inst
與鍵進行匹配以找到匹配項,如果找到匹配項, csignals
信號設置為value
部分。
因此,csignals的類型為List()
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.