Used published dependencies for Chisel & Friends
This commit is contained in:
103
build.sbt
103
build.sbt
@@ -17,14 +17,7 @@ lazy val commonSettings = Seq(
|
|||||||
unmanagedBase := (chipyardRoot / unmanagedBase).value,
|
unmanagedBase := (chipyardRoot / unmanagedBase).value,
|
||||||
allDependencies := {
|
allDependencies := {
|
||||||
// drop specific maven dependencies in subprojects in favor of Chipyard's version
|
// drop specific maven dependencies in subprojects in favor of Chipyard's version
|
||||||
val dropDeps = Seq(
|
val dropDeps = Seq(("edu.berkeley.cs", "rocketchip"))
|
||||||
("edu.berkeley.cs", "firrtl"),
|
|
||||||
("edu.berkeley.cs", "chisel3"),
|
|
||||||
("edu.berkeley.cs", "rocketchip"),
|
|
||||||
("edu.berkeley.cs", "chisel-iotesters"),
|
|
||||||
("edu.berkeley.cs", "treadle"),
|
|
||||||
("edu.berkeley.cs", "firrtl-interpreter"))
|
|
||||||
|
|
||||||
allDependencies.value.filterNot { dep =>
|
allDependencies.value.filterNot { dep =>
|
||||||
dropDeps.contains((dep.organization, dep.name))
|
dropDeps.contains((dep.organization, dep.name))
|
||||||
}
|
}
|
||||||
@@ -67,34 +60,23 @@ def isolateAllTests(tests: Seq[TestDefinition]) = tests map { test =>
|
|||||||
new Group(test.name, Seq(test), SubProcess(options))
|
new Group(test.name, Seq(test), SubProcess(options))
|
||||||
} toSeq
|
} toSeq
|
||||||
|
|
||||||
|
val chiselVersion = "3.4.1"
|
||||||
|
|
||||||
|
lazy val chiselSettings = Seq(
|
||||||
|
libraryDependencies ++= Seq("edu.berkeley.cs" %% "chisel3" % chiselVersion),
|
||||||
|
addCompilerPlugin("edu.berkeley.cs" % "chisel3-plugin" % chiselVersion cross CrossVersion.full))
|
||||||
|
|
||||||
|
val firrtlVersion = "1.4.1"
|
||||||
|
|
||||||
|
lazy val firrtlSettings = Seq(libraryDependencies ++= Seq("edu.berkeley.cs" %% "firrtl" % firrtlVersion))
|
||||||
|
|
||||||
// Subproject definitions begin
|
// Subproject definitions begin
|
||||||
|
|
||||||
// -- Rocket Chip --
|
// -- Rocket Chip --
|
||||||
|
|
||||||
// This needs to stay in sync with the chisel3 and firrtl git submodules
|
// Rocket-chip dependencies (subsumes making RC a RootProject)
|
||||||
val chiselVersion = "3.4.1"
|
|
||||||
lazy val chiselRef = ProjectRef(workspaceDirectory / "chisel3", "chisel")
|
|
||||||
lazy val chiselLib = "edu.berkeley.cs" %% "chisel3" % chiselVersion
|
|
||||||
lazy val chiselLibDeps = (chiselRef / Keys.libraryDependencies)
|
|
||||||
// While not built from source, *must* be in sync with the chisel3 git submodule
|
|
||||||
// Building from source requires extending sbt-sriracha or a similar plugin and
|
|
||||||
// keeping scalaVersion in sync with chisel3 to the minor version
|
|
||||||
lazy val chiselPluginLib = "edu.berkeley.cs" % "chisel3-plugin" % chiselVersion cross CrossVersion.full
|
|
||||||
|
|
||||||
val firrtlVersion = "1.4.1"
|
|
||||||
lazy val firrtlRef = ProjectRef(workspaceDirectory / "firrtl", "firrtl")
|
|
||||||
lazy val firrtlLib = "edu.berkeley.cs" %% "firrtl" % firrtlVersion
|
|
||||||
val firrtlLibDeps = settingKey[Seq[sbt.librarymanagement.ModuleID]]("FIRRTL Library Dependencies sans antlr4")
|
|
||||||
Global / firrtlLibDeps := {
|
|
||||||
// drop antlr4 compile dep. but keep antlr4-runtime dep. (compile needs the plugin to be setup)
|
|
||||||
(firrtlRef / Keys.libraryDependencies).value.filterNot(_.name == "antlr4")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Rocket-chip dependencies (subsumes making RC a RootProject)
|
|
||||||
lazy val hardfloat = (project in rocketChipDir / "hardfloat")
|
lazy val hardfloat = (project in rocketChipDir / "hardfloat")
|
||||||
.sourceDependency(chiselRef, chiselLib)
|
.settings(chiselSettings)
|
||||||
.settings(addCompilerPlugin(chiselPluginLib))
|
|
||||||
.settings(libraryDependencies ++= chiselLibDeps.value)
|
|
||||||
.dependsOn(midasTargetUtils)
|
.dependsOn(midasTargetUtils)
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
.settings(
|
.settings(
|
||||||
@@ -126,11 +108,8 @@ lazy val rocketConfig = (project in rocketChipDir / "api-config-chipsalliance/bu
|
|||||||
)
|
)
|
||||||
|
|
||||||
lazy val rocketchip = freshProject("rocketchip", rocketChipDir)
|
lazy val rocketchip = freshProject("rocketchip", rocketChipDir)
|
||||||
.sourceDependency(chiselRef, chiselLib)
|
|
||||||
.settings(addCompilerPlugin(chiselPluginLib))
|
|
||||||
.settings(libraryDependencies ++= chiselLibDeps.value)
|
|
||||||
.dependsOn(hardfloat, rocketMacros, rocketConfig)
|
.dependsOn(hardfloat, rocketMacros, rocketConfig)
|
||||||
.settings(commonSettings)
|
.settings(commonSettings, chiselSettings)
|
||||||
.settings(
|
.settings(
|
||||||
libraryDependencies ++= Seq(
|
libraryDependencies ++= Seq(
|
||||||
"org.scala-lang" % "scala-reflect" % scalaVersion.value,
|
"org.scala-lang" % "scala-reflect" % scalaVersion.value,
|
||||||
@@ -145,29 +124,27 @@ lazy val rocketchip = freshProject("rocketchip", rocketChipDir)
|
|||||||
)
|
)
|
||||||
lazy val rocketLibDeps = (rocketchip / Keys.libraryDependencies)
|
lazy val rocketLibDeps = (rocketchip / Keys.libraryDependencies)
|
||||||
|
|
||||||
|
|
||||||
// -- Chipyard-managed External Projects --
|
// -- Chipyard-managed External Projects --
|
||||||
|
|
||||||
lazy val firrtl_interpreter = (project in file("tools/firrtl-interpreter"))
|
// Because we're not using a release version of iotesters to work around a
|
||||||
.sourceDependency(firrtlRef, firrtlLib)
|
// scala test version problem, override it's libdeps to prevent using snapshots
|
||||||
.settings(commonSettings)
|
lazy val chipyardMandatedVersions = Map(
|
||||||
.settings(libraryDependencies ++= (Global / firrtlLibDeps).value)
|
"chisel-iotesters" -> "1.5.4",
|
||||||
lazy val firrtlInterpreterLibDeps = (firrtl_interpreter / Keys.libraryDependencies)
|
"firrtl-interpreter" -> "1.4.4",
|
||||||
|
"treadle" -> "1.3.4",
|
||||||
lazy val treadle = (project in file("tools/treadle"))
|
"chisel3" -> chiselVersion,
|
||||||
.sourceDependency(firrtlRef, firrtlLib)
|
"firrtl" -> firrtlVersion
|
||||||
.settings(commonSettings)
|
)
|
||||||
.settings(libraryDependencies ++= (Global / firrtlLibDeps).value)
|
|
||||||
lazy val treadleLibDeps = (treadle / Keys.libraryDependencies)
|
|
||||||
|
|
||||||
lazy val chisel_testers = (project in file("tools/chisel-testers"))
|
lazy val chisel_testers = (project in file("tools/chisel-testers"))
|
||||||
.sourceDependency(chiselRef, chiselLib)
|
.settings(chiselSettings)
|
||||||
.settings(addCompilerPlugin(chiselPluginLib))
|
.settings(
|
||||||
.settings(libraryDependencies ++= chiselLibDeps.value)
|
allDependencies := allDependencies.value.map {
|
||||||
.dependsOn(firrtl_interpreter, treadle)
|
case dep if chipyardMandatedVersions.isDefinedAt(dep.name) =>
|
||||||
.settings(libraryDependencies ++= firrtlInterpreterLibDeps.value)
|
dep.organization %% dep.name % chipyardMandatedVersions(dep.name)
|
||||||
.settings(libraryDependencies ++= treadleLibDeps.value)
|
case o => o
|
||||||
.settings(commonSettings)
|
})
|
||||||
lazy val chiselTestersLibDeps = (chisel_testers / Keys.libraryDependencies)
|
|
||||||
|
|
||||||
// -- Normal Projects --
|
// -- Normal Projects --
|
||||||
|
|
||||||
@@ -231,14 +208,12 @@ lazy val sodor = (project in file("generators/riscv-sodor"))
|
|||||||
lazy val sha3 = (project in file("generators/sha3"))
|
lazy val sha3 = (project in file("generators/sha3"))
|
||||||
.dependsOn(rocketchip, chisel_testers, midasTargetUtils)
|
.dependsOn(rocketchip, chisel_testers, midasTargetUtils)
|
||||||
.settings(libraryDependencies ++= rocketLibDeps.value)
|
.settings(libraryDependencies ++= rocketLibDeps.value)
|
||||||
.settings(libraryDependencies ++= chiselTestersLibDeps.value)
|
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val gemmini = (project in file("generators/gemmini"))
|
lazy val gemmini = (project in file("generators/gemmini"))
|
||||||
.sourceDependency(testchipip, testchipipLib)
|
.sourceDependency(testchipip, testchipipLib)
|
||||||
.dependsOn(rocketchip, chisel_testers)
|
.dependsOn(rocketchip, chisel_testers)
|
||||||
.settings(libraryDependencies ++= rocketLibDeps.value)
|
.settings(libraryDependencies ++= rocketLibDeps.value)
|
||||||
.settings(libraryDependencies ++= chiselTestersLibDeps.value)
|
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val nvdla = (project in file("generators/nvdla"))
|
lazy val nvdla = (project in file("generators/nvdla"))
|
||||||
@@ -247,39 +222,31 @@ lazy val nvdla = (project in file("generators/nvdla"))
|
|||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val iocell = (project in file("./tools/barstools/iocell/"))
|
lazy val iocell = (project in file("./tools/barstools/iocell/"))
|
||||||
.sourceDependency(chiselRef, chiselLib)
|
.settings(chiselSettings)
|
||||||
.settings(addCompilerPlugin(chiselPluginLib))
|
|
||||||
.settings(libraryDependencies ++= chiselLibDeps.value)
|
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val tapeout = (project in file("./tools/barstools/tapeout/"))
|
lazy val tapeout = (project in file("./tools/barstools/tapeout/"))
|
||||||
.dependsOn(chisel_testers, chipyard) // must depend on chipyard to get scala resources
|
.dependsOn(chisel_testers, chipyard) // must depend on chipyard to get scala resources
|
||||||
.settings(libraryDependencies ++= chiselTestersLibDeps.value)
|
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val mdf = (project in file("./tools/barstools/mdf/scalalib/"))
|
lazy val mdf = (project in file("./tools/barstools/mdf/scalalib/"))
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val barstoolsMacros = (project in file("./tools/barstools/macros/"))
|
lazy val barstoolsMacros = (project in file("./tools/barstools/macros/"))
|
||||||
.sourceDependency(chiselRef, chiselLib)
|
.dependsOn(mdf)
|
||||||
.settings(addCompilerPlugin(chiselPluginLib))
|
|
||||||
.settings(libraryDependencies ++= chiselLibDeps.value)
|
|
||||||
.dependsOn(firrtl_interpreter, mdf, chisel_testers)
|
|
||||||
.settings(libraryDependencies ++= chiselTestersLibDeps.value)
|
|
||||||
.settings(libraryDependencies ++= firrtlInterpreterLibDeps.value)
|
|
||||||
.enablePlugins(sbtassembly.AssemblyPlugin)
|
.enablePlugins(sbtassembly.AssemblyPlugin)
|
||||||
|
.settings(firrtlSettings)
|
||||||
.settings(commonSettings)
|
.settings(commonSettings)
|
||||||
|
|
||||||
lazy val dsptools = freshProject("dsptools", file("./tools/dsptools"))
|
lazy val dsptools = freshProject("dsptools", file("./tools/dsptools"))
|
||||||
.dependsOn(chisel_testers)
|
.dependsOn(chisel_testers)
|
||||||
.settings(libraryDependencies ++= chiselTestersLibDeps.value)
|
|
||||||
.settings(
|
.settings(
|
||||||
commonSettings,
|
commonSettings,
|
||||||
libraryDependencies ++= Seq(
|
libraryDependencies ++= Seq(
|
||||||
|
"org.scalatest" %% "scalatest" % "3.2.+" % "test",
|
||||||
"org.typelevel" %% "spire" % "0.16.2",
|
"org.typelevel" %% "spire" % "0.16.2",
|
||||||
"org.scalanlp" %% "breeze" % "1.1",
|
"org.scalanlp" %% "breeze" % "1.1",
|
||||||
"junit" % "junit" % "4.13" % "test",
|
"junit" % "junit" % "4.13" % "test",
|
||||||
"org.scalatest" %% "scalatest" % "3.0.+" % "test",
|
|
||||||
"org.scalacheck" %% "scalacheck" % "1.14.3" % "test",
|
"org.scalacheck" %% "scalacheck" % "1.14.3" % "test",
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user