class PromoteSubmodule extends Transform
Takes PromoteSubmodule annotations for instantiations and causes each corresponding instance to be removed; ports are added to the parent module and the submodule is added as a peer instance to all modules instantiating the parent module.
Module nomenclature: Grandparent = instantiator of parent. Transformed to instantiate child alongside parent, connect. Parent = instantiator of child. Transformed to get port of child IO instead of instantiating child. Child = submodule to be promoted. Does not get transformed.
Linear Supertypes
Ordering
- Alphabetic
- By Inheritance
Inherited
- PromoteSubmodule
- Transform
- DependencyAPI
- TransformLike
- LazyLogging
- AnyRef
- Any
- Hide All
- Show All
Visibility
- Public
- Protected
Instance Constructors
- new PromoteSubmodule()
Value Members
- def execute(state: CircuitState): CircuitState
- Definition Classes
- PromoteSubmodule → Transform
- def getLogger: Logger
- Definition Classes
- LazyLogging
- def inputForm: HighForm
- Definition Classes
- PromoteSubmodule → Transform
- def invalidates(a: Transform): Boolean
- Definition Classes
- Transform → DependencyAPI
- def name: String
- Definition Classes
- Transform → TransformLike
- def optionalPrerequisiteOf: Seq[Dependency[Transform]]
- Definition Classes
- Transform → DependencyAPI
- def optionalPrerequisites: Seq[Dependency[Transform]]
- Definition Classes
- Transform → DependencyAPI
- def outputForm: HighForm
- Definition Classes
- PromoteSubmodule → Transform
- def prerequisites: Seq[Dependency[Transform]]
- Definition Classes
- Transform → DependencyAPI
- final def runTransform(state: CircuitState): CircuitState
- Definition Classes
- Transform
- def transform(state: CircuitState): CircuitState
- Definition Classes
- Transform → TransformLike
Deprecated Value Members
- def dependents: Seq[Dependency[Transform]]
- Definition Classes
- DependencyAPI
- Annotations
- @deprecated
- Deprecated
(Since version FIRRTL 1.3) Due to confusion, 'dependents' is being renamed to 'optionalPrerequisiteOf'. Override the latter instead.