48 lines
1.5 KiB
Scala
48 lines
1.5 KiB
Scala
// See LICENSE for license details.
|
|
package freechips.rocketchip.regmapper
|
|
|
|
import Chisel._
|
|
import chisel3.experimental._
|
|
import chisel3.{Input, Output}
|
|
import freechips.rocketchip.util.{AsyncResetRegVec, SimpleRegIO}
|
|
|
|
object DescribedReg {
|
|
import freechips.rocketchip.regmapper.RegFieldAccessType._
|
|
import freechips.rocketchip.regmapper.RegFieldWrType._
|
|
import freechips.rocketchip.regmapper.RegFieldRdAction._
|
|
|
|
def apply[T <: Data](
|
|
gen: => T,
|
|
name: String,
|
|
desc: String,
|
|
reset: Option[T],
|
|
access: RegFieldAccessType = RW,
|
|
wrType: Option[RegFieldWrType] = None,
|
|
rdAction: Option[RegFieldRdAction] = None,
|
|
volatile: Boolean = false,
|
|
enumerations: Map[BigInt, (String, String)] = Map()): (T, RegFieldDesc) = {
|
|
val rdesc = RegFieldDesc(name, desc, None, None,
|
|
access, wrType, rdAction, volatile, reset.map{_.litValue}, enumerations)
|
|
val reg = reset.map{i => RegInit(i)}.getOrElse(Reg(gen))
|
|
reg.suggestName(name + "_reg")
|
|
(reg, rdesc)
|
|
}
|
|
|
|
def async(
|
|
width: Int,
|
|
name: String,
|
|
desc: String,
|
|
reset: Int,
|
|
access: RegFieldAccessType = RW,
|
|
wrType: Option[RegFieldWrType] = None,
|
|
rdAction: Option[RegFieldRdAction] = None,
|
|
volatile: Boolean = false,
|
|
enumerations: Map[BigInt, (String, String)] = Map()): (SimpleRegIO, RegFieldDesc) = {
|
|
val rdesc = RegFieldDesc(name, desc, None, None,
|
|
access, wrType, rdAction, volatile, Some(reset), enumerations)
|
|
val reg = Module(new AsyncResetRegVec(w = width, init = reset))
|
|
reg.suggestName(name + "_reg")
|
|
(reg.io, rdesc)
|
|
}
|
|
}
|