mirror of
				https://github.com/SpinalHDL/SpinalTemplateSbt.git
				synced 2025-10-26 01:08:44 +08:00 
			
		
		
		
	Compare commits
	
		
			50 Commits
		
	
	
		
			dev
			...
			9ccca0f64a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 9ccca0f64a | ||
|   | bbbac09f8f | ||
|   | d40940a924 | ||
|   | 09e7cac187 | ||
|   | a53d219051 | ||
|   | ed51a92116 | ||
|   | 8e8b22f6ec | ||
|   | 4570b17a29 | ||
|   | a9de93a481 | ||
|   | 310df743af | ||
|   | 599a1e6daf | ||
|   | 23f8152f1f | ||
|   | 3a93d0fe88 | ||
|   | e2c55528af | ||
|   | 993e66c242 | ||
|   | 1e8a644b8a | ||
|   | df28313eea | ||
|   | 181684644c | ||
|   | 884c4a7ca6 | ||
|   | 16cca3e7ca | ||
|   | 2e50a23fcc | ||
|   | 5502e4f7f6 | ||
|   | 666dcbba79 | ||
|   | 9c0aed7c0d | ||
|   | ef4d9b7db3 | ||
|   | 9b3093e193 | ||
|   | bb5f15798e | ||
|   | 08d79c6134 | ||
|   | 131c6e7654 | ||
|   | e03a66e8f9 | ||
|   | 8acbd1d747 | ||
|   | 173bbb9bb8 | ||
|   | 162e9b5c6b | ||
|   | c7e1834cb4 | ||
|   | 754351b8a1 | ||
|   | fd7f2b7165 | ||
|   | b524ddddd8 | ||
|   | 648d530e4d | ||
|   | 3cd200f9b6 | ||
|   | 4f93c929d4 | ||
|   | 4c1ec24f9b | ||
|   | 83ae9ff28b | ||
|   | 13cd788fdc | ||
|   | 53b4595be9 | ||
|   | 8ab19a2b3e | ||
|   | 9ff9388be2 | ||
|   | 70ee49e249 | ||
|   | 31f3b617a9 | ||
|   | 0c8143eebc | ||
|   | 84b413aefc | 
							
								
								
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -11,15 +11,21 @@ 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 | ||||||
|  | project/metals.sbt | ||||||
|  |  | ||||||
| # Eclipse | # Eclipse | ||||||
| bin/ | bin/ | ||||||
| .classpath | .classpath | ||||||
| @@ -38,3 +44,4 @@ bin/ | |||||||
|  |  | ||||||
| simWorkspace/ | simWorkspace/ | ||||||
| tmp/ | tmp/ | ||||||
|  | null | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.mill-version
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.mill-version
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | 0.9.8 | ||||||
							
								
								
									
										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 | ||||||
							
								
								
									
										62
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								README.md
									
									
									
									
									
								
							| @@ -2,15 +2,28 @@ Spinal Base Project | |||||||
| ============ | ============ | ||||||
| This repository is a base SBT project added to help non Scala/SBT native people in their first steps. | This repository is a base SBT project added to help non Scala/SBT native people in their first steps. | ||||||
|  |  | ||||||
| ## Basics, without any IDE | Just one important note, you need a java JDK >= 8 | ||||||
|  |  | ||||||
| You need to install Java JDK and SBT | On debian : | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| sudo apt-get install openjdk-8-jdk | sudo add-apt-repository -y ppa:openjdk-r/ppa | ||||||
|  | sudo apt-get update | ||||||
|  | sudo apt-get install openjdk-8-jdk -y | ||||||
|  |  | ||||||
| echo "deb https://dl.bintray.com/sbt/debian /" | sudo tee -a /etc/apt/sources.list.d/sbt.list | #To set the default java | ||||||
| sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2EE0EA64E40A89B84B2DF73499E82A75642AC823 | sudo update-alternatives --config java | ||||||
|  | sudo update-alternatives --config javac | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Basics, without any IDE | ||||||
|  |  | ||||||
|  | You need to install SBT | ||||||
|  |  | ||||||
|  | ```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 update | ||||||
| sudo apt-get install sbt | sudo apt-get install sbt | ||||||
| ``` | ``` | ||||||
| @@ -24,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 verilator_3_916 | git checkout v4.040 | ||||||
| autoconf        # Create ./configure script | autoconf        # Create ./configure script | ||||||
| ./configure | ./configure | ||||||
| make -j$(nproc) | make -j$(nproc) | ||||||
| @@ -46,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 "run-main mylib.MyTopLevelVerilog" | sbt "runMain mylib.MyTopLevelVerilog" | ||||||
|  |  | ||||||
| //If you want to generate the VHDL of your design | //If you want to generate the VHDL of your design | ||||||
| sbt "run-main mylib.MyTopLevelVhdl" | sbt "runMain mylib.MyTopLevelVhdl" | ||||||
|  |  | ||||||
| //If you want to run the scala written testbench | //If you want to run the scala written testbench | ||||||
| sbt "run-main mylib.MyTopLevelSim" | sbt "runMain mylib.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 | ||||||
| @@ -77,6 +90,8 @@ Normally, this must generate an MyTopLevel.v output files. | |||||||
|  |  | ||||||
| ## Basics, with Eclipse and its scala plugin | ## Basics, with Eclipse and its scala plugin | ||||||
|  |  | ||||||
|  | First, i "strongly" suggest to use intellij idea instead. | ||||||
|  |  | ||||||
| You need to install : | You need to install : | ||||||
|  |  | ||||||
| - Java JDK | - Java JDK | ||||||
| @@ -88,9 +103,38 @@ You need to install : | |||||||
| And do the following : | And do the following : | ||||||
|  |  | ||||||
| - Clone or download this repository. | - Clone or download this repository. | ||||||
|  | - Revert changes from https://github.com/SpinalHDL/SpinalTemplateSbt/commit/173bbb9bb8cbf70087339104f6ebced9321908dd | ||||||
| - Run ```sbt eclipse``` in the ```SpinalTemplateSbt``` directory. | - Run ```sbt eclipse``` in the ```SpinalTemplateSbt``` directory. | ||||||
| - Import the eclipse project from eclipse. | - 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 | - 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```. | Normally, this must generate output file ```MyTopLevel.v```. | ||||||
|  |  | ||||||
|  | ## Mill Support (Experimental) | ||||||
|  |  | ||||||
|  | This Spinal Base Project contains support for the [Mill build tool](https://com-lihaoyi.github.io/mill). | ||||||
|  |  | ||||||
|  | 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 | ||||||
|  | git clone https://github.com/SpinalHDL/SpinalTemplateSbt.git | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | 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 | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								build.sbt
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								build.sbt
									
									
									
									
									
								
							| @@ -1,14 +1,16 @@ | |||||||
| name := "SpinalTemplateSbt" | ThisBuild / version := "1.0" | ||||||
|  | ThisBuild / scalaVersion := "2.12.16" | ||||||
|  | ThisBuild / organization := "org.example" | ||||||
|  |  | ||||||
| version := "1.0" | val spinalVersion = "1.7.3" | ||||||
|  | val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion | ||||||
|  | val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion | ||||||
|  | val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion) | ||||||
|  |  | ||||||
| scalaVersion := "2.11.12" | lazy val mylib = (project in file(".")) | ||||||
|  |   .settings( | ||||||
| EclipseKeys.withSource := true |     name := "SpinalTemplateSbt", | ||||||
|  |     libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin) | ||||||
| libraryDependencies ++= Seq( |   ) | ||||||
|   "com.github.spinalhdl" % "spinalhdl-core_2.11" % "1.3.0", |  | ||||||
|   "com.github.spinalhdl" % "spinalhdl-lib_2.11" % "1.3.0" |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| fork := true | fork := true | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								build.sc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								build.sc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | import mill._, scalalib._ | ||||||
|  |  | ||||||
|  | val spinalVersion = "1.7.3" | ||||||
|  |  | ||||||
|  | object mylib extends SbtModule { | ||||||
|  |   def scalaVersion = "2.12.14" | ||||||
|  |   override def millSourcePath = os.pwd | ||||||
|  |   def ivyDeps = Agg( | ||||||
|  |     ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion", | ||||||
|  |     ivy"com.github.spinalhdl::spinalhdl-lib:$spinalVersion" | ||||||
|  |   ) | ||||||
|  |   def scalacPluginIvyDeps = Agg(ivy"com.github.spinalhdl::spinalhdl-idsl-plugin:$spinalVersion") | ||||||
|  | } | ||||||
| @@ -1 +1 @@ | |||||||
| sbt.version=1.2.7 | sbt.version=1.6.0 | ||||||
|   | |||||||
| @@ -1,2 +1 @@ | |||||||
| addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4") | addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6") | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,67 +1,22 @@ | |||||||
| /* |  | ||||||
|  * 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 | package mylib | ||||||
|  |  | ||||||
| import spinal.core._ | import spinal.core._ | ||||||
| import spinal.lib._ |  | ||||||
|  |  | ||||||
| import scala.util.Random | // Hardware definition | ||||||
|  | case class MyTopLevel() extends Component { | ||||||
| //Hardware definition |  | ||||||
| class MyTopLevel extends Component { |  | ||||||
|   val io = new Bundle { |   val io = new Bundle { | ||||||
|     val cond0 = in  Bool |     val cond0 = in  Bool() | ||||||
|     val cond1 = in  Bool |     val cond1 = in  Bool() | ||||||
|     val flag  = out Bool |     val flag  = out Bool() | ||||||
|     val state = out UInt(8 bits) |     val state = out UInt(8 bits) | ||||||
|   } |   } | ||||||
|   val counter = Reg(UInt(8 bits)) init(0) |  | ||||||
|  |  | ||||||
|   when(io.cond0){ |   val counter = Reg(UInt(8 bits)) init 0 | ||||||
|  |  | ||||||
|  |   when(io.cond0) { | ||||||
|     counter := counter + 1 |     counter := counter + 1 | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   io.state := counter |   io.state := counter | ||||||
|   io.flag  := (counter === 0) | io.cond1 |   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) |  | ||||||
|   } |  | ||||||
| } | } | ||||||
							
								
								
									
										24
									
								
								src/main/scala/mylib/MyTopLevelFormal.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								src/main/scala/mylib/MyTopLevelFormal.scala
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | package mylib | ||||||
|  |  | ||||||
|  | import spinal.core._ | ||||||
|  | import spinal.core.formal._ | ||||||
|  |  | ||||||
|  | // You need SymbiYosys to be installed. | ||||||
|  | // See https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Formal%20verification/index.html#installing-requirements | ||||||
|  | object MyTopLevelFormal extends App { | ||||||
|  |   FormalConfig | ||||||
|  |     .withBMC(10) | ||||||
|  |     .doVerify(new Component { | ||||||
|  |       val dut = FormalDut(MyTopLevel()) | ||||||
|  |  | ||||||
|  |       // Ensure the formal test start with a reset | ||||||
|  |       assumeInitial(clockDomain.isResetActive) | ||||||
|  |  | ||||||
|  |       // Provide some stimulus | ||||||
|  |       anyseq(dut.io.cond0) | ||||||
|  |       anyseq(dut.io.cond1) | ||||||
|  |  | ||||||
|  |       // Check the state initial value and increment | ||||||
|  |       assert(dut.io.state === past(dut.io.state + U(dut.io.cond0)).init(0)) | ||||||
|  |     }) | ||||||
|  | } | ||||||
							
								
								
									
										25
									
								
								src/main/scala/mylib/MyTopLevelGen.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/main/scala/mylib/MyTopLevelGen.scala
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | 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()) | ||||||
|  | } | ||||||
| @@ -1,40 +1,30 @@ | |||||||
| package mylib | package mylib | ||||||
|  |  | ||||||
| import spinal.core._ | import spinal.core._ | ||||||
| import spinal.sim._ |  | ||||||
| import spinal.core.sim._ | import spinal.core.sim._ | ||||||
|  |  | ||||||
| import scala.util.Random | object MyTopLevelSim extends App { | ||||||
|  |   SimConfig.withWave.doSim(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.randomize() | ||||||
|  |       dut.io.cond1.randomize() | ||||||
|  |  | ||||||
| //MyTopLevel's testbench |       // Wait a rising edge on the clock | ||||||
| object MyTopLevelSim { |       dut.clockDomain.waitRisingEdge() | ||||||
|   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 |       // Check that the dut values match with the reference model ones | ||||||
|       var idx = 0 |       val modelFlag = modelState == 0 || dut.io.cond1.toBoolean | ||||||
|       while(idx < 100){ |       assert(dut.io.state.toInt == modelState) | ||||||
|         //Drive the dut inputs with random values |       assert(dut.io.flag.toBoolean == modelFlag) | ||||||
|         dut.io.cond0 #= Random.nextBoolean() |  | ||||||
|         dut.io.cond1 #= Random.nextBoolean() |  | ||||||
|  |  | ||||||
|         //Wait a rising edge on the clock |       // Update the reference model value | ||||||
|         dut.clockDomain.waitRisingEdge() |       if (dut.io.cond0.toBoolean) { | ||||||
|  |         modelState = (modelState + 1) & 0xff | ||||||
|         //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 |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         idx += 1 |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user