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),...
- ListLookUp 在这里到底做了什么?
- 'csignals' 的值是布尔值还是其他值?
ListLookUp 大致相当于软件编程中的一条switch()
语句,或Verilog RTL 中的一条casez
语句。
第一个参数 (io.dat.inst
) 是要匹配的信号。
如果没有匹配出现,第二个参数是默认值。
第三个参数是 "key"->"value" 元组的数组。 io.dat.inst
与键匹配以找到匹配项,如果找到匹配项,csignals
将设置为 value
部分。
所以 csignals 的类型是 List()
。
我是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 在这里到底做了什么?
- 'csignals' 的值是布尔值还是其他值?
ListLookUp 大致相当于软件编程中的一条switch()
语句,或Verilog RTL 中的一条casez
语句。
第一个参数 (io.dat.inst
) 是要匹配的信号。
如果没有匹配出现,第二个参数是默认值。
第三个参数是 "key"->"value" 元组的数组。 io.dat.inst
与键匹配以找到匹配项,如果找到匹配项,csignals
将设置为 value
部分。
所以 csignals 的类型是 List()
。