add vortex cache temporarily
This commit is contained in:
@@ -23,22 +23,8 @@ case class RocketTileBoundaryBufferParams(force: Boolean = false)
|
||||
|
||||
case class VortexTileParams(
|
||||
core: RocketCoreParams = RocketCoreParams(),
|
||||
icache: Option[ICacheParams] = Some(ICacheParams(
|
||||
nSets = 64,
|
||||
nWays = 4,
|
||||
rowBits = 128,
|
||||
nTLBSets = 1,
|
||||
nTLBWays = 32,
|
||||
nTLBBasePageSectors = 4,
|
||||
nTLBSuperpages = 4,
|
||||
cacheIdBits = 0,
|
||||
blockBytes = 64,
|
||||
latency = 2,
|
||||
fetchBytes = 4
|
||||
)),
|
||||
dcache: Option[DCacheParams] = Some(DCacheParams(
|
||||
// TODO
|
||||
)),
|
||||
icache: Option[ICacheParams] = None /* Some(ICacheParams()) */,
|
||||
dcache: Option[DCacheParams] = None /* Some(DCacheParams()) */,
|
||||
btb: Option[BTBParams] = None, // Some(BTBParams()),
|
||||
dataScratchpadBytes: Int = 0,
|
||||
name: Option[String] = Some("vortex_tile"),
|
||||
@@ -48,8 +34,12 @@ case class VortexTileParams(
|
||||
clockSinkParams: ClockSinkParameters = ClockSinkParameters(),
|
||||
boundaryBuffers: Option[RocketTileBoundaryBufferParams] = None
|
||||
) extends InstantiableTileParams[VortexTile] {
|
||||
require(icache.isDefined)
|
||||
require(dcache.isDefined)
|
||||
// require(icache.isDefined)
|
||||
// require(dcache.isDefined)
|
||||
require(icache.isDefined == dcache.isDefined)
|
||||
|
||||
def useVxCache: Boolean = !icache.isDefined;
|
||||
|
||||
def instantiate(crossing: TileCrossingParamsLike, lookup: LookupByHartIdImpl)(implicit p: Parameters): VortexTile = {
|
||||
new VortexTile(this, crossing, lookup)
|
||||
}
|
||||
@@ -111,8 +101,24 @@ class VortexTile private(
|
||||
))
|
||||
)))}
|
||||
|
||||
imemNodes.foreach { tlMasterXbar.node := _ }
|
||||
dmemNodes.foreach { tlMasterXbar.node := _ }
|
||||
val memNode = TLClientNode(Seq(TLMasterPortParameters.v1(
|
||||
clients = Seq(TLMasterParameters.v1(
|
||||
sourceId = IdRange(0, 1 << 10), // TODO magic number
|
||||
name = s"Vortex Core ${vortexParams.hartId} Mem Interface",
|
||||
requestFifo = true,
|
||||
supportsProbe = TransferSizes(1, lazyCoreParamsView.coreDataBytes),
|
||||
supportsGet = TransferSizes(1, lazyCoreParamsView.coreDataBytes),
|
||||
supportsPutFull = TransferSizes(1, lazyCoreParamsView.coreDataBytes),
|
||||
supportsPutPartial = TransferSizes(1, lazyCoreParamsView.coreDataBytes)
|
||||
))
|
||||
)))
|
||||
|
||||
if (vortexParams.useVxCache) {
|
||||
tlMasterXbar.node := memNode
|
||||
} else {
|
||||
imemNodes.foreach { tlMasterXbar.node := _ }
|
||||
dmemNodes.foreach { tlMasterXbar.node := _ }
|
||||
}
|
||||
|
||||
val bus_error_unit = vortexParams.beuAddr map { a =>
|
||||
val beu = LazyModule(new BusErrorUnit(new L1BusErrors, BusErrorUnitParams(a)))
|
||||
@@ -172,7 +178,7 @@ class VortexTileModuleImp(outer: VortexTile) extends BaseTileModuleImp(outer) {
|
||||
Annotated.params(this, outer.vortexParams)
|
||||
|
||||
val core = Module(new Vortex(outer)(outer.p))
|
||||
|
||||
|
||||
core.io.clock := clock
|
||||
core.io.reset := reset
|
||||
|
||||
@@ -201,31 +207,37 @@ class VortexTileModuleImp(outer: VortexTile) extends BaseTileModuleImp(outer) {
|
||||
require(core.io.hartid.getWidth >= outer.hartIdSinkNode.bundle.getWidth,
|
||||
s"core hartid wire (${core.io.hartid.getWidth}b) truncates external hartid wire (${outer.hartIdSinkNode.bundle.getWidth}b)")
|
||||
|
||||
(core.io.imem zip outer.imemNodes).foreach { case (coreMem, tileNode) =>
|
||||
coreMem.d <> tileNode.out.head._1.d
|
||||
coreMem.a <> tileNode.out.head._1.a
|
||||
if (outer.vortexParams.useVxCache) {
|
||||
core.io.mem.get.a <> outer.memNode.out.head._1.a
|
||||
core.io.mem.get.d <> outer.memNode.out.head._1.d
|
||||
}
|
||||
else {
|
||||
(core.io.imem.get zip outer.imemNodes).foreach { case (coreMem, tileNode) =>
|
||||
coreMem.d <> tileNode.out.head._1.d
|
||||
coreMem.a <> tileNode.out.head._1.a
|
||||
}
|
||||
|
||||
val arb = Module(new RRArbiter(core.io.dmem.head.d.bits.source.cloneType, 4))
|
||||
val matchingSources = Wire(UInt(4.W))
|
||||
val dmemDs = outer.dmemNodes.map(_.out.head._1.d)
|
||||
val arb = Module(new RRArbiter(core.io.dmem.get.head.d.bits.source.cloneType, 4))
|
||||
val matchingSources = Wire(UInt(4.W))
|
||||
val dmemDs = outer.dmemNodes.map(_.out.head._1.d)
|
||||
|
||||
(arb.io.in zip dmemDs).zipWithIndex.foreach { case ((arbIn, tileNode), i) =>
|
||||
arbIn.valid := tileNode.valid
|
||||
arbIn.bits := tileNode.bits.source
|
||||
// assert(arbIn.ready, "source id arbiter should always be ready")
|
||||
}
|
||||
matchingSources := dmemDs.map(d => (d.bits.source === arb.io.out.bits) && arb.io.out.valid).asUInt
|
||||
arb.io.out.ready := true.B
|
||||
(arb.io.in zip dmemDs).zipWithIndex.foreach { case ((arbIn, tileNode), i) =>
|
||||
arbIn.valid := tileNode.valid
|
||||
arbIn.bits := tileNode.bits.source
|
||||
// assert(arbIn.ready, "source id arbiter should always be ready")
|
||||
}
|
||||
matchingSources := dmemDs.map(d => (d.bits.source === arb.io.out.bits) && arb.io.out.valid).asUInt
|
||||
arb.io.out.ready := true.B
|
||||
|
||||
(core.io.dmem zip dmemDs).zipWithIndex.foreach { case ((coreMem, tileNode), i) =>
|
||||
coreMem.d.bits := tileNode.bits
|
||||
coreMem.d.valid := tileNode.valid && matchingSources(i)
|
||||
tileNode.ready := coreMem.d.ready && matchingSources(i)
|
||||
}
|
||||
(core.io.dmem.get zip dmemDs).zipWithIndex.foreach { case ((coreMem, tileNode), i) =>
|
||||
coreMem.d.bits := tileNode.bits
|
||||
coreMem.d.valid := tileNode.valid && matchingSources(i)
|
||||
tileNode.ready := coreMem.d.ready && matchingSources(i)
|
||||
}
|
||||
|
||||
(core.io.dmem zip outer.dmemNodes).foreach { case (coreMem, tileNode) =>
|
||||
coreMem.a <> tileNode.out.head._1.a
|
||||
(core.io.dmem.get zip outer.dmemNodes).foreach { case (coreMem, tileNode) =>
|
||||
coreMem.a <> tileNode.out.head._1.a
|
||||
}
|
||||
}
|
||||
|
||||
core.io.fpu := DontCare
|
||||
|
||||
Reference in New Issue
Block a user