3 Commits

Author SHA1 Message Date
Dolu1990
121ba1514d Update README.md 2022-11-28 10:49:19 +01:00
Dolu1990
07a5beaf08 Merge pull request #23 from numero-744/rework-structure
Structure suggestion
2022-11-28 10:47:29 +01:00
Côme ALLART
4849860e14 refactor: simplify project structure 2022-11-25 10:39:48 +01:00
11 changed files with 43 additions and 40 deletions

View File

@@ -37,7 +37,7 @@ unsetenv VERILATOR_ROOT # For csh; ignore error if on bash
unset VERILATOR_ROOT # For bash unset VERILATOR_ROOT # For bash
cd verilator cd verilator
git pull # Make sure we're up-to-date git pull # Make sure we're up-to-date
git checkout v4.040 git checkout v4.216
autoconf # Create ./configure script autoconf # Create ./configure script
./configure ./configure
make -j$(nproc) make -j$(nproc)
@@ -59,13 +59,13 @@ Open a terminal in the root of it and run "sbt run". At the first execution, the
cd SpinalTemplateSbt cd SpinalTemplateSbt
//If you want to generate the Verilog of your design //If you want to generate the Verilog of your design
sbt "runMain mylib.MyTopLevelVerilog" sbt "runMain projectname.MyTopLevelVerilog"
//If you want to generate the VHDL of your design //If you want to generate the VHDL of your design
sbt "runMain mylib.MyTopLevelVhdl" sbt "runMain projectname.MyTopLevelVhdl"
//If you want to run the scala written testbench //If you want to run the scala written testbench
sbt "runMain mylib.MyTopLevelSim" sbt "runMain projectname.MyTopLevelSim"
``` ```
The top level spinal code is defined into src\main\scala\mylib The top level spinal code is defined into src\main\scala\mylib
@@ -128,13 +128,13 @@ Open a terminal in the root of it and execute your favorite mill command. At the
cd SpinalTemplateSbt cd SpinalTemplateSbt
//If you want to generate the Verilog of your design //If you want to generate the Verilog of your design
mill mylib.runMain mylib.MyTopLevelVerilog mill projectname.runMain projectname.MyTopLevelVerilog
//If you want to generate the VHDL of your design //If you want to generate the VHDL of your design
mill mylib.runMain mylib.MyTopLevelVhdl mill projectname.runMain projectname.MyTopLevelVhdl
//If you want to run the scala written testbench //If you want to run the scala written testbench
mill mylib.runMain mylib.MyTopLevelSim mill projectname.runMain projectname.MyTopLevelSim
``` ```
The top level spinal code is defined into src\main\scala\mylib The top level spinal code is defined into src\main\scala\mylib

View File

@@ -7,9 +7,9 @@ val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion
val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion
val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion) val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion)
lazy val mylib = (project in file(".")) lazy val projectname = (project in file("."))
.settings( .settings(
name := "SpinalTemplateSbt", Compile / scalaSource := baseDirectory.value / "hw" / "spinal",
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin) libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
) )

View File

@@ -2,9 +2,12 @@ import mill._, scalalib._
val spinalVersion = "1.7.3" val spinalVersion = "1.7.3"
object mylib extends SbtModule { object projectname extends SbtModule {
def scalaVersion = "2.12.14" def scalaVersion = "2.12.16"
override def millSourcePath = os.pwd override def millSourcePath = os.pwd
def sources = T.sources(
millSourcePath / "hw" / "spinal"
)
def ivyDeps = Agg( def ivyDeps = Agg(
ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion", ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion",
ivy"com.github.spinalhdl::spinalhdl-lib:$spinalVersion" ivy"com.github.spinalhdl::spinalhdl-lib:$spinalVersion"

1
hw/gen/.gitignore vendored Normal file
View File

@@ -0,0 +1 @@
*

View File

@@ -0,0 +1,16 @@
package projectname
import spinal.core._
import spinal.core.sim._
object Config {
def spinal = SpinalConfig(
targetDirectory = "hw/gen",
defaultConfigForClockDomains = ClockDomainConfig(
resetActiveLevel = HIGH
),
onlyStdLogicVectorAtTopLevelIo = true
)
def sim = SimConfig.withConfig(spinal).withFstWave
}

View File

@@ -1,4 +1,4 @@
package mylib package projectname
import spinal.core._ import spinal.core._
@@ -20,3 +20,11 @@ case class MyTopLevel() extends Component {
io.state := counter io.state := counter
io.flag := (counter === 0) | io.cond1 io.flag := (counter === 0) | io.cond1
} }
object MyTopLevelVerilog extends App {
Config.spinal.generateVerilog(MyTopLevel())
}
object MyTopLevelVhdl extends App {
Config.spinal.generateVhdl(MyTopLevel())
}

View File

@@ -1,4 +1,4 @@
package mylib package projectname
import spinal.core._ import spinal.core._
import spinal.core.formal._ import spinal.core.formal._

View File

@@ -1,10 +1,10 @@
package mylib package projectname
import spinal.core._ import spinal.core._
import spinal.core.sim._ import spinal.core.sim._
object MyTopLevelSim extends App { object MyTopLevelSim extends App {
SimConfig.withWave.doSim(MyTopLevel()) { dut => Config.sim.compile(MyTopLevel()).doSim { dut =>
// Fork a process to generate the reset and the clock on the dut // Fork a process to generate the reset and the clock on the dut
dut.clockDomain.forkStimulus(period = 10) dut.clockDomain.forkStimulus(period = 10)

0
hw/verilog/.gitignore vendored Normal file
View File

0
hw/vhdl/.gitignore vendored Normal file
View File

View File

@@ -1,25 +0,0 @@
package mylib
import spinal.core._
object MyTopLevelVerilog extends App {
// Generate the MyTopLevel's Verilog
SpinalVerilog(MyTopLevel())
}
object MyTopLevelVhdl extends App {
// Generate the MyTopLevel's VHDL
SpinalVhdl(MyTopLevel())
}
// Custom SpinalHDL configuration with synchronous reset instead of the default asynchronous one
// This configuration can be resued everywhere
object MySpinalConfig
extends SpinalConfig(
defaultConfigForClockDomains = ClockDomainConfig(resetKind = SYNC)
)
object MyTopLevelVerilogWithCustomConfig extends App {
// Generate the MyTopLevel's Verilog using the above custom configuration.
MySpinalConfig.generateVerilog(MyTopLevel())
}