gpt4 book ai didi

scala - CHISEL 中的列表查找

转载 作者:行者123 更新时间:2023-12-02 21:04:57 25 4
gpt4 key购买 nike

我是 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”的值是 bool 值还是其他值?

最佳答案

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

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

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

第三个参数是“key”->“value”元组的数组。 io.dat.inst 与键进行匹配以查找匹配项,如果找到匹配项,则将 csignals 设置为 value 部分.

所以 csignals 是 List() 类型。

关于scala - CHISEL 中的列表查找,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36612741/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com