如何从 Rocket-Chip 连接到外部 AHB 从端口(即内存控制器上的 AHB 端口)?在连接到 AXI4 从设备的其他几个示例之后,我尝试对我的代码进行模式化,并且工作正常。但是,当我尝试实现相同的方法时,:=
IntelliJ 中红色波浪线中的高亮显示它告诉我它无法连接这两种类型的节点,或者这些类与绑定操作不兼容。我觉得我错过了一些关于这些节点类型的重要概念,这些概念涉及如何将这些设备粘合在一起。
trait CanHaveDdr4Ahb extends LazyModule { this: BaseSubsystem =>
import freechips.rocketchip.subsystem.ExtMem
override val module: CanHaveDdr4AhbImp
val ahb_mem = p(ExtMem).map {
case MemoryPortParams(mpp, nChan) => {
val portName = "my_ahb"
val device = new MemoryDevice
val memAHBNode = AHBSlaveSinkNode(Seq.tabulate(nChan) { channel =>
val base = AddressSet.misaligned(mpp.base, mpp.size)
val filter = AddressSet(channel * mbus.blockBytes, ~((nChan - 1) * mbus.blockBytes))
AHBSlavePortParameters(
slaves = Seq(AHBSlaveParameters(
address = List(AddressSet(mpp.base, mpp.size - 1)),
resources = device.reg,
regionType = RegionType.UNCACHED,
executable = true,
supportsWrite = TransferSizes(1, mbus.blockBytes),
supportsRead = TransferSizes(1, mbus.blockBytes))),
beatBytes = mpp.beatBytes)
})
// TODO: Why can't I assign DRAMController output to this AHBSlaveSinkNode?
// AHBSlaveSinkNode := OutwardNodeHandle[D,U,E,B] { body }
memAHBNode := mbus.toDRAMController(Some(portName)) { TLToAHB() }
memAHBNode
}
}
编辑:好的,在将代码库返回到 Chipyard 并使用给定的解决方案之后,即删除 AHBSlaveParameters 中 nodePath 和设备的分配,并将 := 绑定语句更改为:
memAHBNode := mbus.toDRAMController(Some(portName)) { TLToAHB() }
...相同类型的错误仍然存在,涉及绑定操作如何尝试绑定到左侧的某些内容:
OutwardNodeHandle[
AHBMasterPortParameters,
AHBSlavePortParameters,
AHBEdgeParameters,
AHBMasterBundle] // <-- should be AHBSlaveBundle according to ahb/Nodes.scala
注意在最后一行,它试图匹配一个
OutwardNodeHandle[D,U,E,AHBSlaveBundle]
在 RHS 上推断
OutwardNodeHandle[D,U,E,AHBMasterBundle]
在作业的 LHS 上。我不知道为什么编译器会这样输入。下面是我得到的错误输出。我也更新了上面的代码。
[error] /home/abryant/workspace/chipyard/generators/socta1_rtl/src/main/scala/devices/Ddr4Ahb.scala:62:16: overloaded method value := with alternatives:
[error] [EY](h: freechips.rocketchip.diplomacy.OutwardNodeHandle[freechips.rocketchip.amba.ahb.AHBMasterPortParameters,freechips.rocketchip.amba.ahb.AHBSlavePortParameters,EY,freechips.rocketchip.amba.ahb.AHBSlaveBundle])(implicit p: freechips.rocketchip.config.Parameters, implicit sourceInfo: chisel3.internal.sourceinfo.SourceInfo)freechips.rocketchip.diplomacy.OutwardNodeHandle[freechips.rocketchip.amba.ahb.AHBMasterPortParameters,freechips.rocketchip.amba.ahb.AHBSlavePortParameters,freechips.rocketchip.amba.ahb.AHBEdgeParameters,freechips.rocketchip.amba.ahb.AHBSlaveBundle] <and>
[error] [DX, UX, EX, BX <: Chisel.Data, EY](h: freechips.rocketchip.diplomacy.NodeHandle[DX,UX,EX,BX,freechips.rocketchip.amba.ahb.AHBMasterPortParameters,freechips.rocketchip.amba.ahb.AHBSlavePortParameters,EY,freechips.rocketchip.amba.ahb.AHBSlaveBundle])(implicit p: freechips.rocketchip.config.Parameters, implicit sourceInfo: chisel3.internal.sourceinfo.SourceInfo)freechips.rocketchip.diplomacy.NodeHandle[DX,UX,EX,BX,freechips.rocketchip.amba.ahb.AHBMasterPortParameters,freechips.rocketchip.amba.ahb.AHBSlavePortParameters,freechips.rocketchip.amba.ahb.AHBEdgeParameters,freechips.rocketchip.amba.ahb.AHBSlaveBundle]
[error] cannot be applied to (freechips.rocketchip.diplomacy.OutwardNodeHandle[freechips.rocketchip.amba.ahb.AHBMasterPortParameters,freechips.rocketchip.amba.ahb.AHBSlavePortParameters,freechips.rocketchip.amba.ahb.AHBEdgeParameters,freechips.rocketchip.amba.ahb.AHBMasterBundle])
[error] memAHBNode := mbus.toDRAMController(Some(portName)) {
[error] ^
mbus.toDRAMController 传递给 := 的 OutwardNodeHandle 可从 AXI4Slave 类型继承,但不能从 AHBSlave 类型继承。