Merge pull request #1244 from freechipsproject/dtim-priority
Give Rocket priority over DTIM TL port
This commit is contained in:
commit
1b158d2caf
@ -105,8 +105,6 @@ class RocketTileModuleImp(outer: RocketTile) extends BaseTileModuleImp(outer)
|
|||||||
val uncorrectable = RegInit(Bool(false))
|
val uncorrectable = RegInit(Bool(false))
|
||||||
val halt_and_catch_fire = outer.rocketParams.hcfOnUncorrectable.option(IO(Bool(OUTPUT)))
|
val halt_and_catch_fire = outer.rocketParams.hcfOnUncorrectable.option(IO(Bool(OUTPUT)))
|
||||||
|
|
||||||
outer.dtim_adapter.foreach { lm => dcachePorts += lm.module.io.dmem }
|
|
||||||
|
|
||||||
outer.bus_error_unit.foreach { lm =>
|
outer.bus_error_unit.foreach { lm =>
|
||||||
lm.module.io.errors.dcache := outer.dcache.module.io.errors
|
lm.module.io.errors.dcache := outer.dcache.module.io.errors
|
||||||
lm.module.io.errors.icache := outer.frontend.module.io.errors
|
lm.module.io.errors.icache := outer.frontend.module.io.errors
|
||||||
@ -130,6 +128,9 @@ class RocketTileModuleImp(outer: RocketTile) extends BaseTileModuleImp(outer)
|
|||||||
core.io.rocc.busy := roccCore.busy
|
core.io.rocc.busy := roccCore.busy
|
||||||
core.io.rocc.interrupt := roccCore.interrupt
|
core.io.rocc.interrupt := roccCore.interrupt
|
||||||
|
|
||||||
|
// Rocket has higher priority to DTIM than other TileLink clients
|
||||||
|
outer.dtim_adapter.foreach { lm => dcachePorts += lm.module.io.dmem }
|
||||||
|
|
||||||
when(!uncorrectable) { uncorrectable :=
|
when(!uncorrectable) { uncorrectable :=
|
||||||
List(outer.frontend.module.io.errors, outer.dcache.module.io.errors)
|
List(outer.frontend.module.io.errors, outer.dcache.module.io.errors)
|
||||||
.flatMap { e => e.uncorrectable.map(_.valid) }
|
.flatMap { e => e.uncorrectable.map(_.valid) }
|
||||||
|
Loading…
Reference in New Issue
Block a user