СписокПосмотреть в ДОЛОТО

Я новичок в 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 логическим или другим?

person batssassin    schedule 14.04.2016    source источник


Ответы (1)


ListLookUp примерно эквивалентен оператору switch() в программировании или оператору casez в Verilog RTL.

Первый аргумент (io.dat.inst) - это сигнал для сопоставления.

Второй аргумент - это значение по умолчанию, если совпадений нет.

Третий аргумент - это массив кортежей «ключ» -> «значение». io.dat.inst сопоставляется с ключами, чтобы найти совпадение, а csignals устанавливается на часть value, если совпадение найдено.

Итак, csignals имеет тип List().

person Chris    schedule 14.04.2016
comment
Следующая строка кода присутствовала после функции ListLookUp. [code] val (cs_val_inst: Bool) :: cs_br_type :: cs_op1_sel :: cs_op2_sel :: cs0 = csignals [/ code] Что именно здесь происходит? Я понимаю, что список создается с переменными cs_ *. - person batssassin; 14.04.2016
comment
Он сопоставляет отдельные элементы в списке справа с переменными слева. Это синтаксис Scala, о котором вы можете прочитать. - person Chris; 15.04.2016