tile: BaseTile refactor, pt 2
* 2 layer cake * no more bundle traits, only call to IO
This commit is contained in:
		| @@ -32,7 +32,7 @@ trait HasTilesModuleImp extends LazyModuleImp | |||||||
|  |  | ||||||
|   def resetVectorBits: Int = { |   def resetVectorBits: Int = { | ||||||
|     // Consider using the minimum over all widths, rather than enforcing homogeneity |     // Consider using the minimum over all widths, rather than enforcing homogeneity | ||||||
|     val vectors = outer.tiles.map(_.module.io.reset_vector) |     val vectors = outer.tiles.map(_.module.constants.reset_vector) | ||||||
|     require(vectors.tail.forall(_.getWidth == vectors.head.getWidth)) |     require(vectors.tail.forall(_.getWidth == vectors.head.getWidth)) | ||||||
|     vectors.head.getWidth |     vectors.head.getWidth | ||||||
|   } |   } | ||||||
| @@ -45,8 +45,8 @@ trait HasTilesModuleImp extends LazyModuleImp | |||||||
|   outer.tiles.map(_.module).zip(tile_inputs).foreach { case(tile, wire) => |   outer.tiles.map(_.module).zip(tile_inputs).foreach { case(tile, wire) => | ||||||
|     tile.clock := wire.clock |     tile.clock := wire.clock | ||||||
|     tile.reset := wire.reset |     tile.reset := wire.reset | ||||||
|     tile.io.hartid := wire.hartid |     tile.constants.hartid := wire.hartid | ||||||
|     tile.io.reset_vector := wire.reset_vector |     tile.constants.reset_vector := wire.reset_vector | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -44,9 +44,9 @@ class GroundTestCoreplexModule[+L <: GroundTestCoreplex](_outer: L) extends Base | |||||||
|     with HasMasterAXI4MemPortModuleImp { |     with HasMasterAXI4MemPortModuleImp { | ||||||
|   val success = IO(Bool(OUTPUT)) |   val success = IO(Bool(OUTPUT)) | ||||||
|  |  | ||||||
|   outer.tiles.zipWithIndex.map { case(t, i) => t.module.io.hartid := UInt(i) } |   outer.tiles.zipWithIndex.map { case(t, i) => t.module.constants.hartid := UInt(i) } | ||||||
|  |  | ||||||
|   val status = DebugCombiner(outer.tiles.map(_.module.io.status)) |   val status = DebugCombiner(outer.tiles.map(_.module.status)) | ||||||
|   success := status.finished |   success := status.finished | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -39,15 +39,12 @@ abstract class GroundTestTile(params: GroundTestTileParams) | |||||||
|  |  | ||||||
|   val dcacheOpt = params.dcache.map { dc => LazyModule(new DCache(0)) } |   val dcacheOpt = params.dcache.map { dc => LazyModule(new DCache(0)) } | ||||||
|  |  | ||||||
|   override lazy val module = new GroundTestTileModule(this, () => new GroundTestTileBundle(this)) |   override lazy val module = new GroundTestTileModule(this) | ||||||
| } | } | ||||||
|  |  | ||||||
| class GroundTestTileBundle[+L <: GroundTestTile](_outer: L) extends BaseTileBundle(_outer) { | class GroundTestTileModule(outer: GroundTestTile) extends BaseTileModule(outer) { | ||||||
|   val status = new GroundTestStatus |   val status = IO(new GroundTestStatus) | ||||||
|   val halt_and_catch_fire = None |   val halt_and_catch_fire = None | ||||||
| } |  | ||||||
|  |  | ||||||
| class GroundTestTileModule[+L <: GroundTestTile, +B <: GroundTestTileBundle[L]](_outer: L, _io: () => B) extends BaseTileModule(_outer, _io) { |  | ||||||
|  |  | ||||||
|   outer.dcacheOpt foreach { dcache => |   outer.dcacheOpt foreach { dcache => | ||||||
|     val ptw = Module(new DummyPTW(1)) |     val ptw = Module(new DummyPTW(1)) | ||||||
|   | |||||||
| @@ -583,10 +583,10 @@ class TraceGenTile(val id: Int, val params: TraceGenParams)(implicit p: Paramete | |||||||
|   override lazy val module = new TraceGenTileModule(this) |   override lazy val module = new TraceGenTileModule(this) | ||||||
| } | } | ||||||
|  |  | ||||||
| class TraceGenTileModule(outer: TraceGenTile) extends GroundTestTileModule(outer, () => new GroundTestTileBundle(outer)) { | class TraceGenTileModule(outer: TraceGenTile) extends GroundTestTileModule(outer) { | ||||||
|  |  | ||||||
|   val tracegen = Module(new TraceGenerator(outer.params)) |   val tracegen = Module(new TraceGenerator(outer.params)) | ||||||
|   tracegen.io.hartid := io.hartid |   tracegen.io.hartid := constants.hartid | ||||||
|  |  | ||||||
|   outer.dcacheOpt foreach { dcache => |   outer.dcacheOpt foreach { dcache => | ||||||
|     val dcacheIF = Module(new SimpleHellaCacheIF()) |     val dcacheIF = Module(new SimpleHellaCacheIF()) | ||||||
| @@ -594,10 +594,10 @@ class TraceGenTileModule(outer: TraceGenTile) extends GroundTestTileModule(outer | |||||||
|     dcache.module.io.cpu <> dcacheIF.io.cache |     dcache.module.io.cpu <> dcacheIF.io.cache | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   io.status.finished := tracegen.io.finished |   status.finished := tracegen.io.finished | ||||||
|   io.status.timeout.valid := tracegen.io.timeout |   status.timeout.valid := tracegen.io.timeout | ||||||
|   io.status.timeout.bits := UInt(0) |   status.timeout.bits := UInt(0) | ||||||
|   io.status.error.valid := Bool(false) |   status.error.valid := Bool(false) | ||||||
|  |  | ||||||
|   assert(!tracegen.io.timeout, s"TraceGen tile ${outer.id}: request timed out") |   assert(!tracegen.io.timeout, s"TraceGen tile ${outer.id}: request timed out") | ||||||
| } | } | ||||||
|   | |||||||
| @@ -315,10 +315,6 @@ trait HasICacheFrontend extends CanHavePTW { this: BaseTile => | |||||||
|   nPTWPorts += 1 |   nPTWPorts += 1 | ||||||
| } | } | ||||||
|  |  | ||||||
| trait HasICacheFrontendBundle { |  | ||||||
|   val outer: HasICacheFrontend |  | ||||||
| } |  | ||||||
|  |  | ||||||
| trait HasICacheFrontendModule extends CanHavePTWModule { | trait HasICacheFrontendModule extends CanHavePTWModule { | ||||||
|   val outer: HasICacheFrontend |   val outer: HasICacheFrontend | ||||||
|   ptwPorts += outer.frontend.module.io.ptw |   ptwPorts += outer.frontend.module.io.ptw | ||||||
|   | |||||||
| @@ -194,7 +194,7 @@ class HellaCacheModule(outer: HellaCache) extends LazyModuleImp(outer) | |||||||
|  |  | ||||||
| /** Mix-ins for constructing tiles that have a HellaCache */ | /** Mix-ins for constructing tiles that have a HellaCache */ | ||||||
|  |  | ||||||
| trait HasHellaCache extends HasTileParameters { this: BaseTile => | trait HasHellaCache { this: BaseTile => | ||||||
|   val module: HasHellaCacheModule |   val module: HasHellaCacheModule | ||||||
|   implicit val p: Parameters |   implicit val p: Parameters | ||||||
|   def findScratchpadFromICache: Option[AddressSet] |   def findScratchpadFromICache: Option[AddressSet] | ||||||
| @@ -207,13 +207,8 @@ trait HasHellaCache extends HasTileParameters { this: BaseTile => | |||||||
|   tlMasterXbar.node := dcache.node |   tlMasterXbar.node := dcache.node | ||||||
| } | } | ||||||
|  |  | ||||||
| trait HasHellaCacheBundle { |  | ||||||
|   val outer: HasHellaCache |  | ||||||
| } |  | ||||||
|  |  | ||||||
| trait HasHellaCacheModule { | trait HasHellaCacheModule { | ||||||
|   val outer: HasHellaCache |   val outer: HasHellaCache | ||||||
|   //val io: HasHellaCacheBundle |  | ||||||
|   val dcachePorts = ListBuffer[HellaCacheIO]() |   val dcachePorts = ListBuffer[HellaCacheIO]() | ||||||
|   val dcacheArb = Module(new HellaCacheArbiter(outer.nDCachePorts)(outer.p)) |   val dcacheArb = Module(new HellaCacheArbiter(outer.nDCachePorts)(outer.p)) | ||||||
|   outer.dcache.module.io.cpu <> dcacheArb.io.mem |   outer.dcache.module.io.cpu <> dcacheArb.io.mem | ||||||
|   | |||||||
| @@ -287,8 +287,7 @@ class PTW(n: Int)(implicit edge: TLEdgeOut, p: Parameters) extends CoreModule()( | |||||||
| } | } | ||||||
|  |  | ||||||
| /** Mix-ins for constructing tiles that might have a PTW */ | /** Mix-ins for constructing tiles that might have a PTW */ | ||||||
| trait CanHavePTW extends HasHellaCache { this: BaseTile => | trait CanHavePTW extends HasTileParameters with HasHellaCache { this: BaseTile => | ||||||
|   implicit val p: Parameters |  | ||||||
|   val module: CanHavePTWModule |   val module: CanHavePTWModule | ||||||
|   var nPTWPorts = 1 |   var nPTWPorts = 1 | ||||||
|   nDCachePorts += usingPTW.toInt |   nDCachePorts += usingPTW.toInt | ||||||
|   | |||||||
| @@ -137,10 +137,6 @@ trait CanHaveScratchpad extends HasHellaCache with HasICacheFrontend { this: Bas | |||||||
|   nDCachePorts += (scratch.isDefined).toInt |   nDCachePorts += (scratch.isDefined).toInt | ||||||
| } | } | ||||||
|  |  | ||||||
| trait CanHaveScratchpadBundle extends HasHellaCacheBundle with HasICacheFrontendBundle { |  | ||||||
|   val outer: CanHaveScratchpad |  | ||||||
| } |  | ||||||
|  |  | ||||||
| trait CanHaveScratchpadModule extends HasHellaCacheModule with HasICacheFrontendModule { | trait CanHaveScratchpadModule extends HasHellaCacheModule with HasICacheFrontendModule { | ||||||
|   val outer: CanHaveScratchpad |   val outer: CanHaveScratchpad | ||||||
|  |  | ||||||
|   | |||||||
| @@ -121,35 +121,11 @@ trait HasTileParameters { | |||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| abstract class BareTile(implicit p: Parameters) extends LazyModule |  | ||||||
|  |  | ||||||
| abstract class BareTileBundle[+L <: BareTile](_outer: L) extends GenericParameterizedBundle(_outer) { |  | ||||||
|   val outer = _outer |  | ||||||
|   implicit val p = outer.p |  | ||||||
| } |  | ||||||
|  |  | ||||||
| abstract class BareTileModule[+L <: BareTile, +B <: BareTileBundle[L]](_outer: L, _io: () => B) extends LazyModuleImp(_outer) { |  | ||||||
|   val outer = _outer |  | ||||||
|   val io = IO(_io ()) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** Some other standard inputs */ |  | ||||||
| trait HasExternallyDrivenTileConstants extends Bundle with HasTileParameters { |  | ||||||
|   val hartid = UInt(INPUT, hartIdLen) |  | ||||||
|   val reset_vector = UInt(INPUT, resetVectorLen) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| trait CanHaveInstructionTracePort extends Bundle with HasTileParameters { |  | ||||||
|   val trace = tileParams.trace.option(Vec(tileParams.core.retireWidth, new TracedInstruction).asOutput) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** Base class for all Tiles that use TileLink */ | /** Base class for all Tiles that use TileLink */ | ||||||
| abstract class BaseTile( | abstract class BaseTile(tileParams: TileParams, val crossing: CoreplexClockCrossing) | ||||||
|   tileParams: TileParams, |                        (implicit p: Parameters) extends LazyModule with HasTileParameters with HasCrossing | ||||||
|   val crossing: CoreplexClockCrossing)(implicit p: Parameters) extends BareTile | { | ||||||
|     with HasTileParameters |   def module: BaseTileModule[BaseTile] | ||||||
|     with HasCrossing { |  | ||||||
|   def module: BaseTileModule[BaseTile, BaseTileBundle[BaseTile]] |  | ||||||
|   def masterNode: TLOutwardNode |   def masterNode: TLOutwardNode | ||||||
|   def slaveNode: TLInwardNode |   def slaveNode: TLInwardNode | ||||||
|   def intInwardNode: IntInwardNode |   def intInwardNode: IntInwardNode | ||||||
| @@ -195,16 +171,22 @@ abstract class BaseTile( | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| abstract class BaseTileBundle[+L <: BaseTile](_outer: L) extends BareTileBundle(_outer) | class BaseTileModule[+L <: BaseTile](val outer: L) extends LazyModuleImp(outer) with HasTileParameters { | ||||||
|     with HasExternallyDrivenTileConstants |  | ||||||
|     with CanHaveInstructionTracePort |  | ||||||
|     with CanHaltAndCatchFire |  | ||||||
|  |  | ||||||
| class BaseTileModule[+L <: BaseTile, +B <: BaseTileBundle[L]](_outer: L, _io: () => B) extends BareTileModule(_outer, _io) |  | ||||||
|     with HasTileParameters { |  | ||||||
|   require(xLen == 32 || xLen == 64) |   require(xLen == 32 || xLen == 64) | ||||||
|   require(paddrBits <= maxPAddrBits) |   require(paddrBits <= maxPAddrBits) | ||||||
|   require(resetVectorLen <= xLen) |   require(resetVectorLen <= xLen) | ||||||
|   require(resetVectorLen <= vaddrBitsExtended) |   require(resetVectorLen <= vaddrBitsExtended) | ||||||
|   require (log2Up(hartId + 1) <= hartIdLen, s"p(MaxHartIdBits) of $hartIdLen is not enough for hartid $hartId") |   require (log2Up(hartId + 1) <= hartIdLen, s"p(MaxHartIdBits) of $hartIdLen is not enough for hartid $hartId") | ||||||
|  |  | ||||||
|  |   val trace = tileParams.trace.option(IO(Vec(tileParams.core.retireWidth, new TracedInstruction).asOutput)) | ||||||
|  |   val constants = IO(new TileInputConstants) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** Some other non-tilelink but still standard inputs */ | ||||||
|  | trait HasExternallyDrivenTileConstants extends Bundle with HasTileParameters { | ||||||
|  |   val hartid = UInt(INPUT, hartIdLen) | ||||||
|  |   val reset_vector = UInt(INPUT, resetVectorLen) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class TileInputConstants(implicit val p: Parameters) extends ParameterizedBundle with HasExternallyDrivenTileConstants | ||||||
|   | |||||||
| @@ -875,11 +875,8 @@ class FPU(cfg: FPUParams)(implicit p: Parameters) extends FPUModule()(p) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| /** Mix-ins for constructing tiles that may have an FPU external to the core pipeline */ | /** Mix-in for constructing tiles that may have an FPU external to the core pipeline */ | ||||||
| trait CanHaveSharedFPU extends HasTileParameters | trait CanHaveSharedFPUModule[+L <: BaseTile] { this: BaseTileModule[L] => | ||||||
|  |  | ||||||
| trait CanHaveSharedFPUModule { |  | ||||||
|   val outer: CanHaveSharedFPU |  | ||||||
|   val fpuOpt = outer.tileParams.core.fpu.map(params => Module(new FPU(params)(outer.p))) |   val fpuOpt = outer.tileParams.core.fpu.map(params => Module(new FPU(params)(outer.p))) | ||||||
|   // TODO fpArb could go here instead of inside LegacyRoccComplex |   // TODO fpArb could go here instead of inside LegacyRoccComplex | ||||||
| } | } | ||||||
|   | |||||||
| @@ -77,10 +77,7 @@ class LazyRoCCModule(outer: LazyRoCC) extends LazyModuleImp(outer) { | |||||||
|  |  | ||||||
| /** Mixins for including RoCC **/ | /** Mixins for including RoCC **/ | ||||||
|  |  | ||||||
| trait HasLazyRoCC extends CanHaveSharedFPU with CanHavePTW { this: BaseTile => | trait HasLazyRoCC extends CanHavePTW { this: BaseTile => | ||||||
|   implicit val p: Parameters |  | ||||||
|   val module: HasLazyRoCCModule |  | ||||||
|  |  | ||||||
|   val roccs = p(BuildRoCC).zipWithIndex.map { case (accelParams, i) => |   val roccs = p(BuildRoCC).zipWithIndex.map { case (accelParams, i) => | ||||||
|     accelParams.generator(p.alterPartial({ |     accelParams.generator(p.alterPartial({ | ||||||
|       case RoccNPTWPorts => accelParams.nPTWPorts |       case RoccNPTWPorts => accelParams.nPTWPorts | ||||||
| @@ -93,10 +90,10 @@ trait HasLazyRoCC extends CanHaveSharedFPU with CanHavePTW { this: BaseTile => | |||||||
|   nDCachePorts += roccs.size |   nDCachePorts += roccs.size | ||||||
| } | } | ||||||
|  |  | ||||||
| trait HasLazyRoCCModule extends CanHaveSharedFPUModule | trait HasLazyRoCCModule[+L <: BaseTile with HasLazyRoCC] extends CanHaveSharedFPUModule[L] | ||||||
|   with CanHavePTWModule |     with CanHavePTWModule | ||||||
|   with HasCoreParameters { |     with HasCoreParameters { this: BaseTileModule[L] => | ||||||
|   val outer: HasLazyRoCC |  | ||||||
|   val roccCore = Wire(new RoCCCoreIO()(outer.p)) |   val roccCore = Wire(new RoCCCoreIO()(outer.p)) | ||||||
|  |  | ||||||
|   val buildRocc = outer.p(BuildRoCC) |   val buildRocc = outer.p(BuildRoCC) | ||||||
|   | |||||||
| @@ -56,27 +56,24 @@ class RocketTile( | |||||||
|   override lazy val module = new RocketTileModule(this) |   override lazy val module = new RocketTileModule(this) | ||||||
| } | } | ||||||
|  |  | ||||||
| class RocketTileBundle(outer: RocketTile) extends BaseTileBundle(outer) | class RocketTileModule(outer: RocketTile) extends BaseTileModule(outer) | ||||||
|     with CanHaltAndCatchFire { |     with HasLazyRoCCModule[RocketTile] | ||||||
|   val halt_and_catch_fire = outer.rocketParams.hcfOnUncorrectable.option(Bool(OUTPUT)) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| class RocketTileModule(outer: RocketTile) extends BaseTileModule(outer, () => new RocketTileBundle(outer)) |  | ||||||
|     with HasLazyRoCCModule |  | ||||||
|     with CanHaveScratchpadModule { |     with CanHaveScratchpadModule { | ||||||
|  |  | ||||||
|   val core = Module(p(BuildCore)(outer.p)) |   val core = Module(p(BuildCore)(outer.p)) | ||||||
|  |  | ||||||
|   val uncorrectable = RegInit(Bool(false)) |   val uncorrectable = RegInit(Bool(false)) | ||||||
|  |   val halt_and_catch_fire = outer.rocketParams.hcfOnUncorrectable.option(IO(Bool(OUTPUT))) | ||||||
|  |  | ||||||
|   outer.decodeCoreInterrupts(core.io.interrupts) // Decode the interrupt vector |   outer.decodeCoreInterrupts(core.io.interrupts) // Decode the interrupt vector | ||||||
|   outer.busErrorUnit.foreach { beu => core.io.interrupts.buserror.get := beu.module.io.interrupt } |   outer.busErrorUnit.foreach { beu => core.io.interrupts.buserror.get := beu.module.io.interrupt } | ||||||
|   core.io.hartid := io.hartid // Pass through the hartid |   core.io.hartid := constants.hartid // Pass through the hartid | ||||||
|   io.trace.foreach { _ := core.io.trace } |   trace.foreach { _ := core.io.trace } | ||||||
|   io.halt_and_catch_fire.foreach { _ := uncorrectable } |   halt_and_catch_fire.foreach { _ := uncorrectable } | ||||||
|   outer.frontend.module.io.cpu <> core.io.imem |   outer.frontend.module.io.cpu <> core.io.imem | ||||||
|   outer.frontend.module.io.reset_vector := io.reset_vector |   outer.frontend.module.io.reset_vector := constants.reset_vector | ||||||
|   outer.frontend.module.io.hartid := io.hartid |   outer.frontend.module.io.hartid := constants.hartid | ||||||
|   outer.dcache.module.io.hartid := io.hartid |   outer.dcache.module.io.hartid := constants.hartid | ||||||
|   dcachePorts += core.io.dmem // TODO outer.dcachePorts += () => module.core.io.dmem ?? |   dcachePorts += core.io.dmem // TODO outer.dcachePorts += () => module.core.io.dmem ?? | ||||||
|   fpuOpt foreach { fpu => core.io.fpu <> fpu.io } |   fpuOpt foreach { fpu => core.io.fpu <> fpu.io } | ||||||
|   core.io.ptw <> ptw.io.dpath |   core.io.ptw <> ptw.io.dpath | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user