簡體   English   中英

CHISEL中的ListLookUp

[英]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),... 
  1. ListLookUp到底在這里做什么?
  2. 'csignals'的值是布爾型還是其他?

ListLookUp大致等效於軟件編程中的switch()語句,或Verilog RTL中的casez語句。

第一個參數( io.dat.inst )是要匹配的信號。

如果沒有匹配項,則第二個參數是默認值。

第三個參數是“鍵”->“值”元組的數組。 io.dat.inst與鍵進行匹配以找到匹配項,如果找到匹配項, csignals信號設置為value部分。

因此,csignals的類型為List()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM