在 CHISEL 中查找列表

bat*_*sin 2 scala chisel riscv

我是 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),... 
Run Code Online (Sandbox Code Playgroud)
  1. ListLookUp 在这里到底做了什么?
  2. 'csignals' 的值是布尔值还是其他值?

Chr*_*ris 5

ListLookUp 大致相当于switch()软件编程中的casez语句,或Verilog RTL 中的语句。

第一个参数 ( io.dat.inst) 是要匹配的信号。

如果没有匹配发生,第二个参数是默认值。

第三个参数是“键”->“值”元组的数组。该io.dat.inst是对键匹配找到匹配且csignals被设置为value如果发现匹配的一部分。

所以 csignals 是一个类型List()