86 lines
1.7 KiB
Scala
86 lines
1.7 KiB
Scala
package rocket
|
|
package constants
|
|
|
|
import Chisel._
|
|
import scala.math._
|
|
|
|
trait ScalarOpConstants {
|
|
val SZ_BR = 3
|
|
val BR_X = Bits("b???", 3)
|
|
val BR_EQ = Bits(0, 3)
|
|
val BR_NE = Bits(1, 3)
|
|
val BR_J = Bits(2, 3)
|
|
val BR_N = Bits(3, 3)
|
|
val BR_LT = Bits(4, 3)
|
|
val BR_GE = Bits(5, 3)
|
|
val BR_LTU = Bits(6, 3)
|
|
val BR_GEU = Bits(7, 3)
|
|
|
|
val PC_EX = UInt(0, 2)
|
|
val PC_WB = UInt(2, 2)
|
|
val PC_PCR = UInt(3, 2)
|
|
|
|
val A1_X = Bits("b??", 2)
|
|
val A1_ZERO = UInt(0, 2)
|
|
val A1_RS1 = UInt(1, 2)
|
|
val A1_PC = UInt(2, 2)
|
|
|
|
val IMM_X = Bits("b???", 3)
|
|
val IMM_S = UInt(0, 3)
|
|
val IMM_SB = UInt(1, 3)
|
|
val IMM_U = UInt(2, 3)
|
|
val IMM_UJ = UInt(3, 3)
|
|
val IMM_I = UInt(4, 3)
|
|
val IMM_Z = UInt(5, 3)
|
|
|
|
val A2_X = Bits("b??", 2)
|
|
val A2_ZERO = UInt(0, 2)
|
|
val A2_FOUR = UInt(1, 2)
|
|
val A2_RS2 = UInt(2, 2)
|
|
val A2_IMM = UInt(3, 2)
|
|
|
|
val X = Bool.DC
|
|
val N = Bool(false)
|
|
val Y = Bool(true)
|
|
|
|
val NBYP = 4
|
|
val SZ_BYP = log2Up(NBYP)
|
|
val BYP_0 = 0
|
|
val BYP_EX = 1
|
|
val BYP_MEM = 2
|
|
val BYP_DC = 3
|
|
|
|
val SZ_DW = 1
|
|
val DW_X = X
|
|
val DW_32 = N
|
|
val DW_64 = Y
|
|
val DW_XPR = Y
|
|
|
|
val RA = UInt(1, 5)
|
|
}
|
|
|
|
trait VectorOpConstants {
|
|
val VEC_X = Bits("b??", 2).toUInt
|
|
val VEC_FN_N = UInt(0, 2)
|
|
val VEC_VL = UInt(1, 2)
|
|
val VEC_CFG = UInt(2, 2)
|
|
val VEC_CFGVL = UInt(3, 2)
|
|
|
|
val VCMD_I = UInt(0, 3)
|
|
val VCMD_F = UInt(1, 3)
|
|
val VCMD_TX = UInt(2, 3)
|
|
val VCMD_TF = UInt(3, 3)
|
|
val VCMD_MX = UInt(4, 3)
|
|
val VCMD_MF = UInt(5, 3)
|
|
val VCMD_A = UInt(6, 3)
|
|
val VCMD_X = UInt(0, 3)
|
|
|
|
val VIMM_VLEN = UInt(0, 1)
|
|
val VIMM_ALU = UInt(1, 1)
|
|
val VIMM_X = UInt(0, 1)
|
|
|
|
val VIMM2_RS2 = UInt(0, 1)
|
|
val VIMM2_ALU = UInt(1, 1)
|
|
val VIMM2_X = UInt(0, 1)
|
|
}
|