mirror of
				https://github.com/SpinalHDL/SpinalTemplateSbt.git
				synced 2025-10-25 16:58:45 +08:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
			8e8b22f6ec
			...
			25-readme-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | dd76ac14f7 | ||
|   | 3929e815a5 | ||
|   | cb8b3565b9 | ||
|   | 121ba1514d | ||
|   | 07a5beaf08 | ||
|   | 4849860e14 | ||
|   | 9ccca0f64a | ||
|   | bbbac09f8f | ||
|   | d40940a924 | ||
|   | 09e7cac187 | ||
|   | a53d219051 | ||
|   | ed51a92116 | 
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -11,17 +11,20 @@ target | |||||||
| lib_managed/ | lib_managed/ | ||||||
| src_managed/ | src_managed/ | ||||||
| project/boot/ | project/boot/ | ||||||
|  | project/project | ||||||
| project/plugins/project/ | project/plugins/project/ | ||||||
|  |  | ||||||
| # Scala-IDE specific | # Scala-IDE specific | ||||||
| .scala_dependencies | .scala_dependencies | ||||||
| .worksheet | .worksheet | ||||||
|  | .bloop | ||||||
|  |  | ||||||
| .idea | .idea | ||||||
| out | out | ||||||
|  |  | ||||||
| # Metals | # Metals | ||||||
| .metals | .metals | ||||||
|  | project/metals.sbt | ||||||
|  |  | ||||||
| # Eclipse | # Eclipse | ||||||
| bin/ | bin/ | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								.scalafmt.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.scalafmt.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | version = 3.6.0 | ||||||
|  | runner.dialect = scala212 | ||||||
|  | align.preset = some | ||||||
|  | maxColumn = 120 | ||||||
|  | docstrings.wrap = no | ||||||
							
								
								
									
										165
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,140 +1,83 @@ | |||||||
| Spinal Base Project | # SpinalHDL Base Project | ||||||
| ============ |  | ||||||
| This repository is a base SBT project added to help non Scala/SBT native people in their first steps. |  | ||||||
|  |  | ||||||
| Just one important note, you need a java JDK >= 8 | This repository is a base project to help Spinal users set-up project without knowledge about Scala and SBT. | ||||||
|  |  | ||||||
| On debian : |  | ||||||
|  | ## If it is your are learning SpinalHDL | ||||||
|  |  | ||||||
|  | You can follow the tutorial on the [Getting Started](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/index.html) page. | ||||||
|  |  | ||||||
|  | More specifically: | ||||||
|  |  | ||||||
|  | * instructions to install tools can be found on the [Install and setup](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#install-and-setup) page | ||||||
|  | * instructions to get this repository locally are available in the [Create a SpinalHDL project](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#create-a-spinalhdl-project) section. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### TL;DR Things have arleady been set up in my environment, how do I run things to try SpinalHDL? | ||||||
|  |  | ||||||
|  | Once in the `SpinalTemplateSbt` directory, when tools are installed, the commands below can be run to use `sbt`. | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| sudo add-apt-repository -y ppa:openjdk-r/ppa | // To generate the Verilog from the example | ||||||
| sudo apt-get update | sbt "runMain projectname.MyTopLevelVerilog" | ||||||
| sudo apt-get install openjdk-8-jdk -y |  | ||||||
|  |  | ||||||
| #To set the default java | // To generate the VHDL from the example | ||||||
| sudo update-alternatives --config java | sbt "runMain projectname.MyTopLevelVhdl" | ||||||
| sudo update-alternatives --config javac |  | ||||||
|  | // To run the testbench | ||||||
|  | sbt "runMain projectname.MyTopLevelSim" | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Basics, without any IDE | * The example hardware description is into `hw/spinal/projectname/MyTopLevel.scala` | ||||||
|  | * The testbench is into `hw/spinal/projectname/MyTopLevelSim.scala` | ||||||
|  |  | ||||||
| You need to install SBT | When you really start working with SpinalHDL, it is recommended (both for comfort and efficiency) to use an IDE, see the [Getting started](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/index.html). | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| echo "deb https://repo.scala-sbt.org/scalasbt/debian all main" | sudo tee /etc/apt/sources.list.d/sbt.list |  | ||||||
| echo "deb https://repo.scala-sbt.org/scalasbt/debian /" | sudo tee /etc/apt/sources.list.d/sbt_old.list |  | ||||||
| curl -sL "https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x2EE0EA64E40A89B84B2DF73499E82A75642AC823" | sudo apt-key add |  | ||||||
| sudo apt-get update |  | ||||||
| sudo apt-get install sbt |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| If you want to run the scala written testbench, you have to be on linux and have Verilator installed (a recent version) : | ## If you want to create a new project from this template | ||||||
|  |  | ||||||
| ```sh | ### Change project name | ||||||
| sudo apt-get install git make autoconf g++ flex bison -y  # First time prerequisites |  | ||||||
| git clone http://git.veripool.org/git/verilator   # Only first time |  | ||||||
| unsetenv VERILATOR_ROOT  # For csh; ignore error if on bash |  | ||||||
| unset VERILATOR_ROOT  # For bash |  | ||||||
| cd verilator |  | ||||||
| git pull        # Make sure we're up-to-date |  | ||||||
| git checkout v4.040 |  | ||||||
| autoconf        # Create ./configure script |  | ||||||
| ./configure |  | ||||||
| make -j$(nproc) |  | ||||||
| sudo make install |  | ||||||
| cd .. |  | ||||||
| echo "DONE" |  | ||||||
|  |  | ||||||
| ``` | You might want to change the project name, which is currently `projectname`. To do so (let's say your actual project name is `myproject`; it must be all lowercase with no separators): | ||||||
|  |  | ||||||
| Clone or download this repository. | * Update `build.sbt` and/or `build.sc` by replacing `projectname` by the name of your project `myproject` (1 occurrence in each file). The better is to replace in both (it will always work), but in some contexts you can keep only one of these two files: | ||||||
|  |     * If you are sure all people only use `sbt`, you can replace only in `build.sbt` and remove `build.sc` | ||||||
|  |     * If you are sure all people only use `mill`, you can replace only in `build.sc` and remove `build.sbt` | ||||||
|  |     * Replace in both files for open-source project. | ||||||
|  | * Put all your scala files into `hw/spinal/myproject/` (remove the unused `hw/spinal/projectname/` folder) | ||||||
|  | * Start all your scala files with `package myproject` | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| git clone https://github.com/SpinalHDL/SpinalTemplateSbt.git |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Open a terminal in the root of it and run "sbt run". At the first execution, the process could take some seconds | ### Change project structure | ||||||
|  |  | ||||||
| ```sh | You can change the project structure as you want. The only restrictions (from Scala environment) are (let's say your actual project name is `myproject`): | ||||||
| cd SpinalTemplateSbt |  | ||||||
|  |  | ||||||
| //If you want to generate the Verilog of your design | * you must have a `myproject` folder and files in it must start with `package myproject` | ||||||
| sbt "runMain mylib.MyTopLevelVerilog" | * if you have a file in a subfolder `myproject/somepackage/MyElement.scala` it must start with `package myproject.somepackage`. | ||||||
|  | * `sbt` and `mill` must be run right in the folder containing their configurations (recommended to not move these files) | ||||||
|  |  | ||||||
| //If you want to generate the VHDL of your design | Once the project structure is modified, update configurations: | ||||||
| sbt "runMain mylib.MyTopLevelVhdl" |  | ||||||
|  |  | ||||||
| //If you want to run the scala written testbench | * In `build.sbt` and/or `build.sc` (see above) replace `/ "hw" / "spinal"` by the new path to the folder containing the `myproject` folder. | ||||||
| sbt "runMain mylib.MyTopLevelSim" | * In the spinal configuration file (if you kept it, by default it is in `projectname/Config.scala`) change the path in `targetDirectory = "hw/gen"` to the directory where you want generated files to be written. If you don't use a config or if it doesn't contain this element, generated files will be written in the root directory. | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The top level spinal code is defined into src\main\scala\mylib |  | ||||||
|  |  | ||||||
| ## Basics, with Intellij IDEA and its scala plugin | ### Update this README | ||||||
|  |  | ||||||
| You need to install : | Of course you can replace/modify this file to help people with your own project! | ||||||
|  |  | ||||||
| - Java JDK 8 |  | ||||||
| - SBT |  | ||||||
| - Intellij IDEA (the free Community Edition is good enough) |  | ||||||
| - Intellij IDEA Scala plugin (when you run Intellij IDEA the first time, he will ask you about it) |  | ||||||
|  |  | ||||||
| And do the following : |  | ||||||
|  |  | ||||||
| - Clone or download this repository. |  | ||||||
| - In Intellij IDEA, "import project" with the root of this repository, Import project from external model SBT |  | ||||||
| - In addition maybe you need to specify some path like JDK to Intellij |  | ||||||
| - In the project (Intellij project GUI), go in src/main/scala/mylib/MyTopLevel.scala, right click on MyTopLevelVerilog, "Run MyTopLevelVerilog" |  | ||||||
|  |  | ||||||
| Normally, this must generate an MyTopLevel.v output files. |  | ||||||
|  |  | ||||||
| ## Basics, with Eclipse and its scala plugin |  | ||||||
|  |  | ||||||
| First, i "strongly" suggest to use intellij idea instead. |  | ||||||
|  |  | ||||||
| You need to install : |  | ||||||
|  |  | ||||||
| - Java JDK |  | ||||||
| - Scala |  | ||||||
| - SBT |  | ||||||
| - Eclipse (tested with Mars.2 - 4.5.2) |  | ||||||
| - [scala plugin](http://scala-ide.org/) (tested with 4.4.1) |  | ||||||
|  |  | ||||||
| And do the following : |  | ||||||
|  |  | ||||||
| - Clone or download this repository. |  | ||||||
| - Revert changes from https://github.com/SpinalHDL/SpinalTemplateSbt/commit/173bbb9bb8cbf70087339104f6ebced9321908dd |  | ||||||
| - Run ```sbt eclipse``` in the ```SpinalTemplateSbt``` directory. |  | ||||||
| - Import the eclipse project from eclipse. |  | ||||||
| - In the project (eclipse project GUI), right click on src/main/scala/mylib/MyTopLevel.scala, right click on MyTopLevelVerilog, and select run it |  | ||||||
|  |  | ||||||
| Normally, this must generate output file ```MyTopLevel.v```. |  | ||||||
|  |  | ||||||
| ## Mill Support (Experimental) | ## Mill Support (Experimental) | ||||||
|  |  | ||||||
| This Spinal Base Project contains support for the [Mill build tool](https://com-lihaoyi.github.io/mill). | The [Mill build tool](https://com-lihaoyi.github.io/mill) can be installed and used instead of `sbt`. | ||||||
|  |  | ||||||
| The prerequisites are the same as for using SBT, except for sbt itself. Additionally, the ```mill``` executable needs to be installed on the path. Download it to ```/usr/local/bin/mill``` or ```~/bin/mill``` according to the [installation instructions](https://com-lihaoyi.github.io/mill/mill/Intro_to_Mill.html#_installation). |  | ||||||
|  |  | ||||||
| You can clone and use this repository in the following way. |  | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| git clone https://github.com/SpinalHDL/SpinalTemplateSbt.git | // To generate the Verilog from the example | ||||||
|  | mill projectname.runMain projectname.MyTopLevelVerilog | ||||||
|  |  | ||||||
|  | // To generate the VHDL from the example | ||||||
|  | mill projectname.runMain projectname.MyTopLevelVhdl | ||||||
|  |  | ||||||
|  | // To run the testbench | ||||||
|  | mill projectname.runMain projectname.MyTopLevelSim | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Open a terminal in the root of it and execute your favorite mill command. At the first execution, the process could take some seconds |  | ||||||
|  |  | ||||||
| ```sh |  | ||||||
| cd SpinalTemplateSbt |  | ||||||
|  |  | ||||||
| //If you want to generate the Verilog of your design |  | ||||||
| mill mylib.runMain mylib.MyTopLevelVerilog |  | ||||||
|  |  | ||||||
| //If you want to generate the VHDL of your design |  | ||||||
| mill mylib.runMain mylib.MyTopLevelVhdl |  | ||||||
|  |  | ||||||
| //If you want to run the scala written testbench |  | ||||||
| mill mylib.runMain mylib.MyTopLevelSim |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The top level spinal code is defined into src\main\scala\mylib |  | ||||||
|   | |||||||
| @@ -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) | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								build.sc
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								build.sc
									
									
									
									
									
								
							| @@ -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
									
								
							
							
						
						
									
										1
									
								
								hw/gen/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | * | ||||||
							
								
								
									
										16
									
								
								hw/spinal/projectname/Config.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								hw/spinal/projectname/Config.scala
									
									
									
									
									
										Normal 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 | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								hw/spinal/projectname/MyTopLevel.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								hw/spinal/projectname/MyTopLevel.scala
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | package projectname | ||||||
|  |  | ||||||
|  | import spinal.core._ | ||||||
|  |  | ||||||
|  | // Hardware definition | ||||||
|  | case class MyTopLevel() extends Component { | ||||||
|  |   val io = new Bundle { | ||||||
|  |     val cond0 = in  Bool() | ||||||
|  |     val cond1 = in  Bool() | ||||||
|  |     val flag  = out Bool() | ||||||
|  |     val state = out UInt(8 bits) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   val counter = Reg(UInt(8 bits)) init 0 | ||||||
|  |  | ||||||
|  |   when(io.cond0) { | ||||||
|  |     counter := counter + 1 | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   io.state := counter | ||||||
|  |   io.flag := (counter === 0) | io.cond1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | object MyTopLevelVerilog extends App { | ||||||
|  |   Config.spinal.generateVerilog(MyTopLevel()) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | object MyTopLevelVhdl extends App { | ||||||
|  |   Config.spinal.generateVhdl(MyTopLevel()) | ||||||
|  | } | ||||||
| @@ -1,14 +1,15 @@ | |||||||
| package mylib | package projectname | ||||||
| 
 | 
 | ||||||
| import spinal.core._ | import spinal.core._ | ||||||
| import spinal.core.formal._ | import spinal.core.formal._ | ||||||
| 
 | 
 | ||||||
| // You need SymbiYosys to be installed. | // You need SymbiYosys to be installed. | ||||||
| // See https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Formal%20verification/index.html#installing-requirements | // See https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Formal%20verification/index.html#installing-requirements | ||||||
| object MyTopLevelFormal { | object MyTopLevelFormal extends App { | ||||||
|   def main(args: Array[String]) { |   FormalConfig | ||||||
|     FormalConfig.withBMC(10).doVerify(new Component { |     .withBMC(10) | ||||||
|       val dut = FormalDut(new MyTopLevel) |     .doVerify(new Component { | ||||||
|  |       val dut = FormalDut(MyTopLevel()) | ||||||
| 
 | 
 | ||||||
|       // Ensure the formal test start with a reset |       // Ensure the formal test start with a reset | ||||||
|       assumeInitial(clockDomain.isResetActive) |       assumeInitial(clockDomain.isResetActive) | ||||||
| @@ -21,4 +22,3 @@ object MyTopLevelFormal { | |||||||
|       assert(dut.io.state === past(dut.io.state + U(dut.io.cond0)).init(0)) |       assert(dut.io.state === past(dut.io.state + U(dut.io.cond0)).init(0)) | ||||||
|     }) |     }) | ||||||
| } | } | ||||||
| } |  | ||||||
							
								
								
									
										31
									
								
								hw/spinal/projectname/MyTopLevelSim.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								hw/spinal/projectname/MyTopLevelSim.scala
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | package projectname | ||||||
|  |  | ||||||
|  | import spinal.core._ | ||||||
|  | import spinal.core.sim._ | ||||||
|  |  | ||||||
|  | object MyTopLevelSim extends App { | ||||||
|  |   Config.sim.compile(MyTopLevel()).doSim { dut => | ||||||
|  |     // Fork a process to generate the reset and the clock on the dut | ||||||
|  |     dut.clockDomain.forkStimulus(period = 10) | ||||||
|  |  | ||||||
|  |     var modelState = 0 | ||||||
|  |     for (idx <- 0 to 99) { | ||||||
|  |       // Drive the dut inputs with random values | ||||||
|  |       dut.io.cond0.randomize() | ||||||
|  |       dut.io.cond1.randomize() | ||||||
|  |  | ||||||
|  |       // Wait a rising edge on the clock | ||||||
|  |       dut.clockDomain.waitRisingEdge() | ||||||
|  |  | ||||||
|  |       // Check that the dut values match with the reference model ones | ||||||
|  |       val modelFlag = modelState == 0 || dut.io.cond1.toBoolean | ||||||
|  |       assert(dut.io.state.toInt == modelState) | ||||||
|  |       assert(dut.io.flag.toBoolean == modelFlag) | ||||||
|  |  | ||||||
|  |       // Update the reference model value | ||||||
|  |       if (dut.io.cond0.toBoolean) { | ||||||
|  |         modelState = (modelState + 1) & 0xff | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										0
									
								
								hw/verilog/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								hw/verilog/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								hw/vhdl/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								hw/vhdl/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6") | ||||||
|   | |||||||
| @@ -1,67 +0,0 @@ | |||||||
| /* |  | ||||||
|  * SpinalHDL |  | ||||||
|  * Copyright (c) Dolu, All rights reserved. |  | ||||||
|  * |  | ||||||
|  * This library is free software; you can redistribute it and/or |  | ||||||
|  * modify it under the terms of the GNU Lesser General Public |  | ||||||
|  * License as published by the Free Software Foundation; either |  | ||||||
|  * version 3.0 of the License, or (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This library is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |  | ||||||
|  * Lesser General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Lesser General Public |  | ||||||
|  * License along with this library. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| package mylib |  | ||||||
|  |  | ||||||
| import spinal.core._ |  | ||||||
| import spinal.lib._ |  | ||||||
|  |  | ||||||
| import scala.util.Random |  | ||||||
|  |  | ||||||
| //Hardware definition |  | ||||||
| class MyTopLevel extends Component { |  | ||||||
|   val io = new Bundle { |  | ||||||
|     val cond0 = in  Bool() |  | ||||||
|     val cond1 = in  Bool() |  | ||||||
|     val flag  = out Bool() |  | ||||||
|     val state = out UInt(8 bits) |  | ||||||
|   } |  | ||||||
|   val counter = Reg(UInt(8 bits)) init(0) |  | ||||||
|  |  | ||||||
|   when(io.cond0){ |  | ||||||
|     counter := counter + 1 |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   io.state := counter |  | ||||||
|   io.flag  := (counter === 0) | io.cond1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| //Generate the MyTopLevel's Verilog |  | ||||||
| object MyTopLevelVerilog { |  | ||||||
|   def main(args: Array[String]) { |  | ||||||
|     SpinalVerilog(new MyTopLevel) |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| //Generate the MyTopLevel's VHDL |  | ||||||
| object MyTopLevelVhdl { |  | ||||||
|   def main(args: Array[String]) { |  | ||||||
|     SpinalVhdl(new MyTopLevel) |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //Define a 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)) |  | ||||||
|  |  | ||||||
| //Generate the MyTopLevel's Verilog using the above custom configuration. |  | ||||||
| object MyTopLevelVerilogWithCustomConfig { |  | ||||||
|   def main(args: Array[String]) { |  | ||||||
|     MySpinalConfig.generateVerilog(new MyTopLevel) |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,38 +0,0 @@ | |||||||
| package mylib |  | ||||||
|  |  | ||||||
| import spinal.core._ |  | ||||||
| import spinal.sim._ |  | ||||||
| import spinal.core.sim._ |  | ||||||
|  |  | ||||||
| import scala.util.Random |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //MyTopLevel's testbench |  | ||||||
| object MyTopLevelSim { |  | ||||||
|   def main(args: Array[String]) { |  | ||||||
|     SimConfig.withWave.doSim(new MyTopLevel){dut => |  | ||||||
|       //Fork a process to generate the reset and the clock on the dut |  | ||||||
|       dut.clockDomain.forkStimulus(period = 10) |  | ||||||
|  |  | ||||||
|       var modelState = 0 |  | ||||||
|       for(idx <- 0 to 99){ |  | ||||||
|         //Drive the dut inputs with random values |  | ||||||
|         dut.io.cond0 #= Random.nextBoolean() |  | ||||||
|         dut.io.cond1 #= Random.nextBoolean() |  | ||||||
|  |  | ||||||
|         //Wait a rising edge on the clock |  | ||||||
|         dut.clockDomain.waitRisingEdge() |  | ||||||
|  |  | ||||||
|         //Check that the dut values match with the reference model ones |  | ||||||
|         val modelFlag = modelState == 0 || dut.io.cond1.toBoolean |  | ||||||
|         assert(dut.io.state.toInt == modelState) |  | ||||||
|         assert(dut.io.flag.toBoolean == modelFlag) |  | ||||||
|  |  | ||||||
|         //Update the reference model value |  | ||||||
|         if(dut.io.cond0.toBoolean) { |  | ||||||
|           modelState = (modelState + 1) & 0xFF |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
		Reference in New Issue
	
	Block a user