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

spinal.lib.misc.slot.Slot.scala Maven / Gradle / Ivy

package spinal.lib.misc.slot

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

class Slot extends Area {
  val fire = False
  val valid = RegInit(False) clearWhen (fire)
}

class SlotPool[T <: Slot](slotsCount: Int, stableAllocate : Boolean)(gen: => T) extends Area {
  val slots = for (i <- 0 until slotsCount) yield gen
  val allocate = new Area {
    val full = slots.map(_.valid).andR
    val ohRaw = B(OHMasking.firstV2(Vec(slots.map(!_.valid))))
    val oh = CombInit(ohRaw)
    val lock = stableAllocate generate new Area{
      val valid = RegInit(False) setWhen(!full)
      val value = RegNextWhen(ohRaw, !valid)
      when(valid){
        oh := value
      }
    }
    val id = OHToUInt(oh)
    def apply(body : T => Unit ){
      slots.onMask(oh){s => s.valid := True; body(s)}
      if(stableAllocate) lock.valid := False
    }
  }
  def free(id : UInt) = slots.onSel(id)(_.fire := True)
  val isEmpty = slots.map(_.valid).norR
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy