如何将Sbus Master添加到火箭芯片外围设备

时间:2018-09-03 02:23:53

标签: chisel rocket-chip

我正在尝试为火箭芯片实现DMA之类的外围设备。 表示挂接到pbus并由寄存器控制的模块。 它也有一个挂接到总线的主机。

我遵循sifive格式附加寄存器控制的外围设备而没有任何问题。 我的问题是我该如何添加sbus master?下面是我在陷入困境之前尝试过的方法。

在附加参数类中,添加了sbus:

case class dmaAttachParams(
    dma       : dmaParams,
    controlBus: TLBusWrapper,
    masterBus : TLBusWrapper, // <-- my addition 
    ....
) (implicit val p: Parameters) 

然后我在工厂对象中修改了attach方法:

def attach(params: dmaAttachParams): TLdma = {
    implicit val p = params.p
    val name = s"dma_${nextId()}"
    val cbus = params.controlBus
    val mbus = params.masterBus  // <- my addition 
    val dma = LazyModule(new TLdma(params.dma))
    dma.suggestName(name)

    cbus.coupleTo(s"slave_named_name") {
        dma.controlXing(params.controlXType) := TLFragmenter(cbus.beatBytes, cbus.blockBytes) := _
    }

    InModuleBody { dma.module.clock := params.mclock.map(_.getWrappedValue).getOrElse(cbus.module.clock) }
    InModuleBody { dma.module.reset := params.mreset.map(_.getWrappedValue).getOrElse(cbus.module.reset) }

    // this section is my problem // <-- this section is my addition
    mbus.from(s"master_named_name") {
        mbus.inwardNode := TLBuffer() :=  dma.mnode // <- what should i do here ??? 
    }
    dma
}

mndoe是我已经添加到dma类的一个节点,

val mnode = TLClientNode(Seq(TLClientPortParameters(Seq(TLClientParameters(name = "dmaSbusMaster")))))

执行工作的mbus.from()方法的主体应该是什么? 尝试构建此代码会出现此错误:

Caused by: java.lang.IllegalArgumentException: requirement failed: buffer.node (A adapter node with parent buffer inside coupler_from_master_named_name) has 1 inputs and 0 outputs; they must match (Buffer.scala:69:28)

任何帮助将不胜感激,在火箭芯片github问题论坛中,他们不再回答支持问题。因此,如果那里有人可以在这里回答,那就太好了,因为我真的被困在这里。

P.S。只是添加调用attach方法的方式:

 trait HasPeripheryDma { this: BaseSubsystem =>
        val dmaNodes = p(PeripheryDmaKey).map { ps =>
            dma.attach(dmaAttachParams(ps, pbus, sbus))
        }
    }

更新:

实现mbus.from()方法的主体,如下所示:

mbus.from(s"master_named_name") {
    mbus.inwardNode := TLBuffer(BufferParams.default)  := dma.mnode
}  

是否从SBUS上的dma创建耦合器,但未连接到dma外围设备。有任何想法吗?

2 个答案:

答案 0 :(得分:3)

我不了解您的“更新”中出了什么问题,但这应该可以解决:

mbus.coupleFrom("master_named_dma") {
    _ := TLBuffer(BufferParams.default) := dma.mnode
}  

答案 1 :(得分:1)

我已经通过对从站的连接方式进行了逆向工程来附加了SBUS。 如果有人可以/想详细说明,请随时这样做。

我向DMA外设添加了一个“ TLOutwardCrossingHelper”字段,如下所示:

class TLdma(params : dmaParams) (implicit p: Parameters) extends dma(params) with HasTLControlRegMap {
  val controlXingMaster : TLOutwardCrossingHelper = this.crossOut(mnode)
}  

请注意,在我们扩展的“ HasTLControlRegMap”特征中定义了等效的“ TLInwardCrossingHelper”。

然后,在attach方法中,下一行完成了工作:

_ := TLBuffer(BufferParams.default) := dma.controlXingMaster(params.controlXType)

通过这种方式,我还可以将外围设备钩接到总线上的耦合器上。 我认为交叉对象对节点有作用,但是我不知道该怎么办。