2016-11-28 01:16:37 +01:00
|
|
|
// See LICENSE.SiFive for license details.
|
|
|
|
// See LICENSE.Berkeley for license details.
|
2014-09-13 03:06:41 +02:00
|
|
|
|
2012-03-25 00:56:59 +01:00
|
|
|
package rocket
|
|
|
|
|
|
|
|
import Chisel._
|
2017-01-17 03:24:08 +01:00
|
|
|
import config._
|
|
|
|
import coreplex._
|
2016-10-27 04:02:04 +02:00
|
|
|
import diplomacy._
|
2016-09-03 00:59:16 +02:00
|
|
|
import uncore.converters._
|
2016-06-28 22:15:39 +02:00
|
|
|
import uncore.devices._
|
2017-01-17 03:24:08 +01:00
|
|
|
import uncore.tilelink2._
|
2016-09-28 06:27:07 +02:00
|
|
|
import util._
|
2012-03-25 00:56:59 +01:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
class RocketTile(val c: RocketConfig)(implicit p: Parameters) extends BaseTile()(p)
|
|
|
|
with CanHaveLegacyRoccs // implies CanHaveSharedFPU with CanHavePTW with HasHellaCache
|
|
|
|
with CanHaveScratchpad { // implies CanHavePTW with HasHellaCache with HasICacheFrontend
|
2015-12-02 02:54:56 +01:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
nDCachePorts += 1 // core TODO dcachePorts += () => module.core.io.dmem ??
|
2014-08-08 21:23:02 +02:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
override lazy val module = new RocketTileModule(this)
|
|
|
|
}
|
2016-11-11 22:07:45 +01:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
class RocketTileBundle(outer: RocketTile) extends BaseTileBundle(outer)
|
|
|
|
with CanHaveScratchpadBundle
|
|
|
|
|
|
|
|
class RocketTileModule(outer: RocketTile) extends BaseTileModule(outer, () => new RocketTileBundle(outer))
|
|
|
|
with CanHaveLegacyRoccsModule
|
|
|
|
with CanHaveScratchpadModule {
|
|
|
|
|
|
|
|
val core = Module(p(BuildCore)(outer.c, outer.p))
|
|
|
|
core.io.interrupts := io.interrupts
|
|
|
|
core.io.hartid := io.hartid
|
|
|
|
outer.frontend.module.io.cpu <> core.io.imem
|
|
|
|
outer.frontend.module.io.resetVector := io.resetVector
|
|
|
|
dcachePorts += core.io.dmem // TODO outer.dcachePorts += () => module.core.io.dmem ??
|
|
|
|
fpuOpt foreach { fpu => core.io.fpu <> fpu.io }
|
|
|
|
ptwOpt foreach { ptw => core.io.ptw <> ptw.io.dpath }
|
|
|
|
outer.legacyRocc foreach { lr =>
|
|
|
|
lr.module.io.core.cmd <> core.io.rocc.cmd
|
|
|
|
lr.module.io.core.exception := core.io.rocc.exception
|
|
|
|
core.io.rocc.resp <> lr.module.io.core.resp
|
|
|
|
core.io.rocc.busy := lr.module.io.core.busy
|
|
|
|
core.io.rocc.interrupt := lr.module.io.core.interrupt
|
2016-11-21 21:19:33 +01:00
|
|
|
}
|
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
// TODO figure out how to move the below into their respective mix-ins
|
|
|
|
require(dcachePorts.size == core.dcacheArbPorts)
|
|
|
|
dcacheArb.io.requestor <> dcachePorts
|
|
|
|
ptwOpt foreach { ptw => ptw.io.requestor <> ptwPorts }
|
|
|
|
}
|
2016-11-11 00:56:42 +01:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
class AsyncRocketTile(c: RocketConfig)(implicit p: Parameters) extends LazyModule {
|
|
|
|
val rocket = LazyModule(new RocketTile(c))
|
2016-11-30 01:34:26 +01:00
|
|
|
|
2017-01-17 03:24:08 +01:00
|
|
|
val masterNodes = rocket.masterNodes.map(_ => TLAsyncOutputNode())
|
|
|
|
val slaveNode = rocket.slaveNode.map(_ => TLAsyncInputNode())
|
|
|
|
|
|
|
|
(rocket.masterNodes zip masterNodes) foreach { case (r,n) => n := TLAsyncCrossingSource()(r) }
|
|
|
|
(rocket.slaveNode zip slaveNode) foreach { case (r,n) => r := TLAsyncCrossingSink()(n) }
|
2016-11-30 01:34:26 +01:00
|
|
|
|
2016-11-11 00:56:42 +01:00
|
|
|
lazy val module = new LazyModuleImp(this) {
|
|
|
|
val io = new Bundle {
|
2017-01-18 21:48:58 +01:00
|
|
|
val master = masterNodes.head.bundleOut // TODO fix after Chisel #366
|
2016-11-11 00:56:42 +01:00
|
|
|
val slave = slaveNode.map(_.bundleIn)
|
|
|
|
val hartid = UInt(INPUT, p(XLen))
|
2017-01-17 03:24:08 +01:00
|
|
|
val interrupts = new TileInterrupts()(p).asInput
|
2016-11-11 00:56:42 +01:00
|
|
|
val resetVector = UInt(INPUT, p(XLen))
|
|
|
|
}
|
2017-01-17 03:24:08 +01:00
|
|
|
rocket.module.io.interrupts := ShiftRegister(io.interrupts, 3)
|
|
|
|
// signals that do not change:
|
|
|
|
rocket.module.io.hartid := io.hartid
|
|
|
|
rocket.module.io.resetVector := io.resetVector
|
2015-12-02 05:41:58 +01:00
|
|
|
}
|
2012-03-25 00:56:59 +01:00
|
|
|
}
|
2017-01-28 02:09:43 +01:00
|
|
|
|
|
|
|
class RationalRocketTile(c: RocketConfig)(implicit p: Parameters) extends LazyModule {
|
|
|
|
val rocket = LazyModule(new RocketTile(c))
|
|
|
|
|
|
|
|
val masterNodes = rocket.masterNodes.map(_ => TLRationalOutputNode())
|
|
|
|
val slaveNode = rocket.slaveNode.map(_ => TLRationalInputNode())
|
|
|
|
|
|
|
|
(rocket.masterNodes zip masterNodes) foreach { case (r,n) => n := TLRationalCrossingSource()(r) }
|
|
|
|
(rocket.slaveNode zip slaveNode) foreach { case (r,n) => r := TLRationalCrossingSink()(n) }
|
|
|
|
|
|
|
|
lazy val module = new LazyModuleImp(this) {
|
|
|
|
val io = new Bundle {
|
|
|
|
val master = masterNodes.head.bundleOut // TODO fix after Chisel #366
|
|
|
|
val slave = slaveNode.map(_.bundleIn)
|
|
|
|
val hartid = UInt(INPUT, p(XLen))
|
|
|
|
val interrupts = new TileInterrupts()(p).asInput
|
|
|
|
val resetVector = UInt(INPUT, p(XLen))
|
|
|
|
}
|
|
|
|
rocket.module.io.interrupts := ShiftRegister(io.interrupts, 1)
|
|
|
|
// signals that do not change:
|
|
|
|
rocket.module.io.hartid := io.hartid
|
|
|
|
rocket.module.io.resetVector := io.resetVector
|
|
|
|
}
|
|
|
|
}
|