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

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

package spinal.lib.bus.regif

import spinal.core.SpinalError

import scala.collection.mutable.ListBuffer


case class RegSliceGrp(baseAddr: BigInt, maxSize: BigInt, doc: String, sec: Secure, grp: GrpTag)(bi: BusIf) {
  private val slices = ListBuffer[RegSlice]()
  def len: Int = slices.length

  def check(offset: BigInt) = {
    if (offset < 0 || offset >= maxSize) {
      SpinalError(s"Offset $offset is out of range [0, $maxSize)")
    }
  }

  def newReg(doc: String)(implicit symbol: SymbolName): RegInst = {
    val ret = bi.newReg(doc, sec, grp)(symbol)
    slices += ret
    ret
  }

  def newRegAt(offset: BigInt, doc: String)(implicit symbol: SymbolName): RegInst = {
    check(offset)
    val ret = bi.newRegAt(baseAddr + offset, doc, sec, grp)(symbol)
    slices += ret
    ret
  }

  def newFifo(doc: String)(implicit symbol: SymbolName): WrFifoInst = {
    val ret = bi.newWrFifo(doc, sec, grp)(symbol)
    slices += ret
    ret
  }

  def newFifoAt(offset: BigInt, doc: String)(implicit symbol: SymbolName) = {
    check(offset)
    val ret = bi.newWrFifoAt(baseAddr + offset, doc, sec, grp)(symbol)
    slices += ret
    ret
  }

  def newRAM(size: BigInt, doc: String)(implicit symbol: SymbolName) = {
    val ret = bi.newRAM(size, doc, sec, grp)(symbol)
    slices += ret
    ret
  }

  def newRAMAt(offset: BigInt, size: BigInt, doc: String)(implicit symbol: SymbolName) = {
    check(offset + size)
    val ret = bi.newRAMAt(baseAddr + offset, size, doc, sec,  grp)(symbol)
    slices += ret
    ret
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy