rocket: if no MMU, don't print it in DTS
This commit is contained in:
parent
7660be039c
commit
8e4f348dda
@ -43,19 +43,31 @@ class RocketTile(val rocketParams: RocketTileParams, val hartid: Int)(implicit p
|
|||||||
val isa = s"rv${p(XLen)}i$m$a$f$d$c$s"
|
val isa = s"rv${p(XLen)}i$m$a$f$d$c$s"
|
||||||
|
|
||||||
val dcache = rocketParams.dcache.map(d => Map(
|
val dcache = rocketParams.dcache.map(d => Map(
|
||||||
"d-tlb-size" -> ofInt(d.nTLBEntries),
|
|
||||||
"d-tlb-sets" -> ofInt(1),
|
|
||||||
"d-cache-block-size" -> ofInt(block),
|
"d-cache-block-size" -> ofInt(block),
|
||||||
"d-cache-sets" -> ofInt(d.nSets),
|
"d-cache-sets" -> ofInt(d.nSets),
|
||||||
"d-cache-size" -> ofInt(d.nSets * d.nWays * block))).getOrElse(Map())
|
"d-cache-size" -> ofInt(d.nSets * d.nWays * block))).getOrElse(Map())
|
||||||
|
|
||||||
val icache = rocketParams.icache.map(i => Map(
|
val icache = rocketParams.icache.map(i => Map(
|
||||||
"i-tlb-size" -> ofInt(i.nTLBEntries),
|
|
||||||
"i-tlb-sets" -> ofInt(1),
|
|
||||||
"i-cache-block-size" -> ofInt(block),
|
"i-cache-block-size" -> ofInt(block),
|
||||||
"i-cache-sets" -> ofInt(i.nSets),
|
"i-cache-sets" -> ofInt(i.nSets),
|
||||||
"i-cache-size" -> ofInt(i.nSets * i.nWays * block))).getOrElse(Map())
|
"i-cache-size" -> ofInt(i.nSets * i.nWays * block))).getOrElse(Map())
|
||||||
|
|
||||||
|
val dtlb = rocketParams.dcache.filter(_ => rocketParams.core.useVM).map(d => Map(
|
||||||
|
"d-tlb-size" -> ofInt(d.nTLBEntries),
|
||||||
|
"d-tlb-sets" -> ofInt(1))).getOrElse(Map())
|
||||||
|
|
||||||
|
val itlb = rocketParams.icache.filter(_ => rocketParams.core.useVM).map(i => Map(
|
||||||
|
"i-tlb-size" -> ofInt(i.nTLBEntries),
|
||||||
|
"i-tlb-sets" -> ofInt(1))).getOrElse(Map())
|
||||||
|
|
||||||
|
val mmu = if (!rocketParams.core.useVM) Map() else Map(
|
||||||
|
"tlb-split" -> Nil,
|
||||||
|
"mmu-type" -> ofStr(p(PgLevels) match {
|
||||||
|
case 2 => "riscv,sv32"
|
||||||
|
case 3 => "riscv,sv39"
|
||||||
|
case 4 => "riscv,sv48"
|
||||||
|
}))
|
||||||
|
|
||||||
// Find all the caches
|
// Find all the caches
|
||||||
val outer = masterNode.edgesOut
|
val outer = masterNode.edgesOut
|
||||||
.flatMap(_.manager.managers)
|
.flatMap(_.manager.managers)
|
||||||
@ -74,14 +86,9 @@ class RocketTile(val rocketParams: RocketTileParams, val hartid: Int)(implicit p
|
|||||||
"status" -> ofStr("okay"),
|
"status" -> ofStr("okay"),
|
||||||
"clock-frequency" -> Seq(ResourceInt(rocketParams.core.bootFreqHz)),
|
"clock-frequency" -> Seq(ResourceInt(rocketParams.core.bootFreqHz)),
|
||||||
"riscv,isa" -> ofStr(isa),
|
"riscv,isa" -> ofStr(isa),
|
||||||
"mmu-type" -> ofStr(p(PgLevels) match {
|
|
||||||
case 2 => "riscv,sv32"
|
|
||||||
case 3 => "riscv,sv39"
|
|
||||||
case 4 => "riscv,sv48" }),
|
|
||||||
"tlb-split" -> Nil,
|
|
||||||
"interrupt-controller" -> Nil,
|
"interrupt-controller" -> Nil,
|
||||||
"#interrupt-cells" -> ofInt(1))
|
"#interrupt-cells" -> ofInt(1))
|
||||||
++ dcache ++ icache ++ nextlevel)
|
++ dcache ++ icache ++ nextlevel ++ mmu ++ itlb ++ dtlb)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user