Skip to content
This repository has been archived by the owner on Aug 20, 2024. It is now read-only.

Multi protobuf module emission and consumption #2344

Merged
merged 25 commits into from
Sep 8, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
38a2786
Multiprotobuf algorithm now pulls the top module from the protobufs
jardhu Aug 16, 2021
4194f86
Remove double assignment compilation error
jardhu Aug 16, 2021
47c3a1b
Add compiler option to emit individual module protobufs
jardhu Aug 23, 2021
abae2b2
Scalafmt
jardhu Aug 23, 2021
7b1817a
Compiler options for proto buf emission
jardhu Aug 24, 2021
2362a75
Implement multi module combination when reading directory of protobufs
jardhu Aug 27, 2021
e2245c0
Use foreacher in protobuf emitter
jardhu Aug 31, 2021
3155a0a
Revert directoryToCircuit change
jardhu Aug 31, 2021
beeec3e
Low opt option now properly uses low opt emitter
jardhu Aug 31, 2021
691994a
emit-modules-protobuf for long -e option
jared-barocsi Sep 1, 2021
3c39745
Directory annotation now correctly throws exceptions
jardhu Sep 1, 2021
0b53842
Dedup collects extmodules if they don't have an accompanying implemen…
jardhu Sep 2, 2021
e161016
Absolute paths for exception references in scala doc
jardhu Sep 2, 2021
c6704d3
Compiler option tests
jardhu Sep 2, 2021
c99ed1e
Fix multiple inclusion of top module in combined circuit
jardhu Sep 2, 2021
f420097
Only one stage is sufficient for multiprotobuf test
jardhu Sep 2, 2021
f991a28
Multi-module circuit combination tests
jardhu Sep 3, 2021
e2189c4
Update src/test/scala/firrtlTests/stage/FirrtlMainSpec.scala
jared-barocsi Sep 3, 2021
c26f7d8
Multi protobuf test checks output circuit against input for equality
jardhu Sep 3, 2021
118ff7d
Move collectInstantiatedModules into private util function
jardhu Sep 4, 2021
0885f70
Comment cleanup
jardhu Sep 7, 2021
4830c89
Rename file -> dir in scaladoc
jardhu Sep 7, 2021
5942386
Apply suggestions from code review
jared-barocsi Sep 8, 2021
fc136d4
Scalafmt
jardhu Sep 8, 2021
ed93404
Merge branch 'master' into multi-protobufs
jackkoenig Sep 8, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Compiler options for proto buf emission
  • Loading branch information
jardhu committed Aug 24, 2021
commit 7b1817ab13c43b2ae6246bad4e5db70696a77867
49 changes: 44 additions & 5 deletions src/main/scala/firrtl/backends/proto/ProtoBufEmitter.scala
Original file line number Diff line number Diff line change
@@ -1,15 +1,17 @@
// SPDX-License-Identifier: Apache-2.0
package firrtl.backends.proto

import firrtl.{AnnotationSeq, CircuitState, DependencyAPIMigration, Transform}
import firrtl.ir
import firrtl._
import firrtl.ir._
import firrtl.annotations.NoTargetAnnotation
import firrtl.options.CustomFileEmission
import firrtl.options.Viewer.view
import firrtl.proto.ToProto
import firrtl.stage.{FirrtlOptions, Forms}
import firrtl.stage.TransformManager.TransformDependency
import java.io.{ByteArrayOutputStream, Writer}
import scala.collection.mutable.ArrayBuffer
import Utils.throwInternalError

/** This object defines Annotations that are used by Protocol Buffer emission.
*/
Expand Down Expand Up @@ -59,10 +61,47 @@ sealed abstract class ProtoBufEmitter(prereqs: Seq[TransformDependency])
override def optionalPrerequisiteOf = Seq.empty
override def invalidates(a: Transform) = false

override def execute(state: CircuitState) =
state.copy(annotations = state.annotations :+ Annotation.ProtoBufSerialization(state.circuit, Some(outputSuffix)))
private def emitAllModules(circuit: Circuit): Seq[Annotation.ProtoBufSerialization] = {
// For a given module, returns a Seq of all modules instantited inside of it
def collectInstantiatedModules(mod: Module, map: Map[String, DefModule]): Seq[DefModule] = {
// Use list instead of set to maintain order
val modules = ArrayBuffer.empty[DefModule]
def onStmt(stmt: Statement): Unit = stmt match {
case DefInstance(_, _, name, _) => modules += map(name)
case _: WDefInstanceConnector => throwInternalError(s"unrecognized statement: $stmt")
case other => other.foreach(onStmt)
}
onStmt(mod.body)
modules.distinct.toSeq
}
val modMap = circuit.modules.map(m => m.name -> m).toMap
// Turn each module into it's own circuit with it as the top and all instantied modules as ExtModules
circuit.modules.collect {
case m: Module =>
val instModules = collectInstantiatedModules(m, modMap)
val extModules = instModules.map {
case Module(info, name, ports, _) => ExtModule(info, name, ports, name, Seq.empty)
case ext: ExtModule => ext
}
val newCircuit = Circuit(m.info, extModules :+ m, m.name)
Annotation.ProtoBufSerialization(newCircuit, Some(outputSuffix))
}
}
jared-barocsi marked this conversation as resolved.
Show resolved Hide resolved

override def execute(state: CircuitState) = {
val newAnnos = state.annotations.flatMap {
case EmitCircuitAnnotation(a) if this.getClass == a =>
Seq(
Annotation.ProtoBufSerialization(state.circuit, Some(outputSuffix))
)
case EmitAllModulesAnnotation(a) if this.getClass == a =>
emitAllModules(state.circuit)
case _ => Seq()
}
state.copy(annotations = newAnnos ++ state.annotations)
}

override def emit(state: CircuitState, writer: Writer): Unit = {
def emit(state: CircuitState, writer: Writer): Unit = {
val ostream = new java.io.ByteArrayOutputStream
ToProto.writeToStream(ostream, state.circuit)
writer.write(ostream.toString())
Expand Down
1 change: 0 additions & 1 deletion src/main/scala/firrtl/stage/FirrtlAnnotations.scala
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@ object FirrtlFileAnnotation extends HasShellOptions {

/** Read a directory of FIRRTL files or ProtoBufs
* - set with `-I/--input-directory`
* - If unset, an [[FirrtlFileAnnotation]] with the default input file __will not be generated__
* @param file input filename
jared-barocsi marked this conversation as resolved.
Show resolved Hide resolved
*/
case class FirrtlDirectoryAnnotation(dir: String) extends NoTargetAnnotation with CircuitOption {
Expand Down
1 change: 1 addition & 0 deletions src/main/scala/firrtl/stage/FirrtlCli.scala
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ trait FirrtlCli { this: Shell =>
parser.note("FIRRTL Compiler Options")
Seq(
FirrtlFileAnnotation,
FirrtlDirectoryAnnotation,
OutputFileAnnotation,
InfoModeAnnotation,
FirrtlSourceAnnotation,
Expand Down