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

spinal.lib.bus.regif.Block.WrFifoInst.scala Maven / Gradle / Ivy

package spinal.lib.bus.regif

import spinal.core._
import spinal.lib.{Flow, Stream}

class WrFifoInst(name: String, addr: BigInt, doc: String, sec: Secure,  grp: GrpTag = null)(bi: BusIf) extends FifoInst(name, addr, doc, sec, grp)(bi){
  override val regType: String = "wFIFO"

  val hitDoRead: Bool = False
  val hitDoWrite = wrSecurePassage(bi.writeAddress === U(addr) && bi.doWrite)
  hitDoWrite.setName(f"write_hit_0x${addr}%04x", weak = true)

  val bus = Flow(Bits(bi.busDataWidth bit))

  bus.setName(s"${name}_wrfifo")

  bus.valid   := hitDoWrite
  bus.payload := bi.writeData

  override def readBits: Bits = bi.defaultReadBits

  override def readGenerator() = {
    is(addr) {
      bi.reg_rdata := rdSecurePassage(this.rdata())
      bi.reg_rderr := True
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy