2018-04-21 02:18:18 +08:00
|
|
|
lazy val commonSettings = Seq(
|
|
|
|
organization := "edu.berkeley.cs",
|
|
|
|
version := "1.0",
|
2018-09-30 04:30:07 +08:00
|
|
|
scalaVersion := "2.12.4",
|
2018-04-21 02:18:18 +08:00
|
|
|
traceLevel := 15,
|
2019-02-08 03:11:25 +08:00
|
|
|
test in assembly := {},
|
|
|
|
assemblyMergeStrategy in assembly := { _ match {
|
|
|
|
case PathList("META-INF", "MANIFEST.MF") => MergeStrategy.discard
|
|
|
|
case _ => MergeStrategy.first}},
|
2018-09-30 04:30:07 +08:00
|
|
|
scalacOptions ++= Seq("-deprecation","-unchecked","-Xsource:2.11"),
|
2019-04-18 14:11:14 +08:00
|
|
|
libraryDependencies += "org.scalatest" %% "scalatest" % "3.0.5" % "test",
|
|
|
|
libraryDependencies += "org.json4s" %% "json4s-native" % "3.6.1",
|
2018-04-21 02:18:18 +08:00
|
|
|
libraryDependencies += "org.scala-lang" % "scala-reflect" % scalaVersion.value,
|
2019-02-08 03:11:25 +08:00
|
|
|
libraryDependencies += "edu.berkeley.cs" %% "firrtl-interpreter" % "1.2-SNAPSHOT",
|
2019-04-18 14:11:14 +08:00
|
|
|
libraryDependencies += "com.github.scopt" %% "scopt" % "3.7.0",
|
2018-04-21 02:18:18 +08:00
|
|
|
addCompilerPlugin("org.scalamacros" % "paradise" % "2.1.0" cross CrossVersion.full),
|
|
|
|
resolvers ++= Seq(
|
|
|
|
Resolver.sonatypeRepo("snapshots"),
|
|
|
|
Resolver.sonatypeRepo("releases"),
|
|
|
|
Resolver.mavenLocal))
|
2016-10-22 07:03:26 +08:00
|
|
|
|
2019-04-18 14:11:14 +08:00
|
|
|
lazy val rebarFirrtl = (project in file("tools/firrtl"))
|
|
|
|
.settings(commonSettings)
|
|
|
|
|
2019-03-08 06:18:24 +08:00
|
|
|
lazy val rocketchip = RootProject(file("generators/rocket-chip"))
|
2016-10-22 07:03:26 +08:00
|
|
|
|
2019-04-18 14:11:14 +08:00
|
|
|
lazy val testchipip = (project in file("generators/testchipip"))
|
2019-02-08 03:11:25 +08:00
|
|
|
.dependsOn(rocketchip)
|
2019-04-18 14:11:14 +08:00
|
|
|
.settings(commonSettings)
|
2019-02-08 03:11:25 +08:00
|
|
|
|
2019-03-07 10:22:21 +08:00
|
|
|
// Checks for -DROCKET_USE_MAVEN.
|
|
|
|
// If it's there, use a maven dependency.
|
|
|
|
// Else, depend on subprojects in git submodules.
|
2019-04-18 14:11:14 +08:00
|
|
|
def testchipIpDependsOn(prj: Project): Project = {
|
2019-03-07 10:22:21 +08:00
|
|
|
if (sys.props.contains("ROCKET_USE_MAVEN")) {
|
|
|
|
prj.settings(Seq(
|
|
|
|
libraryDependencies += "edu.berkeley.cs" %% "testchipip" % "1.0-020719-SNAPSHOT",
|
|
|
|
))
|
|
|
|
} else {
|
|
|
|
prj.dependsOn(testchipip)
|
|
|
|
}
|
|
|
|
}
|
2019-04-18 14:11:14 +08:00
|
|
|
|
|
|
|
lazy val example = testchipIpDependsOn(project in file("."))
|
2019-02-08 03:11:25 +08:00
|
|
|
.settings(commonSettings)
|
|
|
|
|
2019-04-18 14:11:14 +08:00
|
|
|
lazy val boom = (project in file("generators/boom"))
|
|
|
|
.dependsOn(rocketchip)
|
2019-04-18 07:06:42 +08:00
|
|
|
.settings(commonSettings)
|
|
|
|
|
2019-04-18 14:11:14 +08:00
|
|
|
lazy val tapeout = (project in file("./tools/barstools/tapeout/"))
|
|
|
|
.dependsOn(rebarFirrtl, rocketchip)
|
2019-02-08 03:11:25 +08:00
|
|
|
.settings(commonSettings)
|
|
|
|
|
2019-03-08 06:18:24 +08:00
|
|
|
lazy val mdf = (project in file("./tools/barstools/mdf/scalalib/"))
|
2019-04-18 14:11:14 +08:00
|
|
|
.settings(commonSettings)
|
2019-02-08 03:11:25 +08:00
|
|
|
|
2019-04-18 14:11:14 +08:00
|
|
|
lazy val `barstools-macros` = (project in file("./tools/barstools/macros/"))
|
|
|
|
.dependsOn(mdf, rocketchip, rebarFirrtl)
|
2019-02-08 03:11:25 +08:00
|
|
|
.enablePlugins(sbtassembly.AssemblyPlugin)
|
|
|
|
.settings(commonSettings)
|