spinal.lib.bus.misc

BusSlaveFactoryDelayed

Related Doc: package misc

trait BusSlaveFactoryDelayed extends BusSlaveFactory

BusSlaveFactoryDelayed captures each primitives (BusSlaveFactoryElement) into a data-model

Example:
  1. class Apb3SlaveFactory(bus : Apb3) extends BusSlaveFactoryDelayed{
        override def build(): Unit = { ... }
        override def busDataWidth: Int = bus.config.dataWidth
     }
Linear Supertypes
BusSlaveFactory, Area, ScalaLocated, ContextUser, GlobalDataUser, Nameable, OwnableRef, AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. BusSlaveFactoryDelayed
  2. BusSlaveFactory
  3. Area
  4. ScalaLocated
  5. ContextUser
  6. GlobalDataUser
  7. Nameable
  8. OwnableRef
  9. AnyRef
  10. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Type Members

  1. abstract type RefOwnerType

    Definition Classes
    OwnableRef

Abstract Value Members

  1. abstract def build(): Unit

    In this function you have to define the read/write logic thanks to element, elementsPerAddress and elementsPerRangeAddress This is the only thing with def busDataWidth that should be implement by class that extends BusSlaveFactoryDelay

  2. abstract def busDataWidth: Int

    Return the data width of the bus

    Return the data width of the bus

    Definition Classes
    BusSlaveFactory

Concrete Value Members

  1. final def !=(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  4. var _config: BusSlaveFactoryConfig

    Configuration of the BusSlaveFactory

    Configuration of the BusSlaveFactory

    Attributes
    protected
    Definition Classes
    BusSlaveFactory
  5. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  6. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. var component: Component

    Definition Classes
    ContextUser
  8. def createAndDriveFlow[T <: Data](dataType: T, address: BigInt, bitOffset: Int = 0): Flow[T]

    Create a writable Flow register of type dataType at address and placed at bitOffset in the word

    Create a writable Flow register of type dataType at address and placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  9. def createReadWrite[T <: Data](dataType: T, address: BigInt, bitOffset: Int = 0): T

    Create a read write register of type dataType at address and placed at bitOffset in the word

    Create a read write register of type dataType at address and placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  10. def createWriteOnly[T <: Data](dataType: T, address: BigInt, bitOffset: Int = 0): T

    Create a write only register of type dataType at address and placed at bitOffset in the word

    Create a write only register of type dataType at address and placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  11. def doBitsAccumulationAndClearOnRead(that: Bits, address: BigInt, bitOffset: Int = 0): Unit

    Instanciate an internal register which at each cycle do : reg := reg | that Then when a read occur, the register is cleared.

    Instanciate an internal register which at each cycle do : reg := reg | that Then when a read occur, the register is cleared. This register is readable at address and placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  12. def drive[T <: Data](that: T, address: BigInt, bitOffset: Int = 0): T

    Drive that with a register writable at address placed at bitOffset in the word

    Drive that with a register writable at address placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  13. def driveAndRead[T <: Data](that: T, address: BigInt, bitOffset: Int = 0): T

    Drive that with a register writable and readable at address placed at bitOffset in the word

    Drive that with a register writable and readable at address placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  14. def driveFlow[T <: Data](that: Flow[T], address: BigInt, bitOffset: Int = 0): Unit

    Emit on that a transaction when a write happen at address by using data placed at bitOffset in the word

    Emit on that a transaction when a write happen at address by using data placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  15. val elements: ArrayBuffer[BusSlaveFactoryElement]

    Contains all elements created

  16. val elementsPerAddress: HashMap[BigInt, ArrayBuffer[BusSlaveFactoryElement]]

    Contains all elements related to an address

  17. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  18. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  19. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  20. def forEachNameables(doThat: (Any) ⇒ Unit): Unit

    Definition Classes
    Nameable
  21. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  22. def getConfig: BusSlaveFactoryConfig

    Definition Classes
    BusSlaveFactory
  23. def getDisplayName(): String

    Definition Classes
    Nameable
  24. def getInstanceCounter: Int

    Definition Classes
    ContextUser
  25. def getName(default: String): String

    Definition Classes
    Nameable
  26. def getName(): String

    Definition Classes
    Nameable
  27. def getRefOwnersChain(): List[Any]

    Definition Classes
    OwnableRef
  28. def getScalaLocationLong: String

    Definition Classes
    ScalaLocated
  29. def getScalaLocationShort: String

    Definition Classes
    ScalaLocated
  30. val globalData: GlobalData

    Definition Classes
    GlobalDataUser
  31. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  32. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  33. def isNamed: Boolean

    Definition Classes
    Nameable
  34. def isReading(address: BigInt): Bool

    Return true if the bus is reading

    Return true if the bus is reading

    Definition Classes
    BusSlaveFactory
  35. def isUnnamed: Boolean

    Definition Classes
    Nameable
  36. def isWriting(address: BigInt): Bool

    Return true if the bus is writing

    Return true if the bus is writing

    Definition Classes
    BusSlaveFactory
  37. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  38. def nonStopWrite(that: Data, bitOffset: Int = 0): Unit

    Permanently assign that by the bus write data from bitOffset

    Permanently assign that by the bus write data from bitOffset

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  39. final def notify(): Unit

    Definition Classes
    AnyRef
  40. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  41. def onRead(address: BigInt)(doThat: ⇒ Unit): Unit

    Call doThat when a read transaction occurs on address

    Call doThat when a read transaction occurs on address

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  42. def onReadCondition(condition: ⇒ Bool)(doThat: ⇒ Unit): Unit

    Call doThat when a read transaction occurs and the condition is true

    Call doThat when a read transaction occurs and the condition is true

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  43. def onWrite(address: BigInt)(doThat: ⇒ Unit): Unit

    Call doThat when a write transaction occurs on address

    Call doThat when a write transaction occurs on address

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  44. def onWriteCondition(condition: ⇒ Bool)(doThat: ⇒ Unit): Unit

    Call doThat when a write transaction occurs and the condition is true

    Call doThat when a write transaction occurs and the condition is true

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  45. def read(that: Data, address: BigInt, bitOffset: Int = 0): Unit

    When the bus read the address, fill the response with that at bitOffset

    When the bus read the address, fill the response with that at bitOffset

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  46. def readAndWrite(that: Data, address: BigInt, bitOffset: Int = 0): Unit

    Make that readable and writable at address and placed at bitOffset in the word

    Make that readable and writable at address and placed at bitOffset in the word

    Definition Classes
    BusSlaveFactory
  47. def readAndWriteMultiWord(that: Data, address: BigInt): Unit

    Create the memory mapping to write/read that from address

    Create the memory mapping to write/read that from address

    Definition Classes
    BusSlaveFactory
  48. def readMultiWord(that: Data, address: BigInt): Unit

    Create the memory mapping to read that from address If that is bigger than one word it extends the register on followings addresses

    Create the memory mapping to read that from address If that is bigger than one word it extends the register on followings addresses

    Definition Classes
    BusSlaveFactory
  49. def readStreamNonBlocking[T <: Data](that: Stream[T], address: BigInt, validBitOffset: Int, payloadBitOffset: Int): Unit

    Read that and consume the transaction when a read happen at address.

    Read that and consume the transaction when a read happen at address.

    Definition Classes
    BusSlaveFactory
  50. var refOwner: RefOwnerType

    Definition Classes
    OwnableRef
  51. def reflectNames(): Unit

    Definition Classes
    Area
  52. def setCompositeName(nameable: Nameable, postfix: String, weak: Boolean): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  53. def setCompositeName(nameable: Nameable, postfix: String): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  54. def setCompositeName(nameable: Nameable, weak: Boolean): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  55. def setCompositeName(nameable: Nameable): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  56. def setConfig(value: BusSlaveFactoryConfig): BusSlaveFactoryDelayed.this.type

    Definition Classes
    BusSlaveFactory
  57. def setName(name: String, weak: Boolean): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  58. def setPartialName(name: String, weak: Boolean): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  59. def setPartialName(owner: Nameable, name: String, weak: Boolean): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  60. def setPartialName(name: String): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  61. def setPartialName(owner: Nameable, name: String): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  62. def setRefOwner(that: Any): Unit

    Definition Classes
    OwnableRef
  63. def setWeakName(name: String): BusSlaveFactoryDelayed.this.type

    Definition Classes
    Nameable
  64. def setWordEndianness(value: Endianness): BusSlaveFactory

    Definition Classes
    BusSlaveFactory
  65. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  66. def toString(): String

    Definition Classes
    Area → Nameable → AnyRef → Any
  67. def unsetName(): Unit

    Definition Classes
    Nameable
  68. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  69. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  70. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  71. def wordAddressInc: Int

    Address incrementation used by the read and write multi words registers

    Address incrementation used by the read and write multi words registers

    Definition Classes
    BusSlaveFactory
  72. def write[T <: Data](that: T, address: BigInt, bitOffset: Int = 0): T

    When the bus write the address, assign that with bus’s data from bitOffset

    When the bus write the address, assign that with bus’s data from bitOffset

    Definition Classes
    BusSlaveFactoryDelayedBusSlaveFactory
  73. def writeMultiWord(that: Data, address: BigInt): Unit

    Create the memory mapping to write that at address.

    Create the memory mapping to write that at address. If that is bigger than one word it extends the register on followings addresses

    Definition Classes
    BusSlaveFactory

Inherited from BusSlaveFactory

Inherited from Area

Inherited from ScalaLocated

Inherited from ContextUser

Inherited from GlobalDataUser

Inherited from Nameable

Inherited from OwnableRef

Inherited from AnyRef

Inherited from Any

Ungrouped