首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ListLookUp凿子

ListLookUp凿子
EN

Stack Overflow用户
提问于 2016-04-14 02:21:41
回答 1查看 556关注 0票数 2

我是Scala的新手,我一直试图理解RISC-V体系结构。我偶然发现了一段代码,我一直盯着它看了好几个小时,无法理解。

代码语言:javascript
运行
复制
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. “信号”的值是布尔值还是其他值?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-04-14 04:15:20

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

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

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

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

因此,信号是一种类型的List()

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36612741

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档