class DispatchPlugin extends FiberPlugin
The role of the dispatch plugin is to : - Collect the instruction exiting the decode pipeline, - Figuring out on which execution lane they could be scheduled (checking for dependencies). If none, then wait for some. - Issue instructions on execution lanes
It is likely one of the hardest plugin to read, as it does a lot of elaboration time analysis to generate the "right" hadware
How to check if a instruction can schedule : - If one of the pipeline which implement its micro op is free - There is no inflight non-bypassed RF write to one of the source operand - There is no scheduling fence - ...
Schedule heuristic : - In priority order, go through the slots - Check which pipeline could schedule it (free && compatible) - Select the pipeline which the highest priority (to avoid using the one which can do load and store, for instance) - If the slot can't be schedule, disable all following ones with same HART_ID
- Alphabetic
- By Inheritance
- DispatchPlugin
- FiberPlugin
- Hostable
- Area
- OverridedEqualsHashCode
- ValCallbackRec
- ValCallback
- NameableByComponent
- Nameable
- ContextUser
- ScalaLocated
- GlobalDataUser
- OwnableRef
- AnyRef
- Any
- Hide All
- Show All
- Public
- All
Instance Constructors
Type Members
-
abstract
type
RefOwnerType
- Definition Classes
- OwnableRef
Value Members
- val DONT_FLUSH: NamedType[Bool]
- val DONT_FLUSH_FROM_LANES: NamedType[Bool]
- val FENCE_OLDER: NamedType[Bool]
- val MAY_FLUSH: NamedType[Bool]
-
val
_context: Capture
- Definition Classes
- Area
- def addDispatchCtx(that: NamedType[_ <: Data]): LinkedHashSet[NamedType[_ <: Data]]
-
def
addService[T](that: T): T
- Definition Classes
- FiberPlugin
- val api: Handle[Area { val haltDispatch: spinal.core.Bool }]
-
def
awaitBuild(): Unit
- Definition Classes
- FiberPlugin
-
def
buildBefore(l: ⇒ Lock): Unit
- Definition Classes
- FiberPlugin
-
var
buildCount: Int
- Definition Classes
- FiberPlugin
-
def
childNamePriority: Byte
- Definition Classes
- Area
-
def
component: Component
- Definition Classes
- ContextUser
- var dispatchAt: Int
-
def
during: AnyRef { ... /* 2 definitions in type refinement */ }
- Definition Classes
- FiberPlugin
- val elaborationLock: Retainer
-
def
equals(obj: Any): Boolean
- Definition Classes
- OverridedEqualsHashCode → AnyRef → Any
- def fenceOlder(op: MicroOp): LinkedHashSet[MicroOp]
- val fenceOlderOps: LinkedHashSet[MicroOp]
-
def
foreachReflectableNameables(doThat: (Any) ⇒ Unit): Unit
- Definition Classes
- Nameable
-
def
getDisplayName(): String
- Definition Classes
- Nameable
-
def
getInstanceCounter: Int
- Definition Classes
- ContextUser
-
def
getName(default: String): String
- Definition Classes
- NameableByComponent → Nameable
-
def
getName(): String
- Definition Classes
- NameableByComponent → Nameable
-
def
getPartialName(): String
- Definition Classes
- Nameable
-
def
getPath(from: Component, to: Component): Seq[Component]
- Definition Classes
- NameableByComponent
-
def
getRefOwnersChain(): List[Any]
- Definition Classes
- OwnableRef
-
def
getScalaLocationLong: String
- Definition Classes
- ScalaLocated
-
def
getScalaLocationShort: String
- Definition Classes
- ScalaLocated
-
def
getScalaTrace(): Throwable
- Definition Classes
- ScalaLocated
-
val
globalData: GlobalData
- Definition Classes
- GlobalDataUser
- def haltDispatchWhen(cond: Bool): Bool
-
def
hashCode(): Int
- Definition Classes
- OverridedEqualsHashCode → AnyRef → Any
- val hmKeys: LinkedHashSet[NamedType[_ <: Data]]
-
var
host: PluginHost
- Definition Classes
- FiberPlugin
-
val
hostLock: Lock
- Definition Classes
- FiberPlugin
-
def
isCompletelyUnnamed: Boolean
- Definition Classes
- Nameable
-
final
def
isNamed: Boolean
- Definition Classes
- Nameable
-
def
isPriorityApplicable(namePriority: Byte): Boolean
- Definition Classes
- Nameable
-
def
isUnnamed: Boolean
- Definition Classes
- NameableByComponent → Nameable
-
val
lockables: LinkedHashSet[() ⇒ Lock]
- Definition Classes
- FiberPlugin
- val logic: Handle[Area { ... /* 58 definitions in type refinement */ }]
-
val
name: String
- Definition Classes
- Nameable
-
def
overrideLocalName(name: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
val
parentScope: ScopeStatement
- Definition Classes
- ContextUser
-
var
pluginEnabled: Boolean
- Definition Classes
- FiberPlugin
-
val
refOwner: RefOwnerType
- Definition Classes
- OwnableRef
- Annotations
- @DontName()
-
def
reflectNames(): Unit
- Definition Classes
- Nameable
-
def
retains(head: Any, tail: Any*): RetainerGroup
- Definition Classes
- FiberPlugin
-
def
retains(that: Seq[Any]): RetainerGroup
- Definition Classes
- FiberPlugin
-
def
rework[T](body: ⇒ T): T
- Definition Classes
- Area
-
val
scalaTrace: Throwable
- Definition Classes
- ScalaLocated
-
def
setCompositeName(nameable: Nameable, postfix: String, namePriority: Byte): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setCompositeName(nameable: Nameable, postfix: String, weak: Boolean): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setCompositeName(nameable: Nameable, postfix: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setCompositeName(nameable: Nameable, namePriority: Byte): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setCompositeName(nameable: Nameable, weak: Boolean): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setCompositeName(nameable: Nameable): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setHost(h: PluginHost): Unit
- Definition Classes
- FiberPlugin → Hostable
-
def
setLambdaName(isNameBody: ⇒ Boolean)(nameGen: ⇒ String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setName(name: String, namePriority: Byte): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setName(name: String, weak: Boolean): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setName(name: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setNameAsWeak(): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(name: String, namePriority: Byte, owner: Any): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(name: String, namePriority: Byte): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(name: String, weak: Boolean): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(owner: Nameable, name: String, namePriority: Byte): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(owner: Nameable, name: String, weak: Boolean): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(name: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(owner: Nameable, name: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setPartialName(owner: Nameable): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setRefOwner(that: Any): Unit
- Definition Classes
- OwnableRef
-
def
setScalaLocated(source: ScalaLocated): DispatchPlugin.this.type
- Definition Classes
- ScalaLocated
-
def
setWeakName(name: String): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
setupRetain(l: ⇒ Lock): Unit
- Definition Classes
- FiberPlugin
-
val
subservices: ArrayBuffer[Any]
- Definition Classes
- FiberPlugin
-
def
toString(): String
- Definition Classes
- Area → Nameable → AnyRef → Any
- var trapLayer: LaneLayer
-
def
unsetName(): DispatchPlugin.this.type
- Definition Classes
- Nameable
-
def
valCallback[T](ref: T, name: String): T
- Definition Classes
- ValCallbackRec → ValCallback
-
def
valCallbackOn(ref: Any, name: String, refs: Set[Any]): Unit
- Definition Classes
- ValCallbackRec
-
def
valCallbackRec(obj: Any, name: String): Unit
- Definition Classes
- Area → ValCallbackRec
- var withBuffer: Boolean
-
def
withPrefix(prefix: String): FiberPlugin
- Definition Classes
- FiberPlugin