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

spinal.lib.bus.tilelink.fabric.AxiLite4Bridge.scala Maven / Gradle / Ivy

The newest version!
package spinal.lib.bus.tilelink.fabric

import spinal.core._
import spinal.core.fiber._
import spinal.lib.bus.amba4.axilite._
import spinal.lib.bus.misc.SizeMapping
import spinal.lib.bus.tilelink
import spinal.lib.bus.tilelink.S2mSupport
import spinal.lib.system.tag.{MappedNode, MemoryConnection, MemoryTransferTag, MemoryTransfers}


class AxiLite4Bridge() extends Area{
  val up = Node.slave()
  val down = new Handle[AxiLite4] with SpinalTagReady

  new MemoryConnection {
    override def up = AxiLite4Bridge.this.up
    override def down = AxiLite4Bridge.this.down
    override def transformers = Nil
    populate()
  }

  down.addTag(new MemoryTransferTag {
    override def get = up.m2s.parameters.emits
  })

  val logic = Fiber build new Area{
    up.m2s.supported load tilelink.AxiLite4Bridge.getSupported(up.m2s.proposed)
    up.s2m.none()

    val bridge = new tilelink.AxiLite4Bridge(up.bus.p.node)
    bridge.io.up << up.bus
    down.load(cloneOf(bridge.io.down))
    bridge.io.down >> down
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy