Class/Object

treadle.executable

Scheduler

Related Docs: object Scheduler | package executable

Permalink

class Scheduler extends LazyLogging

The scheduler holds the ordered assignment statements of the entire circuit. Clocks have magic shadow symbols "clockName/prev". These shadows are used to make the circuit evaluation idempotent, i.e. evaluating the circuit at the moment of an positive clock transition can be done repeatedly and registers will only be advanced on the first call.

Source
Scheduler.scala
Linear Supertypes
LazyLogging, AnyRef, Any
Type Hierarchy
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Scheduler
  2. LazyLogging
  3. AnyRef
  4. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Scheduler(symbolTable: SymbolTable)

    Permalink

    symbolTable

    symbol table is used to find orphans

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. def addAssigner(symbol: Symbol, assigner: Assigner, excludeFromCombinational: Boolean = false): Unit

    Permalink
  5. def addEndOfCycleAssigner(assigner: Assigner): Unit

    Permalink
  6. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  7. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. var combinationalAssigns: ArrayBuffer[Assigner]

    Permalink
  9. val endOfCycleAssigns: HashSet[Assigner]

    Permalink
  10. final def eq(arg0: AnyRef): Boolean

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

    Permalink
    Definition Classes
    AnyRef → Any
  12. def executeCombinationalAssigns(): Unit

    Permalink

    updates signals that depend on inputs

  13. def executeOrphanedAssigns(): Unit

    Permalink

    updates signals that depend on inputs

  14. var executionEngineOpt: Option[ExecutionEngine]

    Permalink
  15. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  16. def getAllAssigners: Seq[Assigner]

    Permalink
  17. def getAssignerInfo(symbolName: String): Info

    Permalink
  18. def getAssignerInfo(symbol: Symbol): Info

    Permalink
  19. def getAssigners(symbols: Seq[Symbol]): Seq[Assigner]

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

    Permalink
    Definition Classes
    AnyRef → Any
  21. def hasAssigner(symbol: Symbol): Boolean

    Permalink
  22. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  23. def inputChildrenAssigners(): Seq[Assigner]

    Permalink
  24. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  25. val logger: Logger

    Permalink
    Attributes
    protected
    Definition Classes
    LazyLogging
  26. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  27. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  28. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  29. def organizeAssigners(): Unit

    Permalink
  30. val orphanedAssigns: ArrayBuffer[Assigner]

    Permalink
  31. def render(engine: ExecutionEngine): String

    Permalink

    Render the assigners managed by this scheduler

  32. def setLeanMode(setLean: Boolean): Unit

    Permalink
  33. def setOrphanedAssigners(assigners: Seq[Assigner]): Unit

    Permalink
  34. def setVerboseAssign(isVerbose: Boolean): Unit

    Permalink
  35. def sortInputSensitiveAssigns(): Unit

    Permalink

    de-duplicates and sorts assignments that depend on top level inputs.

  36. val symbolTable: SymbolTable

    Permalink

    symbol table is used to find orphans

  37. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  38. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  39. final def wait(): Unit

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

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

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from LazyLogging

Inherited from AnyRef

Inherited from Any

Ungrouped