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

Commit

Permalink
Fix invalid PCH error (#738)
Browse files Browse the repository at this point in the history
* simulator: Format displayed commands with quotes for multiple arguments

Signed-off-by: Eryk Szpotanski <[email protected]>

* VerilatorSimulator: Update default CFLAGS to avoid invalid PCH error

Signed-off-by: Eryk Szpotanski <[email protected]>

---------

Signed-off-by: Eryk Szpotanski <[email protected]>
  • Loading branch information
eszpotanski authored Aug 6, 2024
1 parent 82993eb commit da2b67b
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 8 deletions.
6 changes: 4 additions & 2 deletions src/main/scala/chiseltest/simulator/IcarusSimulator.scala
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,9 @@ private object IcarusSimulator extends Simulator with LazyLogging {
val success = ret.exitCode == 0 && os.exists(lib)
assert(
success,
s"failed to compiler VPI shared library for circuit ${topName} in work dir $compileDir\n" + cmd.mkString(" ")
s"failed to compiler VPI shared library for circuit ${topName} in work dir $compileDir\n" + Utils.quoteCmdArgs(
cmd
)
)
lib
}
Expand Down Expand Up @@ -141,7 +143,7 @@ private object IcarusSimulator extends Simulator with LazyLogging {
val ret = os.proc(cmd).call(cwd = os.pwd, check = false)

val success = ret.exitCode == 0 && os.exists(os.pwd / simBinary)
assert(success, s"iverilog command failed on circuit ${topName} in work dir $targetDir\n" + cmd.mkString(" "))
assert(success, s"iverilog command failed on circuit ${topName} in work dir $targetDir\n" + Utils.quoteCmdArgs(cmd))
Seq("vvp", simBinary.toString())
}

Expand Down
9 changes: 9 additions & 0 deletions src/main/scala/chiseltest/simulator/Utils.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// SPDX-License-Identifier: Apache-2.0

package chiseltest.simulator

object Utils {
def quoteCmdArgs(cmd: Seq[String]): String = {
cmd.map(arg => if (arg.contains(" ")) s""""$arg"""" else arg).mkString(" ")
}
}
8 changes: 4 additions & 4 deletions src/main/scala/chiseltest/simulator/VerilatorSimulator.scala
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ package chiseltest.simulator
import firrtl2._
import firrtl2.annotations._
import chiseltest.simulator.jna._
import chiseltest.simulator.Utils.quoteCmdArgs

case object VerilatorBackendAnnotation extends SimulatorAnnotation {
override def getSimulator: Simulator = VerilatorSimulator
Expand Down Expand Up @@ -219,7 +220,7 @@ private object VerilatorSimulator extends Simulator {
private def run(cmd: Seq[String], cwd: os.Path, verbose: Boolean): os.CommandResult = {
if (verbose) {
// print the command and pipe the output to stdout
println(cmd.mkString(" "))
println(quoteCmdArgs(cmd))
os.proc(cmd)
.call(cwd = cwd, stdout = os.ProcessOutput.Readlines(println), stderr = os.ProcessOutput.Readlines(println))
} else {
Expand All @@ -228,12 +229,11 @@ private object VerilatorSimulator extends Simulator {
}

private def DefaultCFlags(topName: String) = List(
"-O1",
"-Os",
"-DVL_USER_STOP",
"-DVL_USER_FATAL",
"-DVL_USER_FINISH", // this is required because we ant to overwrite the vl_finish function!
s"-DTOP_TYPE=V$topName",
s"-include V$topName.h"
s"-DTOP_TYPE=V$topName"
)

private def DefaultFlags(topName: String, verilatedDir: os.Path, cFlags: Seq[String], ldFlags: Seq[String]) = List(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -321,7 +321,7 @@ private[chiseltest] class IPCSimulatorContext(

private def start(): Unit = {
if (verbose)
println(s"""STARTING ${cmd.mkString(" ")}""")
println(s"""STARTING ${Utils.quoteCmdArgs(cmd)}""")
mwhile(!recvOutputs) {}
isRunning = true
}
Expand Down Expand Up @@ -417,7 +417,7 @@ private[chiseltest] class IPCSimulatorContext(
private object TesterProcess {
def apply(cmd: Seq[String], logs: ArrayBuffer[String], verbose: Boolean): Process = {
require(new java.io.File(cmd.head).exists, s"${cmd.head} doesn't exist")
val processBuilder = Process(cmd.mkString(" "))
val processBuilder = Process(Utils.quoteCmdArgs(cmd))
// This makes everything written to stderr get added as lines to logs
val processLogger = ProcessLogger(
{ str => if (verbose) println(str) },
Expand Down

0 comments on commit da2b67b

Please sign in to comment.