Packages

object SyncReadMem extends SyncReadMem$Intf

Source
Mem.scala
Linear Supertypes
SyncReadMem$Intf, SourceInfoDoc, AnyRef, Any
Ordering
  1. Grouped
  2. Alphabetic
  3. By Inheritance
Inherited
  1. SyncReadMem
  2. SyncReadMem$Intf
  3. SourceInfoDoc
  4. AnyRef
  5. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Type Members

  1. type ReadUnderWrite = firrtl.ir.ReadUnderWrite.Value

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. val ReadFirst: firrtl.ir.ReadUnderWrite.Value
  5. val Undefined: firrtl.ir.ReadUnderWrite.Value
  6. val WriteFirst: firrtl.ir.ReadUnderWrite.Value
  7. def _applyImpl[T <: Data](size: Int, t: T, ruw: ReadUnderWrite)(implicit sourceInfo: SourceInfo): SyncReadMem[T]
    Attributes
    protected
  8. def _applyImpl[T <: Data](size: Int, t: T)(implicit sourceInfo: SourceInfo): SyncReadMem[T]
    Attributes
    protected
  9. def _applyImpl[T <: Data](size: BigInt, t: T, ruw: ReadUnderWrite = Undefined)(implicit sourceInfo: SourceInfo): SyncReadMem[T]
    Attributes
    protected
  10. macro def apply[T <: Data](size: Int, t: T, ruw: ReadUnderWrite): SyncReadMem[T]
    Definition Classes
    SyncReadMem$Intf
  11. macro def apply[T <: Data](size: Int, t: T): SyncReadMem[T]

    Creates a sequential/synchronous-read, sequential/synchronous-write SyncReadMem.

    Creates a sequential/synchronous-read, sequential/synchronous-write SyncReadMem.

    size

    number of elements in the memory

    t

    data type of memory element

    Definition Classes
    SyncReadMem$Intf
  12. macro def apply[T <: Data](size: BigInt, t: T, ruw: ReadUnderWrite): SyncReadMem[T]
    Definition Classes
    SyncReadMem$Intf
  13. macro def apply[T <: Data](size: BigInt, t: T): SyncReadMem[T]

    Creates a sequential/synchronous-read, sequential/synchronous-write SyncReadMem.

    Creates a sequential/synchronous-read, sequential/synchronous-write SyncReadMem.

    size

    number of elements in the memory

    t

    data type of memory element

    Definition Classes
    SyncReadMem$Intf
  14. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  15. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  16. def do_apply[T <: Data](size: Int, t: T, ruw: ReadUnderWrite)(implicit sourceInfo: SourceInfo): SyncReadMem[T]

    Definition Classes
    SyncReadMem$Intf
  17. def do_apply[T <: Data](size: Int, t: T)(implicit sourceInfo: SourceInfo): SyncReadMem[T]

    Definition Classes
    SyncReadMem$Intf
  18. def do_apply[T <: Data](size: BigInt, t: T, ruw: ReadUnderWrite = Undefined)(implicit sourceInfo: SourceInfo): SyncReadMem[T]

    Definition Classes
    SyncReadMem$Intf
  19. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  20. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  21. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  22. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  23. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  24. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  25. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  26. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  27. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  28. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  29. def toString(): String
    Definition Classes
    AnyRef → Any
  30. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  31. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  32. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Inherited from SyncReadMem$Intf

Inherited from SourceInfoDoc

Inherited from AnyRef

Inherited from Any

Ungrouped

SourceInfoTransformMacro

These internal methods are not part of the public-facing API!

The equivalent public-facing methods do not have the do_ prefix or have the same name. Use and look at the documentation for those. If you want left shift, use <<, not do_<<. If you want conversion to a Seq of Bools look at the asBools above, not the one below. Users can safely ignore every method in this group!

🐉🐉🐉 Here be dragons... 🐉🐉🐉

These do_X methods are used to enable both implicit passing of SourceInfo while also supporting chained apply methods. In effect all "normal" methods that you, as a user, will use in your designs, are converted to their "hidden", do_*, via macro transformations. Without using macros here, only one of the above wanted behaviors is allowed (implicit passing and chained applies)---the compiler interprets a chained apply as an explicit 'implicit' argument and will throw type errors.

The "normal", public-facing methods then take no SourceInfo. However, a macro transforms this public-facing method into a call to an internal, hidden do_* that takes an explicit SourceInfo by inserting an implicitly[SourceInfo] as the explicit argument.