aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/firrtl/ExecutionOptionsManager.scala
diff options
context:
space:
mode:
authorSchuyler Eldridge2019-02-05 14:57:53 -0500
committerGitHub2019-02-05 14:57:53 -0500
commitd69c609fd41c2b6ca2993085bcd2923daa563bde (patch)
tree3d7a3bacd8debc917cd5525d6fdecdee6a50e31c /src/main/scala/firrtl/ExecutionOptionsManager.scala
parentfa0a6e2cbe2a78fc231f47b5b73d870669b54ade (diff)
parent0a88492bfbbfe7e446b74776ec59cab69e73585b (diff)
Merge pull request #1004 from seldridge/issue-423
Add "mverilog" Compiler Option, MinimumVerilogEmitter
Diffstat (limited to 'src/main/scala/firrtl/ExecutionOptionsManager.scala')
-rw-r--r--src/main/scala/firrtl/ExecutionOptionsManager.scala26
1 files changed, 16 insertions, 10 deletions
diff --git a/src/main/scala/firrtl/ExecutionOptionsManager.scala b/src/main/scala/firrtl/ExecutionOptionsManager.scala
index 16e30f3a..47083cb4 100644
--- a/src/main/scala/firrtl/ExecutionOptionsManager.scala
+++ b/src/main/scala/firrtl/ExecutionOptionsManager.scala
@@ -207,18 +207,19 @@ extends ComposableOptions {
case "low" => new LowFirrtlCompiler()
case "middle" => new MiddleFirrtlCompiler()
case "verilog" => new VerilogCompiler()
+ case "mverilog" => new MinimumVerilogCompiler()
case "sverilog" => new SystemVerilogCompiler()
}
}
def outputSuffix: String = {
compilerName match {
- case "verilog" => "v"
- case "sverilog" => "sv"
- case "low" => "lo.fir"
- case "middle" => "mid.fir"
- case "high" => "hi.fir"
- case "none" => "fir"
+ case "verilog" | "mverilog" => "v"
+ case "sverilog" => "sv"
+ case "low" => "lo.fir"
+ case "middle" => "mid.fir"
+ case "high" => "hi.fir"
+ case "none" => "fir"
case _ =>
throw new Exception(s"Illegal compiler name $compilerName")
}
@@ -267,6 +268,7 @@ extends ComposableOptions {
case "middle" => classOf[MiddleFirrtlEmitter]
case "low" => classOf[LowFirrtlEmitter]
case "verilog" => classOf[VerilogEmitter]
+ case "mverilog" => classOf[MinimumVerilogEmitter]
case "sverilog" => classOf[VerilogEmitter]
}
getOutputConfig(optionsManager) match {
@@ -344,13 +346,16 @@ trait HasFirrtlOptions {
parser.opt[String]("compiler")
.abbr("X")
- .valueName ("<high|middle|low|verilog|sverilog|none>")
+ .valueName ("<high|middle|low|verilog|mverilog|sverilog|none>")
.foreach { x =>
firrtlOptions = firrtlOptions.copy(compilerName = x)
}
.validate { x =>
- if (Array("high", "middle", "low", "verilog", "sverilog", "none").contains(x.toLowerCase)) parser.success
- else parser.failure(s"$x not a legal compiler")
+ if (Array("high", "middle", "low", "verilog", "mverilog", "sverilog", "none").contains(x.toLowerCase)) {
+ parser.success
+ } else {
+ parser.failure(s"$x not a legal compiler")
+ }
}.text {
s"compiler to use, default is ${firrtlOptions.compilerName}"
}
@@ -492,7 +497,8 @@ object FirrtlExecutionSuccess {
* Indicates a successful execution of the firrtl compiler, returning the compiled result and
* the type of compile
*
- * @param emitType The name of the compiler used, currently "high", "middle", "low", "verilog", or "sverilog"
+ * @param emitType The name of the compiler used, currently "high", "middle", "low", "verilog", "mverilog", or
+ * "sverilog"
* @param emitted The emitted result of compilation
*/
class FirrtlExecutionSuccess(