Packages

sealed trait SimLog extends SimLogIntf

A file or I/O device to print to in simulation

val log = SimLog.file("logfile.log")
log.printf(cf"in = $in%0d\n")

val stderr = SimLog.StdErr
stderr.printf(cf"in = $in%0d\n")

// SimLog filenames themselves can be Printable.
// Be careful to avoid uninitialized registers.
val idx = Wire(UInt(8.W))
val log2 = SimLog.file(cf"logfile_$idx%0d.log")
log2.printf(cf"in = $in%0d\n")
Source
SimLog.scala
Linear Supertypes
SimLogIntf, AnyRef, Any
Type Hierarchy
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SimLog
  2. SimLogIntf
  3. AnyRef
  4. Any
Implicitly
  1. by any2stringadd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Abstract Value Members

  1. abstract def _filename: Option[Printable]
    Attributes
    protected

Concrete Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. def +(other: String): String
    Implicit
    This member is added by an implicit conversion from SimLog toany2stringadd[SimLog] performed by method any2stringadd in scala.Predef.
    Definition Classes
    any2stringadd
  4. def ->[B](y: B): (SimLog, B)
    Implicit
    This member is added by an implicit conversion from SimLog toArrowAssoc[SimLog] performed by method ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc
    Annotations
    @inline()
  5. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  6. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  7. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  8. def ensuring(cond: (SimLog) => Boolean, msg: => Any): SimLog
    Implicit
    This member is added by an implicit conversion from SimLog toEnsuring[SimLog] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  9. def ensuring(cond: (SimLog) => Boolean): SimLog
    Implicit
    This member is added by an implicit conversion from SimLog toEnsuring[SimLog] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  10. def ensuring(cond: Boolean, msg: => Any): SimLog
    Implicit
    This member is added by an implicit conversion from SimLog toEnsuring[SimLog] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  11. def ensuring(cond: Boolean): SimLog
    Implicit
    This member is added by an implicit conversion from SimLog toEnsuring[SimLog] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  12. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  13. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  14. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  15. def flush()(implicit sourceInfo: SourceInfo): Unit

    Flush any buffered output immediately

  16. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  17. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  18. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  19. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  20. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  21. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  22. def printf(pable: Printable)(implicit sourceInfo: SourceInfo): Printf

    Prints a message in simulation

    Prints a message in simulation

    Prints a message every cycle. If defined within the scope of a when block, the message will only be printed on cycles that the when condition is true.

    Does not fire when in reset (defined as the encapsulating Module's reset). If your definition of reset is not the encapsulating Module's reset, you will need to gate this externally.

    May be called outside of a Module (like defined in a function), uses the current default clock and reset. These can be overriden with withClockAndReset.

    pable

    Printable to print

    See also

    Printable documentation

  23. macro def printf(fmt: String, data: Bits*)(implicit sourceInfo: SourceInfo): Printf

    Prints a message in simulation

    Prints a message in simulation

    Prints a message every cycle. If defined within the scope of a when block, the message will only be printed on cycles that the when condition is true.

    Does not fire when in reset (defined as the encapsulating Module's reset). If your definition of reset is not the encapsulating Module's reset, you will need to gate this externally.

    May be called outside of a Module (like defined in a function), uses the current default clock and reset. These can be overriden with withClockAndReset.

    Format Strings

    This method expects a format string and an argument list in a similar style to printf in C. The format string expects a String that may contain format specifiers For example:

    printf("myWire has the value %d\n", myWire)

    This prints the string "myWire has the value " followed by the current value of myWire (in decimal, followed by a newline.

    There must be exactly as many arguments as there are format specifiers

    Format Specifiers

    Format specifiers are prefixed by %. If you wish to print a literal %, use %%.

    • %d - Decimal
    • %x - Hexadecimal
    • %b - Binary
    • %c - 8-bit Character
    • %n - Name of a signal
    • %N - Full name of a leaf signal (in an aggregate)
    • %% - Literal percent
    • %m - Hierarchical name of the current module
    • %T - Simulation time
    fmt

    printf format string

    data

    format string varargs containing data to print

    Definition Classes
    SimLogIntf
  24. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  25. def toString(): String
    Definition Classes
    AnyRef → Any
  26. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  27. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  28. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Deprecated Value Members

  1. def formatted(fmtstr: String): String
    Implicit
    This member is added by an implicit conversion from SimLog toStringFormat[SimLog] performed by method StringFormat in scala.Predef.
    Definition Classes
    StringFormat
    Annotations
    @deprecated @inline()
    Deprecated

    (Since version 2.12.16) Use formatString.format(value) instead of value.formatted(formatString), or use the f"" string interpolator. In Java 15 and later, formatted resolves to the new method in String which has reversed parameters.

  2. def [B](y: B): (SimLog, B)
    Implicit
    This member is added by an implicit conversion from SimLog toArrowAssoc[SimLog] performed by method ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc
    Annotations
    @deprecated
    Deprecated

    (Since version 2.13.0) Use -> instead. If you still wish to display it as one character, consider using a font with programming ligatures such as Fira Code.

Inherited from SimLogIntf

Inherited from AnyRef

Inherited from Any

Inherited by implicit conversion any2stringadd fromSimLog to any2stringadd[SimLog]

Inherited by implicit conversion StringFormat fromSimLog to StringFormat[SimLog]

Inherited by implicit conversion Ensuring fromSimLog to Ensuring[SimLog]

Inherited by implicit conversion ArrowAssoc fromSimLog to ArrowAssoc[SimLog]

Ungrouped