axi4 tilelink2: include minAlignment and maxAddress in slaves
This commit is contained in:
parent
538437384a
commit
dc26736f32
@ -21,9 +21,10 @@ case class AXI4SlaveParameters(
|
||||
val name = nodePath.lastOption.map(_.lazyModule.name).getOrElse("disconnected")
|
||||
val maxTransfer = max(supportsWrite.max, supportsRead.max)
|
||||
val maxAddress = address.map(_.max).max
|
||||
val minAlignment = address.map(_.alignment).min
|
||||
|
||||
// The device had better not support a transfer larger than it's alignment
|
||||
address.foreach { case a => require (a.alignment >= maxTransfer) }
|
||||
require (minAlignment >= maxTransfer)
|
||||
}
|
||||
|
||||
case class AXI4SlavePortParameters(
|
||||
|
@ -25,9 +25,7 @@ case class TLManagerParameters(
|
||||
customDTS: Option[String]= None)
|
||||
{
|
||||
address.foreach { a => require (a.finite) }
|
||||
address.combinations(2).foreach({ case Seq(x,y) =>
|
||||
require (!x.overlaps(y))
|
||||
})
|
||||
address.combinations(2).foreach { case Seq(x,y) => require (!x.overlaps(y)) }
|
||||
require (supportsPutFull.contains(supportsPutPartial))
|
||||
|
||||
// Largest support transfer of all types
|
||||
@ -38,6 +36,7 @@ case class TLManagerParameters(
|
||||
supportsGet.max,
|
||||
supportsPutFull.max,
|
||||
supportsPutPartial.max).max
|
||||
val maxAddress = address.map(_.max).max
|
||||
|
||||
val name = nodePath.lastOption.map(_.lazyModule.name).getOrElse("disconnected")
|
||||
|
||||
@ -53,9 +52,8 @@ case class TLManagerParameters(
|
||||
}
|
||||
|
||||
// The device had better not support a transfer larger than it's alignment
|
||||
address.foreach({ case a =>
|
||||
require (a.alignment >= maxTransfer)
|
||||
})
|
||||
val minAlignment = address.map(_.alignment).min
|
||||
require (minAlignment >= maxTransfer)
|
||||
}
|
||||
|
||||
case class TLManagerPortParameters(
|
||||
@ -77,7 +75,7 @@ case class TLManagerPortParameters(
|
||||
|
||||
// Bounds on required sizes
|
||||
def endSinkId = managers.map(_.sinkId.end).max
|
||||
def maxAddress = managers.map(_.address.map(_.max).max).max
|
||||
def maxAddress = managers.map(_.maxAddress).max
|
||||
def maxTransfer = managers.map(_.maxTransfer).max
|
||||
|
||||
// Operation sizes supported by all outward Managers
|
||||
|
Loading…
x
Reference in New Issue
Block a user