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

spinal.lib.bus.bsb.package.scala Maven / Gradle / Ivy

There is a newer version: 1.10.2a
Show newest version
package spinal.lib.bus
import spinal.core._
import spinal.lib.{Fragment, Stream}

import spinal.core._

package object bsb {
  type Bsb = spinal.lib.Stream[BsbTransaction]

  implicit class BsbPimper(pimped : Bsb) {
    def firstSink = {
      val regs = (0 until 1 << pimped.p.sinkWidth).map(sinkId => RegNextWhen(pimped.last, pimped.fire && pimped.sink === sinkId, True))
      B(regs)
    }

    def toStreamFragment(omitMask : Boolean = false) = {
      assert(omitMask || !pimped.p.withMask)
      val s = Stream(Fragment(Bits(pimped.p.byteCount*8 bits)))
      s.arbitrationFrom(pimped)
      s.fragment := pimped.data
      s.last := pimped.last
      s
    }
    def toStream(omitMask : Boolean = false, throwSparse : Boolean = false) = {
      assert(omitMask || throwSparse || !pimped.p.withMask)
      val s = Stream(Bits(pimped.p.byteCount*8 bits))
      throwSparse match {
        case false => s.arbitrationFrom(pimped)
        case true => s.arbitrationFrom(pimped.throwWhen(!pimped.mask.andR))
      }
      s.payload := pimped.data
      s
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy