aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/firrtl/transforms/formal/RemoveVerificationStatements.scala
blob: 35e2d804d1ec7fc9ea23a0378f1a4c3c904ee443 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
// SPDX-License-Identifier: Apache-2.0

package firrtl.transforms.formal

import firrtl.ir.{Circuit, EmptyStmt, Statement, Verification}
import firrtl.{CircuitState, DependencyAPIMigration, MinimumVerilogEmitter, Transform, VerilogEmitter}
import firrtl.options.{Dependency, PreservesAll, StageUtils}
import firrtl.stage.TransformManager.TransformDependency

/**
  * Remove Verification Statements
  *
  * Replaces all verification statements in all modules with the empty statement.
  * This is intended to be required by the Verilog emitter to ensure compatibility
  * with the Verilog 2001 standard.
  */
class RemoveVerificationStatements extends Transform with DependencyAPIMigration with PreservesAll[Transform] {

  override def prerequisites:         Seq[TransformDependency] = Seq.empty
  override def optionalPrerequisites: Seq[TransformDependency] = Seq(Dependency(ConvertAsserts))
  override def optionalPrerequisiteOf: Seq[TransformDependency] =
    Seq(Dependency[VerilogEmitter], Dependency[MinimumVerilogEmitter])

  private var removedCounter = 0

  def removeVerification(s: Statement): Statement = s match {
    case _: Verification => {
      removedCounter += 1
      EmptyStmt
    }
    case t => t.mapStmt(removeVerification)
  }

  def run(c: Circuit): Circuit = {
    c.mapModule(mod => {
      mod.mapStmt(removeVerification)
    })
  }

  def execute(state: CircuitState): CircuitState = {
    val newState = state.copy(circuit = run(state.circuit))
    if (removedCounter > 0) {
      StageUtils.dramaticWarning(
        s"$removedCounter verification statements " +
          "(assert, assume or cover) " +
          "were removed when compiling to Verilog because the basic Verilog " +
          "standard does not support them. If this was not intended, compile " +
          "to System Verilog instead using the `-X sverilog` compiler flag."
      )
    }
    newState
  }
}