Class/Object

spinal.core

Mem

Related Docs: object Mem | package core

Permalink

class Mem[T <: Data] extends DeclarationStatement with StatementDoubleLinkedContainer[Mem[_], MemPortStatement] with WidthProvider with SpinalTagReady with InComponent

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Mem
  2. InComponent
  3. SpinalTagReady
  4. WidthProvider
  5. StatementDoubleLinkedContainer
  6. DoubleLinkedContainer
  7. DeclarationStatement
  8. Nameable
  9. OwnableRef
  10. LeafStatement
  11. Statement
  12. BaseNode
  13. ContextUser
  14. ScalaLocated
  15. GlobalDataUser
  16. ExpressionContainer
  17. AnyRef
  18. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Mem(wordType: HardType[T], wordCount: Int)

    Permalink

Type Members

  1. abstract type RefOwnerType

    Permalink
    Definition Classes
    OwnableRef

Value Members

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

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

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

    Permalink
    Definition Classes
    AnyRef → Any
  4. var _spinalTags: LinkedHashSet[SpinalTag]

    Permalink
    Definition Classes
    SpinalTagReady
  5. val _widths: Vector[Int]

    Permalink
  6. def addAttribute(attribute: Attribute): Mem.this.type

    Permalink
    Definition Classes
    MemSpinalTagReady
  7. def addAttribute(name: String, value: Int): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  8. def addAttribute(name: String, value: String): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  9. def addAttribute(name: String): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  10. def addTag[T <: SpinalTag](spinalTag: T): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  11. def addTags[T <: SpinalTag](tags: Iterable[T]): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  12. val addressType: HardType[UInt]

    Permalink
  13. def addressWidth: Int

    Permalink
  14. var algoIncrementale: Int

    Permalink
    Definition Classes
    BaseNode
  15. var algoInt: Int

    Permalink
    Definition Classes
    BaseNode
  16. def apply(address: Int): T

    Permalink
  17. def apply(address: UInt)(implicit loc: Location): T

    Permalink
  18. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  19. def byteCount: Int

    Permalink
  20. def cldCount: Int

    Permalink
    Definition Classes
    DoubleLinkedContainer
  21. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @HotSpotIntrinsicCandidate() @throws( ... )
  22. def component: Component

    Permalink
    Definition Classes
    ContextUser
  23. def dlcAppend(that: MemPortStatement): Mem.this.type

    Permalink
    Definition Classes
    DoubleLinkedContainer
  24. def dlcForeach[T >: MemPortStatement](func: (T) ⇒ Unit): Unit

    Permalink
    Definition Classes
    DoubleLinkedContainer
  25. def dlcHasOnlyOne: Boolean

    Permalink
    Definition Classes
    DoubleLinkedContainer
  26. var dlcHead: MemPortStatement

    Permalink
    Definition Classes
    DoubleLinkedContainer
  27. def dlcIsEmpty: Boolean

    Permalink
    Definition Classes
    DoubleLinkedContainer
  28. var dlcLast: MemPortStatement

    Permalink
    Definition Classes
    DoubleLinkedContainer
  29. def dlcPrepend(that: MemPortStatement): Mem.this.type

    Permalink
    Definition Classes
    DoubleLinkedContainer
  30. final def eq(arg0: AnyRef): Boolean

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

    Permalink
    Definition Classes
    AnyRef → Any
  32. def existsTag(cond: (SpinalTag) ⇒ Boolean): Boolean

    Permalink
    Definition Classes
    SpinalTagReady
  33. def filterTag(cond: (SpinalTag) ⇒ Boolean): Iterable[SpinalTag]

    Permalink
    Definition Classes
    SpinalTagReady
  34. def findTag(cond: (SpinalTag) ⇒ Boolean): Option[SpinalTag]

    Permalink
    Definition Classes
    SpinalTagReady
  35. var forceMemToBlackboxTranslation: Boolean

    Permalink
  36. def foreachClockDomain(func: (ClockDomain) ⇒ Unit): Unit

    Permalink
    Definition Classes
    Statement
  37. def foreachDrivingExpression(func: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  38. def foreachExpression(func: (Expression) ⇒ Unit): Unit

    Permalink
  39. def foreachReflectableNameables(doThat: (Any) ⇒ Unit): Unit

    Permalink
    Definition Classes
    Nameable
  40. def foreachStatements(func: (MemPortStatement) ⇒ Unit): Unit

    Permalink
  41. def foreachTag(body: (SpinalTag) ⇒ Unit): Unit

    Permalink
    Definition Classes
    SpinalTagReady
  42. def formalContains(cond: (T) ⇒ Bool): Bool

    Permalink
  43. def formalContains(word: T): Bool

    Permalink
  44. def generateAsBlackBox(): Mem.this.type

    Permalink
  45. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
    Annotations
    @HotSpotIntrinsicCandidate()
  46. def getComponent(): Component

    Permalink
    Definition Classes
    MemInComponent
  47. def getComponents(): Seq[Component]

    Permalink

    Get current component with all parents

    Get current component with all parents

    Definition Classes
    InComponent
  48. def getDisplayName(): String

    Permalink
    Definition Classes
    Nameable
  49. def getInstanceCounter: Int

    Permalink
    Definition Classes
    ContextUser
  50. def getMode: Byte

    Permalink
    Attributes
    protected
    Definition Classes
    Nameable
  51. def getName(default: String): String

    Permalink
    Definition Classes
    Nameable
  52. def getName(): String

    Permalink
    Definition Classes
    Nameable
  53. def getPartialName(): String

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

    Permalink
    Definition Classes
    OwnableRef
  55. def getScalaLocationLong: String

    Permalink
    Definition Classes
    ScalaLocated
  56. def getScalaLocationShort: String

    Permalink
    Definition Classes
    ScalaLocated
  57. def getScalaTrace(): Throwable

    Permalink
    Definition Classes
    ScalaLocated
  58. def getTag[T <: SpinalTag](clazz: Class[T]): Option[T]

    Permalink
    Definition Classes
    SpinalTagReady
  59. def getTags(): LinkedHashSet[SpinalTag]

    Permalink
    Definition Classes
    SpinalTagReady
  60. val getWidth: Int

    Permalink
    Definition Classes
    MemWidthProvider
  61. val globalData: GlobalData

    Permalink
    Definition Classes
    GlobalDataUser
  62. def hasOnlyOneStatement: Boolean

    Permalink
  63. def hasTag[T <: SpinalTag](clazz: Class[T]): Boolean

    Permalink
    Definition Classes
    SpinalTagReady
  64. def hasTag(spinalTag: SpinalTag): Boolean

    Permalink
    Definition Classes
    SpinalTagReady
  65. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
    Annotations
    @HotSpotIntrinsicCandidate()
  66. def head: MemPortStatement

    Permalink
  67. def init(initialContent: Seq[T]): Mem.this.type

    Permalink
  68. def initBigInt(initialContent: Seq[BigInt], allowNegative: Boolean = false): Mem.this.type

    Permalink
  69. var initialContent: Array[BigInt]

    Permalink
  70. def insertNext(s: Statement): Unit

    Permalink
    Definition Classes
    Statement
  71. def instanceAttributes(language: Language): Iterable[Attribute]

    Permalink
    Definition Classes
    SpinalTagReady
  72. def instanceAttributes: Iterable[Attribute]

    Permalink
    Definition Classes
    SpinalTagReady
  73. def isCompletelyUnnamed: Boolean

    Permalink
    Definition Classes
    Nameable
  74. def isEmptyOfTag: Boolean

    Permalink
    Definition Classes
    SpinalTagReady
  75. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  76. def isNamed: Boolean

    Permalink
    Definition Classes
    Nameable
  77. def isPriorityApplicable(namePriority: Byte): Boolean

    Permalink
    Definition Classes
    Nameable
  78. def isUnnamed: Boolean

    Permalink
    Definition Classes
    Nameable
  79. var lastScopeStatement: Statement

    Permalink
    Definition Classes
    Statement
  80. var name: String

    Permalink
    Definition Classes
    Nameable
  81. var nameableRef: Nameable

    Permalink
    Attributes
    protected
    Definition Classes
    Nameable
  82. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  83. var nextScopeStatement: Statement

    Permalink
    Definition Classes
    Statement
  84. def normalizeInputs: Unit

    Permalink
    Definition Classes
    ExpressionContainer
  85. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @HotSpotIntrinsicCandidate()
  86. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @HotSpotIntrinsicCandidate()
  87. def onEachAttributes(doIt: (Attribute) ⇒ Unit): Unit

    Permalink
    Definition Classes
    SpinalTagReady
  88. def overrideLocalName(name: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  89. var parentScope: ScopeStatement

    Permalink
    Definition Classes
    ContextUser
  90. def randBoot(): Mem.this.type

    Permalink
  91. def readAsync(address: UInt, readUnderWrite: ReadUnderWritePolicy = dontCare): T

    Permalink
  92. def readAsyncImpl(address: UInt, data: Data, readUnderWrite: ReadUnderWritePolicy = dontCare, allowMixedWidth: Boolean): Unit

    Permalink
  93. def readSync(address: UInt, enable: Bool = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false): T

    Permalink
  94. def readSyncImpl(address: UInt, data: Data, enable: Bool = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false, allowMixedWidth: Boolean = false): Unit

    Permalink
  95. def readSyncMixedWidth(address: UInt, data: Data, enable: Bool = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false): Unit

    Permalink
  96. def readWriteSync(address: UInt, data: T, enable: Bool, write: Bool, mask: Bits = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false, duringWrite: DuringWritePolicy = dontCare): T

    Permalink
  97. def readWriteSyncImpl[U <: Data](address: UInt, data: U, enable: Bool, write: Bool, mask: Bits = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false, allowMixedWidth: Boolean = false, duringWrite: DuringWritePolicy = dontCare): U

    Permalink
  98. def readWriteSyncMixedWidth[U <: Data](address: UInt, data: U, enable: Bool, write: Bool, mask: Bits = null, readUnderWrite: ReadUnderWritePolicy = dontCare, clockCrossing: Boolean = false, duringWrite: DuringWritePolicy = dontCare): U

    Permalink
  99. var refOwner: RefOwnerType

    Permalink
    Definition Classes
    OwnableRef
  100. def reflectNames(): Unit

    Permalink
    Definition Classes
    Nameable
  101. def remapDrivingExpressions(func: (Expression) ⇒ Expression): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  102. def remapExpressions(func: (Expression) ⇒ Expression): Unit

    Permalink
  103. def removeStatement(): Unit

    Permalink
    Definition Classes
    Statement
  104. def removeStatementFromScope(): Unit

    Permalink
    Definition Classes
    Statement
  105. def removeTag(spinalTag: SpinalTag): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  106. def removeTags(tags: Iterable[SpinalTag]): Mem.this.type

    Permalink
    Definition Classes
    SpinalTagReady
  107. def rootScopeStatement: ScopeStatement

    Permalink
    Definition Classes
    Statement
  108. var scalaTrace: Throwable

    Permalink
    Definition Classes
    ScalaLocated
  109. def setCompositeName(nameable: Nameable, postfix: String, namePriority: Byte): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  110. def setCompositeName(nameable: Nameable, postfix: String, weak: Boolean): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  111. def setCompositeName(nameable: Nameable, postfix: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  112. def setCompositeName(nameable: Nameable, namePriority: Byte): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  113. def setCompositeName(nameable: Nameable, weak: Boolean): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  114. def setCompositeName(nameable: Nameable): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  115. def setLambdaName(isNameBody: ⇒ Boolean)(nameGen: ⇒ String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  116. def setName(name: String, namePriority: Byte): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  117. def setName(name: String, weak: Boolean): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  118. def setName(name: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  119. def setNameAsWeak(): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  120. def setPartialName(name: String, namePriority: Byte, owner: Any): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  121. def setPartialName(name: String, namePriority: Byte): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  122. def setPartialName(name: String, weak: Boolean): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  123. def setPartialName(owner: Nameable, name: String, namePriority: Byte): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  124. def setPartialName(owner: Nameable, name: String, weak: Boolean): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  125. def setPartialName(name: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  126. def setPartialName(owner: Nameable, name: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  127. def setPartialName(owner: Nameable): Mem.this.type

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

    Permalink
    Definition Classes
    OwnableRef
  129. def setScalaLocated(source: ScalaLocated): Mem.this.type

    Permalink
    Definition Classes
    ScalaLocated
  130. def setTechnology(tech: MemTechnologyKind): Unit

    Permalink
  131. def setWeakName(name: String): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  132. def spinalTags: LinkedHashSet[SpinalTag]

    Permalink
    Definition Classes
    SpinalTagReady
  133. def stabilized(func: (Expression) ⇒ Expression, seed: Expression): Expression

    Permalink
    Definition Classes
    ExpressionContainer
  134. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  135. var technology: MemTechnologyKind

    Permalink
  136. def toString(): String

    Permalink
    Definition Classes
    MemNameable → AnyRef → Any
  137. def toStringMultiLine(): String

    Permalink
    Definition Classes
    BaseNode
  138. def unsetName(): Mem.this.type

    Permalink
    Definition Classes
    Nameable
  139. final def wait(arg0: Long, arg1: Int): Unit

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

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  141. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  142. def walkDrivingExpressions(func: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  143. def walkExpression(func: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  144. def walkExpressionPostorder(func: (Expression) ⇒ Unit): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  145. def walkParentTreeStatements(func: (TreeStatement) ⇒ Unit): Unit

    Permalink
    Definition Classes
    Statement
  146. def walkParentTreeStatementsUntilRootScope(func: (TreeStatement) ⇒ Unit): Unit

    Permalink
    Definition Classes
    Statement
  147. def walkRemapDrivingExpressions(func: (Expression) ⇒ Expression): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  148. def walkRemapExpressions(func: (Expression) ⇒ Expression): Unit

    Permalink
    Definition Classes
    ExpressionContainer
  149. val width: Int

    Permalink
  150. val wordCount: Int

    Permalink
  151. val wordType: HardType[T]

    Permalink
  152. def write(address: UInt, data: T, enable: Bool = null, mask: Bits = null): Unit

    Permalink
  153. def writeImpl(address: UInt, data: Data, enable: Bool = null, mask: Bits = null, allowMixedWidth: Boolean = false): Unit

    Permalink
  154. def writeMixedWidth(address: UInt, data: Data, enable: Bool = null, mask: Bits = null): Unit

    Permalink

Deprecated Value Members

  1. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @Deprecated @deprecated @throws( classOf[java.lang.Throwable] )
    Deprecated

    (Since version ) see corresponding Javadoc for more information.

  2. def readSyncCC(address: UInt, enable: Bool = True, readUnderWrite: ReadUnderWritePolicy = dontCare): T

    Permalink
    Annotations
    @deprecated
    Deprecated

    (Since version ???) Use readSync with the corresponding arguments

Inherited from InComponent

Inherited from SpinalTagReady

Inherited from WidthProvider

Inherited from DeclarationStatement

Inherited from Nameable

Inherited from OwnableRef

Inherited from LeafStatement

Inherited from Statement

Inherited from BaseNode

Inherited from ContextUser

Inherited from ScalaLocated

Inherited from GlobalDataUser

Inherited from ExpressionContainer

Inherited from AnyRef

Inherited from Any

Ungrouped