aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/firrtl/analyses/Netlist.scala
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/scala/firrtl/analyses/Netlist.scala')
-rw-r--r--src/main/scala/firrtl/analyses/Netlist.scala74
1 files changed, 74 insertions, 0 deletions
diff --git a/src/main/scala/firrtl/analyses/Netlist.scala b/src/main/scala/firrtl/analyses/Netlist.scala
new file mode 100644
index 00000000..c83dcc2b
--- /dev/null
+++ b/src/main/scala/firrtl/analyses/Netlist.scala
@@ -0,0 +1,74 @@
+package firrtl.analyses
+
+import scala.collection.mutable
+
+import firrtl._
+import firrtl.ir._
+import firrtl.graph._
+import firrtl.Utils._
+import firrtl.Mappers._
+
+
+/** A class representing the instance hierarchy of a working IR Circuit
+ *
+ * @constructor constructs an instance graph from a Circuit
+ * @param c the Circuit to analyze
+ */
+class InstanceGraph(c: Circuit) {
+
+ private def collectInstances(insts: mutable.Set[WDefInstance])(s: Statement): Statement = s match {
+ case i: WDefInstance =>
+ insts += i
+ i
+ case _ =>
+ s map collectInstances(insts)
+ }
+
+ private val moduleMap = c.modules.map({m => (m.name,m) }).toMap
+ private val childInstances =
+ new mutable.HashMap[String,mutable.Set[WDefInstance]]
+ for (m <- c.modules) {
+ childInstances(m.name) = new mutable.HashSet[WDefInstance]
+ m map collectInstances(childInstances(m.name))
+ }
+ private val instanceGraph = new MutableDiGraph[WDefInstance]
+ private val instanceQueue = new mutable.Queue[WDefInstance]
+ private val topInstance = WDefInstance(c.main,c.main) // top instance
+ instanceQueue.enqueue(topInstance)
+ while (!instanceQueue.isEmpty) {
+ val current = instanceQueue.dequeue
+ instanceGraph.addVertex(current)
+ for (child <- childInstances(current.module)) {
+ if (!instanceGraph.contains(child)) {
+ instanceQueue.enqueue(child)
+ }
+ instanceGraph.addEdge(current,child)
+ }
+ }
+
+ /** A directed graph showing the instance dependencies among modules
+ * in the circuit. Every WDefInstance of a module has an edge to
+ * every WDefInstance arising from every instance statement in
+ * that module.
+ */
+ lazy val graph = DiGraph(instanceGraph)
+
+ /** A list of absolute paths (each represented by a Seq of instances)
+ * of all module instances in the Circuit.
+ */
+ lazy val fullHierarchy = graph.pathsInDAG(topInstance)
+
+ /** Finds the absolute paths (each represented by a Seq of instances
+ * representing the chain of hierarchy) of all instances of a
+ * particular module.
+ *
+ * @param module the name of the selected module
+ * @return a Seq[Seq[WDefInstance]] of absolute instance paths
+ */
+ def findInstancesInHierarchy(module: String): Seq[Seq[WDefInstance]] = {
+ val instances = graph.getVertices.filter(_.module == module).toSeq
+ instances flatMap { i => fullHierarchy(i) }
+ }
+
+}
+