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

spinal.lib.bus.wishbone.WishboneAdapter.scala Maven / Gradle / Ivy

The newest version!
/** @todo: support SEL resize*/
/** @todo: change <> with the corrispective >> and <<*/
package spinal.lib.bus.wishbone

import spinal.core._
import spinal.lib._
import spinal.lib.fsm._

/** Factory for [[spinal.lib.bus.wishbone.WishboneAdapter]] instances. */
object WishboneAdapter{
  /** Create a Wishbone Adapter given the master/slave wishbone bus
    * @param master the wishbone master bus
    * @param slave the wishbone slave bus
    * @param allowAddressResize allow the resize of the address bus. Not allow by default
    * @param allowDataResize allow the resize of the data bus. Not allow by default
    * @param allowTagResize allow the resize of all the tagging busses. Not allow by default
    * @example {{{
    * val wishboneMaster = Wishbone(wishboneConfig(8,8).pipelined)
    * val wishboneSlave = Wishbone(wishboneConfig(16,8))
    * val adapter = WishboneAdapter(wishboneMaster, wishboneSlave, allowAddressResize = true)
    * }}}
    */
  def apply(master: Wishbone,
            slave: Wishbone,
            allowAddressResize : Boolean = false,
            allowDataResize : Boolean = false,
            allowTagResize : Boolean = false): WishboneAdapter = {
    val adapter = new WishboneAdapter(master.config,
                                      slave.config,
                                      allowAddressResize,
                                      allowDataResize,
                                      allowTagResize)
    master <> adapter.io.wbm
    slave <> adapter.io.wbs
    adapter.setPartialName(master,"adapter")
  }
}

/** Create a configurable adaptor for the wishbone bus.
  * It can adapt from a wishbone pipelined interface to a standard one
  * or vice versa
  * @constructor Create a wishbone bus adapter
  * @param wbmConfig the wishboneConfig from the wishbone master bus
  * @param wbsConfig the wishboneConfig from the wishbone slave bus
  * @param allowAddressResize allow the resize of the address bus. Not allow by default
  * @param allowDataResize allow the resize of the data bus. Not allow by default
  * @param allowTagResize allow the resize of all the tagging busses. Not allow by default
  * @example {{{
  * val wishboneMaster = Wishbone(wishboneConfig(8,8).pipelined)
  * val wishboneSlave = Wishbone(wishboneConfig(16,8))
  * val adapter = new WishboneAdapter(wishboneMaster.config, wishboneSlave.config, allowAddressResize = true)
  * wishboneMaster <> adapter.io.wbm
  * adapter.io.wbs <> wishboneSlave
  * }}}
  */
class WishboneAdapter(wbmConfig : WishboneConfig,
                      wbsConfig: WishboneConfig,
                      allowAddressResize : Boolean = false,
                      allowDataResize : Boolean = false,
                      allowTagResize : Boolean = false) extends Component{
  val io = new Bundle {
    val wbm = slave(Wishbone(wbmConfig))
    val wbs = master(Wishbone(wbsConfig))
  }

  io.wbm.connectTo(io.wbs, allowDataResize, allowAddressResize, allowTagResize)

  (wbmConfig.isPipelined,wbsConfig.isPipelined) match{
    case (false,true) => {
      /* Little state machine from chapter 5.1 of the wishbone B4 specification
         States:
         - idle     [wait4ack = False]
         - wait4ack [wait4ack = True]
         Logic:
         if (io.wbs.STB) change state to wait4ack [io.wbs.STB = False]
         if (io.wbs.ACK) change state to idle     [io.wbs.STB = io.wbm.STB]
      */
      io.wbs.STB.removeAssignments()
      val wait4ack = Reg(Bool()) init(False)
      when(!wait4ack && io.wbs.STB){
        wait4ack := True
      }.elsewhen(wait4ack && io.wbs.ACK){
        wait4ack := False
      }
      io.wbs.STB := wait4ack ? False | io.wbm.STB
    }
    case (true, false) => {
      io.wbm.STALL.removeAssignments()
      io.wbm.STALL := io.wbs.CYC? !io.wbs.ACK | False
    }
    case _ =>
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy