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

spinal.lib.misc.pipeline.JoinLink.scala Maven / Gradle / Ivy

package spinal.lib.misc.pipeline

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

object JoinLink{
  def apply(ups : Seq[Node], down : Node) : JoinLink = new JoinLink(ups, down)
}
class JoinLink(override val ups : Seq[Node], val down : Node) extends Link {
  this.ups.foreach(_.down = this)
  down.up = this

  override def downs: Seq[Node] = List(down)

  override def propagateDown(): Unit = {
    propagateDownAll()
    down.valid
  }
  override def propagateUp(): Unit = {
    propagateUpAll()
    ups.foreach(_.ready)
  }

  override def build(): Unit = {
    assert(down.ctrl.forgetOne.isEmpty)

    down.valid := ups.map(_.isValid).andR
    ups.foreach(_.ready := down.isValid && down.isReady)
    for(key <- down.fromUp.payload){
      val filtred = ups.filter(up => up.keyToData.contains(key) || up.fromUp.payload.contains(key))
      filtred.size match {
        case 1 => down(key) := filtred(0)(key)
      }
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy