All Downloads are FREE. Search and download functionalities are using the official Maven repository.

spinal.lib.bus.bmb.BmbToWishbone.scala Maven / Gradle / Ivy

There is a newer version: 1.10.2a
Show newest version
package spinal.lib.bus.bmb

import spinal.core._
import spinal.lib._
import spinal.lib.bus.wishbone._
object BmbToWishbone{
  def getWishboneConfig(p : BmbAccessParameter): WishboneConfig = WishboneConfig(
    addressWidth = p.addressWidth-log2Up(p.byteCount),
    dataWidth = p.dataWidth,
    selWidth = p.byteCount,
    useERR = true,
    useBTE = true,
    useCTI = true
  )
}

case class BmbToWishbone(p : BmbParameter) extends Component{
  val io = new Bundle {
    val input = slave(Bmb(p))
    val output = master(Wishbone(BmbToWishbone.getWishboneConfig(p.access)))
  }
  
  val inputCmd = io.input.cmd.halfPipe()

  val halt = Bool()
  val beatCounter = Reg(UInt(p.access.beatCounterWidth bits)) init(0)
  val beatCount = inputCmd.transferBeatCountMinusOne
  val beatLast = beatCounter === beatCount
  when(inputCmd.valid && io.output.ACK && !halt){
    beatCounter := beatCounter + 1
    when(inputCmd.ready && inputCmd.last){
      beatCounter := 0
    }
  }


  io.output.ADR := Bmb.addToAddress(inputCmd.address, beatCounter << log2Up(p.access.byteCount), p) >> log2Up(p.access.byteCount)
  io.output.CTI := beatLast ? ((beatCount === 0) ? B"000" | B"111") | B"010"
  io.output.BTE :=  B"00"
  io.output.SEL := inputCmd.isWrite ? inputCmd.mask | io.output.SEL.getAllTrue
  io.output.WE  := inputCmd.isWrite
  io.output.DAT_MOSI := inputCmd.data

  inputCmd.ready := io.output.ACK && (inputCmd.isWrite || beatLast)
  io.output.CYC := inputCmd.valid
  io.output.STB := inputCmd.valid && !halt

  val rsp = cloneOf(io.input.rsp)
  rsp.valid   := inputCmd.valid && io.output.ACK && (inputCmd.isRead || beatLast) && !halt
  rsp.data    := io.output.DAT_MISO
  rsp.source  := inputCmd.source
  rsp.context := inputCmd.context
  rsp.last    := beatLast
  rsp.setSuccess() //TODO

  halt := !rsp.ready

  io.input.rsp <-/< rsp //the / ensure there is a persistent ready, to not remove transaction from the wishbone
}







© 2015 - 2024 Weber Informatics LLC | Privacy Policy