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

spinal.lib.blackbox.lattice.ecp5.IO.scala Maven / Gradle / Ivy

The newest version!
package spinal.lib.blackbox.lattice.ecp5

import spinal.core._

case class BB() extends BlackBox {
  val I, T = in Bool()
  val O = out Bool()
  val B = inout(Analog(Bool()))
}


case class TSFF() extends BlackBox{
  val TD   = in Bool()
  val SCLK = in Bool()
  val RST  = in Bool()
  val TQ =  out Bool()
}

case class IDDRX1F() extends BlackBox{
  val SCLK, RST, D = in Bool()
  val Q0, Q1 = out Bool()
  mapCurrentClockDomain(SCLK, RST)
}


object ODDRX1F{
  def apply(Q : Bool, D0 : Bool, D1 : Bool): ODDRX1F ={
    val ret = ODDRX1F()
    ret.D0 := D0
    ret.D1 := D1
    Q := ret.Q
    ret
  }
}
case class ODDRX1F() extends BlackBox{
  val SCLK, RST, D0, D1 = in Bool()
  val Q = out Bool()
  mapCurrentClockDomain(SCLK, RST)
}

object IFS1P3BX{
  def apply(that : Bool): Bool ={
    val iFF = IFS1P3BX()
    iFF.PD := False
    iFF.SP := True
    iFF.D := that
    iFF.Q
  }
}

case class IFS1P3BX() extends BlackBox{
  val SCLK, PD, SP, D = in Bool()
  val Q = out Bool()
  mapCurrentClockDomain(SCLK)
  Q := ClockDomain(SCLK)(RegNext(D))
  spinalSimWhiteBox()
}

object OFS1P3BX{
  def apply(that : Bool): Bool ={
    val oFF = OFS1P3BX()
    oFF.PD := False
    oFF.SP := True
    oFF.D := that
    oFF.Q
  }
}
case class OFS1P3BX() extends BlackBox{
  val SCLK, PD, SP, D = in Bool()
  val Q = out Bool()
  mapCurrentClockDomain(SCLK)

  Q := ClockDomain(SCLK)(RegNext(D))

  spinalSimWhiteBox()
}



case class Ulx3sUsrMclk() extends BlackBox{
  setDefinitionName("USRMCLK")

  val USRMCLKI = in Bool()
  val USRMCLKTS = in Bool()

  spinalSimWhiteBox()
}



object DCCA{
  def on(that : Bool) : Bool = {
    val dcca = DCCA()
    dcca.setCompositeName(that, "DCCA")
    dcca.CLKI := that
    dcca.CE := True
    dcca.CLKO
  }
}
case class DCCA() extends BlackBox{
  val CLKI, CE = in Bool()
  val CLKO = out Bool()

  CLKO := CLKI
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy