subsystem: streamline toTile and fromTile attachment
This commit is contained in:
parent
ef3addee7b
commit
57edd7facf
@ -23,6 +23,9 @@ class PeripheryBus(params: PeripheryBusParams, val crossing: SubsystemClockCross
|
||||
private def bufferTo(buffer: BufferParams): TLOutwardNode =
|
||||
TLBuffer(buffer) :*= delayNode :*= outwardNode
|
||||
|
||||
private def bufferTo(buffers: Int): TLOutwardNode =
|
||||
TLBuffer.chain(buffers).foldRight(delayNode)(_ :*= _) :*= outwardNode
|
||||
|
||||
private def fragmentTo(minSize: Int, maxSize: Int, buffer: BufferParams): TLOutwardNode =
|
||||
TLFragmenter(minSize, maxSize) :*= bufferTo(buffer)
|
||||
|
||||
@ -94,10 +97,13 @@ class PeripheryBus(params: PeripheryBusParams, val crossing: SubsystemClockCross
|
||||
}
|
||||
|
||||
|
||||
def toTile(name: Option[String] = None)(gen: => TLNode): TLOutwardNode = {
|
||||
def toTile(
|
||||
name: Option[String] = None,
|
||||
buffers: Int = 0)
|
||||
(gen: => TLNode): TLOutwardNode = {
|
||||
to(s"Tile${name.getOrElse("")}") {
|
||||
FlipRendering { implicit p =>
|
||||
gen :*= delayNode :*= outwardNode
|
||||
gen :*= bufferTo(buffers)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -14,30 +14,8 @@ import freechips.rocketchip.interrupts._
|
||||
import freechips.rocketchip.util._
|
||||
|
||||
// TODO: how specific are these to RocketTiles?
|
||||
case class TileMasterPortParams(
|
||||
buffers: Int = 0,
|
||||
cork: Option[Boolean] = None)
|
||||
|
||||
case class TileSlavePortParams(
|
||||
addBuffers: Int = 0,
|
||||
blockerCtrlAddr: Option[BigInt] = None) {
|
||||
|
||||
def adapt(subsystem: HasPeripheryBus)
|
||||
(slaveNode: TLInwardNode)
|
||||
(implicit p: Parameters, sourceInfo: SourceInfo): TLInwardNode = {
|
||||
val tile_slave_blocker =
|
||||
blockerCtrlAddr
|
||||
.map(BasicBusBlockerParams(_, subsystem.pbus.beatBytes, subsystem.sbus.beatBytes))
|
||||
.map(bp => LazyModule(new BasicBusBlocker(bp)))
|
||||
|
||||
tile_slave_blocker.foreach { b =>
|
||||
subsystem.pbus.toVariableWidthSlave(Some("TileSlavePortBusBlocker")) { b.controlNode }
|
||||
}
|
||||
|
||||
(Seq() ++ tile_slave_blocker.map(_.node) ++ TLBuffer.chain(addBuffers))
|
||||
.foldLeft(slaveNode)(_ :*= _)
|
||||
}
|
||||
}
|
||||
case class TileMasterPortParams(buffers: Int = 0, cork: Option[Boolean] = None)
|
||||
case class TileSlavePortParams(buffers: Int = 0, blockerCtrlAddr: Option[BigInt] = None)
|
||||
|
||||
case class RocketCrossingParams(
|
||||
crossingType: SubsystemClockCrossing = SynchronousCrossing(),
|
||||
@ -87,7 +65,7 @@ trait HasRocketTiles extends HasTiles
|
||||
|
||||
def tileMasterBuffering: TLOutwardNode = rocket {
|
||||
// The buffers needed to cut feed-through paths are microarchitecture specific, so belong here
|
||||
val masterBuffer = LazyModule(new TLBuffer(BufferParams.none, BufferParams.flow, BufferParams.none, BufferParams.flow, BufferParams(1)))
|
||||
val masterBufferNode = TLBuffer(BufferParams.none, BufferParams.flow, BufferParams.none, BufferParams.flow, BufferParams(1))
|
||||
crossing.crossingType match {
|
||||
case _: AsynchronousCrossing => rocket.masterNode
|
||||
case SynchronousCrossing(b) =>
|
||||
@ -96,29 +74,40 @@ trait HasRocketTiles extends HasTiles
|
||||
case RationalCrossing(dir) =>
|
||||
require (dir != SlowToFast, "Misconfiguration? Core slower than fabric")
|
||||
if (tp.boundaryBuffers) {
|
||||
masterBuffer.node :=* rocket.masterNode
|
||||
masterBufferNode :=* rocket.masterNode
|
||||
} else {
|
||||
rocket.masterNode
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sbus.fromTile(tp.name, crossing.master.buffers, crossing.master.cork) {
|
||||
rocket.crossTLOut
|
||||
sbus.fromTile(tp.name, crossing.master.buffers) {
|
||||
crossing.master.cork
|
||||
.map { u => TLCacheCork(unsafe = u) }
|
||||
.map { _ :=* rocket.crossTLOut }
|
||||
.getOrElse { rocket.crossTLOut }
|
||||
} :=* tileMasterBuffering
|
||||
|
||||
// Connect the slave ports of the tile to the periphery bus
|
||||
|
||||
def tileSlaveBuffering: TLInwardNode = rocket {
|
||||
val slaveBuffer = LazyModule(new TLBuffer(BufferParams.flow, BufferParams.none, BufferParams.none, BufferParams.none, BufferParams.none))
|
||||
val slaveBufferNode = TLBuffer(BufferParams.flow, BufferParams.none, BufferParams.none, BufferParams.none, BufferParams.none)
|
||||
crossing.crossingType match {
|
||||
case RationalCrossing(_) if (tp.boundaryBuffers) => rocket.slaveNode :*= slaveBuffer.node
|
||||
case RationalCrossing(_) if (tp.boundaryBuffers) => rocket.slaveNode :*= slaveBufferNode
|
||||
case _ => rocket.slaveNode
|
||||
}
|
||||
}
|
||||
|
||||
DisableMonitors { implicit p =>
|
||||
tileSlaveBuffering :*= pbus.toTile(tp.name) { rocket.crossTLIn }
|
||||
tileSlaveBuffering :*= pbus.toTile(tp.name) {
|
||||
crossing.slave.blockerCtrlAddr
|
||||
.map { BasicBusBlockerParams(_, pbus.beatBytes, sbus.beatBytes) }
|
||||
.map { bbbp => LazyModule(new BasicBusBlocker(bbbp)) }
|
||||
.map { bbb =>
|
||||
pbus.toVariableWidthSlave(Some("TileSlavePortBusBlocker")) { bbb.controlNode }
|
||||
rocket.crossTLIn :*= bbb.node
|
||||
} .getOrElse { rocket.crossTLIn }
|
||||
}
|
||||
}
|
||||
|
||||
// Handle all the different types of interrupts crossing to or from the tile:
|
||||
|
@ -70,10 +70,8 @@ class SystemBus(params: SystemBusParams)(implicit p: Parameters) extends TLBusWr
|
||||
cork: Option[Boolean] = None)
|
||||
(gen: => TLNode): TLInwardNode = {
|
||||
from(s"Tile${name.getOrElse("")}") {
|
||||
(List(master_splitter.node, TLFIFOFixer(TLFIFOFixer.allUncacheable)) ++
|
||||
TLBuffer.chain(buffers) ++
|
||||
cork.map(u => TLCacheCork(unsafe = u))
|
||||
).reduce(_ :=* _) :=* gen
|
||||
(List(master_splitter.node, TLFIFOFixer(TLFIFOFixer.allUncacheable)) ++ TLBuffer.chain(buffers))
|
||||
.reduce(_ :=* _) :=* gen
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user