6 Commits

Author SHA1 Message Date
Dolu1990
9ccca0f64a Merge pull request #21 from numero-744/big-update
Big update
2022-11-18 17:58:51 +01:00
Côme ALLART
bbbac09f8f new MyTopLevel -> MyTopLevel() 2022-11-18 00:37:28 +01:00
Côme ALLART
d40940a924 use case class for Component 2022-11-17 23:18:31 +01:00
Côme ALLART
09e7cac187 restore fancy formatting in io 2022-11-16 21:16:23 +01:00
Côme ALLART
a53d219051 add support of scalafmt 2022-11-16 18:36:01 +01:00
Côme ALLART
ed51a92116 big update
- remove not supported anymore procedural syntax for main functions
- use App instead of main
- auto format
- move comments to have more user-friendly access to "run" and "debug"
  button for Apps
- move generators to dedicated new file
2022-11-16 18:32:24 +01:00
7 changed files with 63 additions and 81 deletions

3
.gitignore vendored
View File

@@ -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
View File

@@ -0,0 +1,5 @@
version = 3.6.0
runner.dialect = scala212
align.preset = some
maxColumn = 120
docstrings.wrap = no

View File

@@ -0,0 +1 @@
addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6")

View File

@@ -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)
}
}

View File

@@ -5,10 +5,11 @@ 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)
@@ -20,5 +21,4 @@ object MyTopLevelFormal {
// Check the state initial value and increment // Check the state initial value and increment
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))
}) })
}
} }

View 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())
}

View File

@@ -1,37 +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
for(idx <- 0 to 99){ val modelFlag = modelState == 0 || dut.io.cond1.toBoolean
//Drive the dut inputs with random values assert(dut.io.state.toInt == modelState)
dut.io.cond0 #= Random.nextBoolean() assert(dut.io.flag.toBoolean == modelFlag)
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
}
} }
} }
} }