diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/main/scala/firrtl/transforms/formal/ConvertAsserts.scala | 39 | ||||
| -rw-r--r-- | src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala | 2 |
2 files changed, 40 insertions, 1 deletions
diff --git a/src/main/scala/firrtl/transforms/formal/ConvertAsserts.scala b/src/main/scala/firrtl/transforms/formal/ConvertAsserts.scala new file mode 100644 index 00000000..ddead331 --- /dev/null +++ b/src/main/scala/firrtl/transforms/formal/ConvertAsserts.scala @@ -0,0 +1,39 @@ +// See LICENSE for license details. + +package firrtl.transforms.formal + +import firrtl._ +import firrtl.ir._ +import firrtl.options.Dependency + +/** Convert Asserts + * + * Replaces all Assert nodes with a gated print-and-stop. This effectively + * emulates the assert for IEEE 1364 Verilog. + */ +object ConvertAsserts extends Transform with DependencyAPIMigration { + override def prerequisites = Nil + override def optionalPrerequisites = Nil + override def optionalPrerequisiteOf = Seq( + Dependency[VerilogEmitter], + Dependency[MinimumVerilogEmitter], + Dependency[RemoveVerificationStatements]) + + override def invalidates(a: Transform): Boolean = false + + def convertAsserts(stmt: Statement): Statement = stmt match { + case Verification(Formal.Assert, i, clk, pred, en, msg) => + val nPred = DoPrim(PrimOps.Not, Seq(pred), Nil, pred.tpe) + val gatedNPred = DoPrim(PrimOps.And, Seq(nPred, en), Nil, pred.tpe) + val stop = Stop(i, 1, clk, gatedNPred) + msg match { + case StringLit("") => stop + case _ => Block(Print(i, msg, Nil, clk, gatedNPred), stop) + } + case s => s.mapStmt(convertAsserts) + } + + def execute(state: CircuitState): CircuitState = { + state.copy(circuit = state.circuit.mapModule(m => m.mapStmt(convertAsserts))) + } +} diff --git a/src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala b/src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala index 40626765..72890c07 100644 --- a/src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala +++ b/src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala @@ -19,7 +19,7 @@ class RemoveVerificationStatements extends Transform with PreservesAll[Transform] { override def prerequisites: Seq[TransformDependency] = Seq.empty - override def optionalPrerequisites: Seq[TransformDependency] = Seq.empty + override def optionalPrerequisites: Seq[TransformDependency] = Seq(Dependency(ConvertAsserts)) override def optionalPrerequisiteOf: Seq[TransformDependency] = Seq( Dependency[VerilogEmitter], Dependency[MinimumVerilogEmitter]) |
