Skip to content

Commit

Permalink
[subsystem] fix RTL for upstream rocket-chip
Browse files Browse the repository at this point in the history
  • Loading branch information
sequencer authored and cyyself committed Feb 21, 2024
1 parent eb3332c commit 69fb2f6
Show file tree
Hide file tree
Showing 15 changed files with 86 additions and 71 deletions.
8 changes: 4 additions & 4 deletions nix/t1/_sources/generated.json
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@
},
"rocket-chip": {
"cargoLocks": null,
"date": "2023-11-25",
"date": "2024-01-28",
"extract": null,
"name": "rocket-chip",
"passthru": null,
Expand All @@ -113,11 +113,11 @@
"name": null,
"owner": "chipsalliance",
"repo": "rocket-chip",
"rev": "b3fa8df9bfb3a6d5b1d57dc4a0633fc6028242ac",
"sha256": "sha256-hQcjdwIObdMLrmLaK/yGTdClbbGlVC61K/o6dehiHFU=",
"rev": "baa9f4523f846831f03761179c209fb633c68f8d",
"sha256": "sha256-kBfeLpliTc2cj3ZUNe1CUKj1qhpJBWglgcuXtuQVZco=",
"type": "github"
},
"version": "b3fa8df9bfb3a6d5b1d57dc4a0633fc6028242ac"
"version": "baa9f4523f846831f03761179c209fb633c68f8d"
},
"rocket-chip-inclusive-cache": {
"cargoLocks": null,
Expand Down
8 changes: 4 additions & 4 deletions nix/t1/_sources/generated.nix
Original file line number Diff line number Diff line change
Expand Up @@ -63,15 +63,15 @@
};
rocket-chip = {
pname = "rocket-chip";
version = "b3fa8df9bfb3a6d5b1d57dc4a0633fc6028242ac";
version = "baa9f4523f846831f03761179c209fb633c68f8d";
src = fetchFromGitHub {
owner = "chipsalliance";
repo = "rocket-chip";
rev = "b3fa8df9bfb3a6d5b1d57dc4a0633fc6028242ac";
rev = "baa9f4523f846831f03761179c209fb633c68f8d";
fetchSubmodules = false;
sha256 = "sha256-hQcjdwIObdMLrmLaK/yGTdClbbGlVC61K/o6dehiHFU=";
sha256 = "sha256-kBfeLpliTc2cj3ZUNe1CUKj1qhpJBWglgcuXtuQVZco=";
};
date = "2023-11-25";
date = "2024-01-28";
};
rocket-chip-inclusive-cache = {
pname = "rocket-chip-inclusive-cache";
Expand Down
1 change: 1 addition & 0 deletions rocket/src/AbstractT1.scala
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,7 @@ trait HasLazyT1Module { this: RocketTileModuleImp =>
// TODO: make it configurable
val maxCount: Int = 32
val vlMax: Int = 1024
val xLen: Int = 32

val instructionQueue: Option[Queue[VectorRequest]] =
core.t1Request.map(req => Module(new Queue(chiselTypeOf(req.bits), maxCount)))
Expand Down
9 changes: 5 additions & 4 deletions rocket/src/CSR.scala
Original file line number Diff line number Diff line change
Expand Up @@ -231,9 +231,9 @@ class CSRDecodeIO(implicit p: Parameters) extends CoreBundle {
val virtualSystemIllegal = Output(Bool())
}

class CSRFileIO(implicit p: Parameters) extends CoreBundle with HasCoreParameters {
class CSRFileIO(hasBeu: Boolean)(implicit p: Parameters) extends CoreBundle with HasCoreParameters {
val ungatedClock = Input(Clock())
val interrupts = Input(new CoreInterrupts())
val interrupts = Input(new CoreInterrupts(hasBeu))
val hartid = Input(UInt(hartIdLen.W))
val rw = new Bundle {
val addr = Input(UInt(CSR.ADDRSZ.W))
Expand Down Expand Up @@ -287,14 +287,15 @@ class CSRFileIO(implicit p: Parameters) extends CoreBundle with HasCoreParameter
*/
class CSRFile(
perfEventSets: EventSets = new EventSets(Seq()),
customCSRs: Seq[CustomCSR] = Nil
customCSRs: Seq[CustomCSR] = Nil,
hasBeu: Boolean
)(
implicit p: Parameters)
extends CoreModule()(p)
with HasCoreParameters {
val vector = Option.when(usingVector)(new csr.V(vLen, usingHypervisor))

val io = IO(new CSRFileIO {
val io = IO(new CSRFileIO(hasBeu) {
val customCSRs = Vec(CSRFile.this.customCSRs.size, new CustomCSRIO)
})

Expand Down
6 changes: 3 additions & 3 deletions rocket/src/DCache.scala
Original file line number Diff line number Diff line change
Expand Up @@ -82,8 +82,8 @@ class DCacheMetadataReq(implicit p: Parameters) extends L1HellaCacheBundle()(p)
val data = UInt(cacheParams.tagCode.width(new L1Metadata().getWidth).W)
}

class DCache(staticIdForMetadataUseOnly: Int, val crossing: ClockCrossingType)(implicit p: Parameters)
extends HellaCache(staticIdForMetadataUseOnly)(p) {
class DCache(val crossing: ClockCrossingType)(implicit p: Parameters)
extends HellaCache()(p) {
override lazy val module = new DCacheModule(this)
}

Expand Down Expand Up @@ -640,7 +640,7 @@ class DCacheModule(outer: DCache) extends HellaCacheModule(outer) {
val atomics = if (edge.manager.anySupportLogical) {
MuxLookup(
s2_req.cmd,
WireDefault(0.U.asTypeOf(new TLBundleA(edge.bundle))),
WireDefault(0.U.asTypeOf(new TLBundleA(edge.bundle))))(
Array(
M_XA_SWAP -> edge.Logical(a_source, access_address, a_size, a_data, TLAtomics.SWAP)._2,
M_XA_XOR -> edge.Logical(a_source, access_address, a_size, a_data, TLAtomics.XOR)._2,
Expand Down
6 changes: 3 additions & 3 deletions rocket/src/Frontend.scala
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,10 @@ class FrontendIO(implicit p: Parameters) extends CoreBundle()(p) {
val progress = Output(Bool())
}

class Frontend(val icacheParams: ICacheParams, staticIdForMetadataUseOnly: Int)(implicit p: Parameters)
class Frontend(val icacheParams: ICacheParams)(implicit p: Parameters)
extends LazyModule {
lazy val module = new FrontendModule(this)
val icache = LazyModule(new ICache(icacheParams, staticIdForMetadataUseOnly))
val icache = LazyModule(new ICache(icacheParams))
val masterNode = icache.masterNode
val slaveNode = icache.slaveNode
val resetVectorSinkNode = BundleBridgeSink[UInt](Some(() => UInt(masterNode.edges.out.head.bundle.addressBits.W)))
Expand Down Expand Up @@ -418,7 +418,7 @@ class FrontendModule(outer: Frontend)
/** Mix-ins for constructing tiles that have an ICache-based pipeline frontend */
trait HasICacheFrontend extends CanHavePTW { this: BaseTile =>
val module: HasICacheFrontendModule
val frontend = LazyModule(new Frontend(tileParams.icache.get, staticIdForMetadataUseOnly))
val frontend = LazyModule(new Frontend(tileParams.icache.get))
tlMasterXbar.node := TLWidthWidget(tileParams.icache.get.rowBits / 8) := frontend.masterNode
connectTLSlave(frontend.slaveNode, tileParams.core.fetchBytes)
frontend.icache.hartIdSinkNodeOpt.foreach { _ := hartIdNexusNode }
Expand Down
8 changes: 4 additions & 4 deletions rocket/src/HellaCache.scala
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,7 @@ class HellaCacheIO(implicit p: Parameters) extends CoreBundle()(p) {

/** Base classes for Diplomatic TL2 HellaCaches */

abstract class HellaCache(staticIdForMetadataUseOnly: Int)(implicit p: Parameters)
abstract class HellaCache()(implicit p: Parameters)
extends LazyModule
with HasNonDiplomaticTileParameters {
protected val cfg = tileParams.dcache.get
Expand All @@ -155,7 +155,7 @@ abstract class HellaCache(staticIdForMetadataUseOnly: Int)(implicit p: Parameter
.getOrElse(
Seq(
TLMasterParameters.v1(
name = s"Core ${staticIdForMetadataUseOnly} DCache",
name = s"Core DCache",
sourceId = IdRange(0, 1.max(cfg.nMSHRs)),
supportsProbe = TransferSizes(cfg.blockBytes, cfg.blockBytes)
)
Expand All @@ -164,7 +164,7 @@ abstract class HellaCache(staticIdForMetadataUseOnly: Int)(implicit p: Parameter

protected def mmioClientParameters = Seq(
TLMasterParameters.v1(
name = s"Core ${staticIdForMetadataUseOnly} DCache MMIO",
name = s"Core DCache MMIO",
sourceId = IdRange(firstMMIO, firstMMIO + cfg.nMMIOs),
requestFifo = true
)
Expand Down Expand Up @@ -234,7 +234,7 @@ case object BuildHellaCache extends Field[BaseTile => Parameters => HellaCache](
object HellaCacheFactory {
def apply(tile: BaseTile)(p: Parameters): HellaCache = {
assert(tile.tileParams.dcache.get.nMSHRs == 0)
new DCache(tile.staticIdForMetadataUseOnly, tile.crossing)(p)
new DCache(tile.crossing)(p)
}
}

Expand Down
5 changes: 2 additions & 3 deletions rocket/src/ICache.scala
Original file line number Diff line number Diff line change
Expand Up @@ -77,9 +77,8 @@ class ICacheErrors(implicit p: Parameters) extends CoreBundle()(p) with HasL1ICa
* There will always be one way(the last way) used for I$, which cannot be allocated to ITIM.
*
* @param icacheParams parameter to this I$.
* @param staticIdForMetadataUseOnly metadata used for hart id.
*/
class ICache(val icacheParams: ICacheParams, val staticIdForMetadataUseOnly: Int)(implicit p: Parameters)
class ICache(val icacheParams: ICacheParams)(implicit p: Parameters)
extends LazyModule {
lazy val module = new ICacheModule(this)

Expand Down Expand Up @@ -111,7 +110,7 @@ class ICache(val icacheParams: ICacheParams, val staticIdForMetadataUseOnly: Int
clients = Seq(
TLMasterParameters.v1(
sourceId = IdRange(0, 1 + icacheParams.prefetch.toInt), // 0=refill, 1=hint
name = s"Core ${staticIdForMetadataUseOnly} ICache"
name = s"ICache"
)
),
requestFields = useVM.option(Seq()).getOrElse(Seq(AMBAProtField()))
Expand Down
34 changes: 21 additions & 13 deletions rocket/src/RocketCore.scala
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ package org.chipsalliance.t1.rocketcore
import chisel3._
import chisel3.util._
import chisel3.util.experimental.decode.DecodeBundle
import freechips.rocketchip.tile.TileInterrupts
import freechips.rocketchip.util._
import org.chipsalliance.cde.config.{Field, Parameters}
import org.chipsalliance.t1.rockettile.{VectorRequest, VectorResponse}
Expand All @@ -14,7 +15,7 @@ import scala.collection.mutable.ArrayBuffer

// TODO: remove it.
import freechips.rocketchip.rocket.{Causes, MulDivParams, RocketCoreParams}
import freechips.rocketchip.tile.{CoreInterrupts, FPUCoreIO, HasCoreParameters}
import freechips.rocketchip.tile.{FPUCoreIO, HasCoreParameters}

trait HasRocketCoreParameters extends HasCoreParameters {
lazy val rocketParams: RocketCoreParams = tileParams.core.asInstanceOf[RocketCoreParams]
Expand All @@ -30,8 +31,13 @@ trait HasRocketCoreParameters extends HasCoreParameters {
require(!rocketParams.haveFSDirty, "rocket doesn't support setting fs dirty from outside, please disable haveFSDirty")
require(!usingConditionalZero, "Zicond is not yet implemented in ABLU")
}
class CoreInterrupts(val hasBeu: Boolean)(implicit p: Parameters) extends TileInterrupts()(p) {
val buserror = Option.when(hasBeu)(Bool())
}

class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with HasRocketCoreParameters {
class Rocket(flushOnFenceI: Boolean, hasBeu: Boolean)(implicit val p: Parameters)
extends Module
with HasRocketCoreParameters {
// Checker
require(decodeWidth == 1 /* TODO */ && retireWidth == decodeWidth)
require(!(coreParams.useRVE && coreParams.fpu.nonEmpty), "Can't select both RVE and floating-point")
Expand Down Expand Up @@ -105,14 +111,14 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
case _ => true
}.toSeq.distinct,
pipelinedMul,
tile.dcache.flushOnFenceI
flushOnFenceI
)
)
val lgNXRegs: Int = if (coreParams.useRVE) 4 else 5
val regAddrMask: Int = (1 << lgNXRegs) - 1

val hartid = IO(Input(UInt(hartIdLen.W)))
val interrupts = IO(Input(new CoreInterrupts()))
val interrupts = IO(Input(new CoreInterrupts(hasBeu)))
val imem = IO(new FrontendIO)
val dmem = IO(new HellaCacheIO)
val ptw = IO(Flipped(new DatapathPTWIO()))
Expand Down Expand Up @@ -214,7 +220,7 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
// instantiate modules
// TODO: remove implicit parameter for them.

val csr: CSRFile = Module(new CSRFile(perfEvents, coreParams.customCSRs.decls))
val csr: CSRFile = Module(new CSRFile(perfEvents, coreParams.customCSRs.decls, hasBeu))

// TODO: move to Parameter Level or LazyModule level.
/** Decoder instantiated, input from IF, output to ID. */
Expand Down Expand Up @@ -522,7 +528,7 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
exRegDecodeOutput(decoder.memCommand) := M_HFENCEV
}

if (tile.dcache.flushOnFenceI) {
if (flushOnFenceI) {
when(idDecodeOutput(decoder.fenceI)) {
exRegMemSize := 0.U
}
Expand Down Expand Up @@ -770,9 +776,11 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
val wbSetSboard: Bool =
wbDcacheMiss ||
Option.when(usingMulDiv)(wbRegDecodeOutput(decoder.div)).getOrElse(false.B) ||
Option.when(usingVector){
wbRegDecodeOutput(decoder.wxd) && wbRegDecodeOutput(decoder.vector) && !wbRegDecodeOutput(decoder.vectorCSR)
}.getOrElse(false.B)
Option
.when(usingVector) {
wbRegDecodeOutput(decoder.wxd) && wbRegDecodeOutput(decoder.vector) && !wbRegDecodeOutput(decoder.vectorCSR)
}
.getOrElse(false.B)
val replayWbCommon: Bool = dmem.s2_nack || wbRegReplay
val replayWbCsr: Bool = wbRegValid && csr.io.rwStall
val replayWb: Bool = replayWbCommon || replayWbCsr
Expand Down Expand Up @@ -980,15 +988,15 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
}

// vector stall
val vectorLSUEmpty: Option[Bool] = Option.when(usingVector)(Wire(Bool()))
val vectorLSUEmpty: Option[Bool] = Option.when(usingVector)(Wire(Bool()))
val vectorQueueFull: Option[Bool] = Option.when(usingVector)(Wire(Bool()))
val vectorStall: Option[Bool] = Option.when(usingVector) {
val vectorLSUNotClear =
(exRegValid && exRegDecodeOutput(decoder.vectorLSU)) ||
(memRegValid && memRegDecodeOutput(decoder.vectorLSU)) ||
(wbRegValid && wbRegDecodeOutput(decoder.vectorLSU)) || !vectorLSUEmpty.get
(idDecodeOutput(decoder.vector) && vectorQueueFull.get) ||
(idDecodeOutput(decoder.mem) && !idDecodeOutput(decoder.vector) && vectorLSUNotClear)
(idDecodeOutput(decoder.mem) && !idDecodeOutput(decoder.vector) && vectorLSUNotClear)
}

val ctrlStalld: Bool =
Expand Down Expand Up @@ -1096,7 +1104,7 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
val maxCount: Int = 32
val countWidth = log2Up(maxCount)

def counterManagement(size: Int, margin: Int = 0)(grant: Bool, release: Bool, flush: Option[Bool]=None) = {
def counterManagement(size: Int, margin: Int = 0)(grant: Bool, release: Bool, flush: Option[Bool] = None) = {
val counter: UInt = RegInit(0.U(size.W))
val nextCount = counter + Mux(grant, 1.U(size.W), (-1.S(size.W)).asUInt)
val updateCounter = grant ^ release
Expand All @@ -1110,7 +1118,7 @@ class Rocket(tile: RocketTile)(implicit val p: Parameters) extends Module with H
(empty, full)
}
// Maintain lsu counter
val lsuGrant: Bool = t1.valid && wbRegDecodeOutput(decoder.vectorLSU)
val lsuGrant: Bool = t1.valid && wbRegDecodeOutput(decoder.vectorLSU)
val lsuRelease: Bool = response.fire && response.bits.mem
val (lsuEmpty, _) = counterManagement(countWidth)(lsuGrant, lsuRelease)
// Maintain vector counter
Expand Down
20 changes: 11 additions & 9 deletions rocket/src/RocketTile.scala
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import freechips.rocketchip.devices.tilelink._
import freechips.rocketchip.diplomacy._
import freechips.rocketchip.interrupts._
import freechips.rocketchip.prci.ClockSinkParameters
import freechips.rocketchip.subsystem.{CanAttachTile, RocketCrossingParams, TileCrossingParamsLike}
import freechips.rocketchip.subsystem.{CanAttachTile, RocketCrossingParams, HierarchicalElementCrossingParamsLike}
import freechips.rocketchip.tile._
import freechips.rocketchip.tilelink._
import freechips.rocketchip.util._
Expand All @@ -31,15 +31,17 @@ case class RocketTileParams(
btb: Option[BTBParams] = Some(BTBParams()),
dataScratchpadBytes: Int = 0,
name: Option[String] = Some("tile"),
hartId: Int = 0,
tileId: Int = 0,
beuAddr: Option[BigInt] = None,
blockerCtrlAddr: Option[BigInt] = None,
clockSinkParams: ClockSinkParameters = ClockSinkParameters(),
boundaryBuffers: Option[RocketTileBoundaryBufferParams] = None)
extends InstantiableTileParams[RocketTile] {
require(icache.isDefined)
require(dcache.isDefined)
def instantiate(crossing: TileCrossingParamsLike, lookup: LookupByHartIdImpl)(implicit p: Parameters): RocketTile = {
val baseName = "rockettile"
val uniqueName = s"${baseName}_$tileId"
def instantiate(crossing: HierarchicalElementCrossingParamsLike, lookup: LookupByHartIdImpl)(implicit p: Parameters): RocketTile = {
new RocketTile(this, crossing, lookup)
}
}
Expand All @@ -58,14 +60,14 @@ class RocketTile private (
// Private constructor ensures altered LazyModule.p is used implicitly
def this(
params: RocketTileParams,
crossing: TileCrossingParamsLike,
crossing: HierarchicalElementCrossingParamsLike,
lookup: LookupByHartIdImpl
)(
implicit p: Parameters
) =
this(params, crossing.crossingType, lookup, p)

val intOutwardNode = IntIdentityNode()
val intOutwardNode = rocketParams.beuAddr map { _ => IntIdentityNode() }
val slaveNode = TLIdentityNode()
val masterNode = visibilityNode

Expand All @@ -84,7 +86,7 @@ class RocketTile private (

val bus_error_unit = rocketParams.beuAddr.map { a =>
val beu = LazyModule(new BusErrorUnit(new L1BusErrors, BusErrorUnitParams(a)))
intOutwardNode := beu.intNode
intOutwardNode.get := beu.intNode
connectTLSlave(beu.node, xBytes)
beu
}
Expand Down Expand Up @@ -121,7 +123,7 @@ class RocketTile private (
}

ResourceBinding {
Resource(cpuDevice, "reg").bind(ResourceAddress(staticIdForMetadataUseOnly))
Resource(cpuDevice, "reg").bind(ResourceAddress(tileId))
}

override lazy val module = new RocketTileModuleImp(this)
Expand Down Expand Up @@ -150,7 +152,7 @@ class RocketTileModuleImp(outer: RocketTile)
with HasICacheFrontendModule {
Annotated.params(this, outer.rocketParams)

lazy val core = Module(new Rocket(outer)(outer.p))
lazy val core = Module(new Rocket(outer.dcache.flushOnFenceI, outer.bus_error_unit.isDefined)(outer.p))

// Report unrecoverable error conditions; for now the only cause is cache ECC errors
outer.reportHalt(List(outer.dcache.module.io.errors))
Expand All @@ -175,7 +177,7 @@ class RocketTileModuleImp(outer: RocketTile)
beu.module.io.errors.icache := outer.frontend.module.io.errors
}

core.interrupts.nmi.foreach { nmi => nmi := outer.nmiSinkNode.bundle }
core.interrupts.nmi.foreach { nmi => nmi := outer.nmiSinkNode.get.bundle }

// Pass through various external constants and reports that were bundle-bridged into the tile
core.traceStall := outer.traceAuxSinkNode.bundle.stall
Expand Down
Loading

0 comments on commit 69fb2f6

Please sign in to comment.