diff options
| author | Schuyler Eldridge | 2019-12-17 18:29:47 -0500 |
|---|---|---|
| committer | Schuyler Eldridge | 2020-03-11 14:01:31 -0400 |
| commit | abf226471249a1cbb8de33d0c4bc8526f9aafa70 (patch) | |
| tree | 0537dff3091db3da167c0fffc3388a5966c46204 /src/main/scala/firrtl/passes/memlib | |
| parent | 646c91e71b8bfb1b0d0f22e81ca113147637ce71 (diff) | |
Migrate to DependencyAPI
Co-authored-by: Schuyler Eldridge <schuyler.eldridge@ibm.com>
Co-authored-by: Albert Magyar <albert.magyar@gmail.com>
Signed-off-by: Schuyler Eldridge <schuyler.eldridge@ibm.com>
Diffstat (limited to 'src/main/scala/firrtl/passes/memlib')
| -rw-r--r-- | src/main/scala/firrtl/passes/memlib/VerilogMemDelays.scala | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/main/scala/firrtl/passes/memlib/VerilogMemDelays.scala b/src/main/scala/firrtl/passes/memlib/VerilogMemDelays.scala index 80b5cbb8..e5e6d6d4 100644 --- a/src/main/scala/firrtl/passes/memlib/VerilogMemDelays.scala +++ b/src/main/scala/firrtl/passes/memlib/VerilogMemDelays.scala @@ -8,6 +8,8 @@ import firrtl.ir._ import firrtl.Utils._ import firrtl.Mappers._ import firrtl.traversals.Foreachers._ +import firrtl.transforms +import firrtl.options.Dependency import MemPortUtils._ import WrappedExpression._ @@ -69,7 +71,7 @@ object MemDelayAndReadwriteTransformer { * read and write ports while simultaneously compiling memory latencies to combinational-read * memories with delay pipelines. It is represented as a class that takes a module as a constructor * argument, as it encapsulates the mutable state required to analyze and transform one module. - * + * * @note The final transformed module is found in the (sole public) field [[transformed]] */ class MemDelayAndReadwriteTransformer(m: DefModule) { @@ -165,6 +167,18 @@ class MemDelayAndReadwriteTransformer(m: DefModule) { } object VerilogMemDelays extends Pass { + + override val prerequisites = firrtl.stage.Forms.LowForm :+ Dependency(firrtl.passes.RemoveValidIf) + + override val dependents = + Seq( Dependency[VerilogEmitter], + Dependency[SystemVerilogEmitter] ) + + override def invalidates(a: Transform): Boolean = a match { + case _: transforms.ConstantPropagation => true + case _ => false + } + def transform(m: DefModule): DefModule = (new MemDelayAndReadwriteTransformer(m)).transformed def run(c: Circuit): Circuit = c.copy(modules = c.modules.map(transform)) } |
