mirror of
				https://github.com/SpinalHDL/SpinalTemplateSbt.git
				synced 2025-10-25 08:48:45 +08:00 
			
		
		
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			8e8b22f6ec
			...
			9ccca0f64a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 9ccca0f64a | ||
|   | bbbac09f8f | ||
|   | d40940a924 | ||
|   | 09e7cac187 | ||
|   | a53d219051 | ||
|   | ed51a92116 | 
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -11,17 +11,20 @@ target | ||||
| lib_managed/ | ||||
| src_managed/ | ||||
| project/boot/ | ||||
| project/project | ||||
| project/plugins/project/ | ||||
|  | ||||
| # Scala-IDE specific | ||||
| .scala_dependencies | ||||
| .worksheet | ||||
| .bloop | ||||
|  | ||||
| .idea | ||||
| out | ||||
|  | ||||
| # Metals | ||||
| .metals | ||||
| project/metals.sbt | ||||
|  | ||||
| # Eclipse | ||||
| 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 | ||||
| @@ -0,0 +1 @@ | ||||
| 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 | ||||
|  | ||||
| import spinal.core._ | ||||
| import spinal.lib._ | ||||
|  | ||||
| import scala.util.Random | ||||
|  | ||||
| //Hardware definition | ||||
| class MyTopLevel extends Component { | ||||
| // 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){ | ||||
|   val counter = Reg(UInt(8 bits)) init 0 | ||||
|  | ||||
|   when(io.cond0) { | ||||
|     counter := counter + 1 | ||||
|   } | ||||
|  | ||||
|   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) | ||||
|   } | ||||
| } | ||||
| @@ -5,10 +5,11 @@ 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 { | ||||
|   def main(args: Array[String]) { | ||||
|     FormalConfig.withBMC(10).doVerify(new Component { | ||||
|       val dut = FormalDut(new MyTopLevel) | ||||
| 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) | ||||
| @@ -20,5 +21,4 @@ object MyTopLevelFormal { | ||||
|       // 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,37 +1,30 @@ | ||||
| package mylib | ||||
|  | ||||
| import spinal.core._ | ||||
| import spinal.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 | ||||
| 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) | ||||
|       // Wait a rising edge on the clock | ||||
|       dut.clockDomain.waitRisingEdge() | ||||
|  | ||||
|       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() | ||||
|       // 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) | ||||
|  | ||||
|         //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 | ||||
|         } | ||||
|       // Update the reference model value | ||||
|       if (dut.io.cond0.toBoolean) { | ||||
|         modelState = (modelState + 1) & 0xff | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user