Support retirement width > 1 in CSR file
This commit is contained in:
parent
267394d3cc
commit
0266c1f76a
@ -98,7 +98,7 @@ class CSRFile(implicit conf: RocketConfiguration) extends Module
|
|||||||
val ptbr = UInt(OUTPUT, PADDR_BITS)
|
val ptbr = UInt(OUTPUT, PADDR_BITS)
|
||||||
val evec = UInt(OUTPUT, VADDR_BITS+1)
|
val evec = UInt(OUTPUT, VADDR_BITS+1)
|
||||||
val exception = Bool(INPUT)
|
val exception = Bool(INPUT)
|
||||||
val retire = Bool(INPUT)
|
val retire = UInt(INPUT, log2Up(1+conf.retireWidth))
|
||||||
val cause = UInt(INPUT, conf.xprlen)
|
val cause = UInt(INPUT, conf.xprlen)
|
||||||
val badvaddr_wen = Bool(INPUT)
|
val badvaddr_wen = Bool(INPUT)
|
||||||
val pc = UInt(INPUT, VADDR_BITS+1)
|
val pc = UInt(INPUT, VADDR_BITS+1)
|
||||||
|
@ -7,6 +7,7 @@ import Util._
|
|||||||
case class RocketConfiguration(tl: TileLinkConfiguration,
|
case class RocketConfiguration(tl: TileLinkConfiguration,
|
||||||
icache: ICacheConfig, dcache: DCacheConfig,
|
icache: ICacheConfig, dcache: DCacheConfig,
|
||||||
fpu: Boolean, rocc: Option[RocketConfiguration => RoCC] = None,
|
fpu: Boolean, rocc: Option[RocketConfiguration => RoCC] = None,
|
||||||
|
retireWidth: Int = 1,
|
||||||
vm: Boolean = true,
|
vm: Boolean = true,
|
||||||
fastLoadWord: Boolean = true,
|
fastLoadWord: Boolean = true,
|
||||||
fastLoadByte: Boolean = false,
|
fastLoadByte: Boolean = false,
|
||||||
@ -30,6 +31,7 @@ class Tile(resetSignal: Bool = null)(confIn: RocketConfiguration) extends Module
|
|||||||
implicit val icConf = confIn.icache
|
implicit val icConf = confIn.icache
|
||||||
implicit val dcConf = confIn.dcache.copy(reqtagbits = confIn.dcacheReqTagBits + log2Up(dcachePorts), databits = confIn.xprlen)
|
implicit val dcConf = confIn.dcache.copy(reqtagbits = confIn.dcacheReqTagBits + log2Up(dcachePorts), databits = confIn.xprlen)
|
||||||
implicit val conf = confIn.copy(dcache = dcConf)
|
implicit val conf = confIn.copy(dcache = dcConf)
|
||||||
|
require(conf.retireWidth == 1) // for now...
|
||||||
|
|
||||||
val io = new Bundle {
|
val io = new Bundle {
|
||||||
val tilelink = new TileLinkIO
|
val tilelink = new TileLinkIO
|
||||||
|
@ -109,17 +109,21 @@ object Split
|
|||||||
}
|
}
|
||||||
|
|
||||||
// a counter that clock gates most of its MSBs using the LSB carry-out
|
// a counter that clock gates most of its MSBs using the LSB carry-out
|
||||||
case class WideCounter(width: Int, inc: Bool = Bool(true))
|
case class WideCounter(width: Int, inc: UInt = UInt(1))
|
||||||
{
|
{
|
||||||
private val isWide = width >= 4
|
require(inc.getWidth > 0)
|
||||||
private val smallWidth = if (isWide) log2Up(width) else width
|
private val isWide = width > 2*inc.getWidth
|
||||||
|
private val smallWidth = if (isWide) inc.getWidth max log2Up(width) else width
|
||||||
private val small = Reg(init=UInt(0, smallWidth))
|
private val small = Reg(init=UInt(0, smallWidth))
|
||||||
private val nextSmall = small + UInt(1, smallWidth+1)
|
private val doInc = inc.orR
|
||||||
when (inc) { small := nextSmall(smallWidth-1,0) }
|
private val nextSmall =
|
||||||
|
if (inc.getWidth == 1) small + UInt(1, smallWidth+1)
|
||||||
|
else Cat(UInt(0,1), small) + inc
|
||||||
|
when (doInc) { small := nextSmall(smallWidth-1,0) }
|
||||||
|
|
||||||
private val large = if (isWide) {
|
private val large = if (isWide) {
|
||||||
val r = Reg(init=UInt(0, width - smallWidth))
|
val r = Reg(init=UInt(0, width - smallWidth))
|
||||||
when (inc && nextSmall(smallWidth)) { r := r + UInt(1) }
|
when (doInc && nextSmall(smallWidth)) { r := r + UInt(1) }
|
||||||
r
|
r
|
||||||
} else null
|
} else null
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user