1 Commits

Author SHA1 Message Date
Dolu1990
514b43937b withAssembly 2020-04-21 10:23:10 +02:00
12 changed files with 98 additions and 152 deletions

6
.gitignore vendored
View File

@@ -11,21 +11,15 @@ 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

View File

@@ -1 +0,0 @@
0.9.8

View File

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

View File

@@ -21,9 +21,8 @@ sudo update-alternatives --config javac
You need to install SBT You need to install SBT
```sh ```sh
echo "deb https://repo.scala-sbt.org/scalasbt/debian all main" | sudo tee /etc/apt/sources.list.d/sbt.list echo "deb https://dl.bintray.com/sbt/debian /" | sudo tee -a /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 sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2EE0EA64E40A89B84B2DF73499E82A75642AC823
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
``` ```
@@ -37,7 +36,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 verilator_3_916
autoconf # Create ./configure script autoconf # Create ./configure script
./configure ./configure
make -j$(nproc) make -j$(nproc)
@@ -90,8 +89,6 @@ 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
@@ -103,38 +100,9 @@ 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

View File

@@ -1,16 +1,13 @@
ThisBuild / version := "1.0" name := "SpinalTemplateSbt"
ThisBuild / scalaVersion := "2.12.16" version := "1.0"
ThisBuild / organization := "org.example" scalaVersion := "2.11.12"
val spinalVersion = "1.4.0"
val spinalVersion = "1.7.3" libraryDependencies ++= Seq(
val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion "com.github.spinalhdl" % "spinalhdl-core_2.11" % spinalVersion,
val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion "com.github.spinalhdl" % "spinalhdl-lib_2.11" % spinalVersion,
val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion) compilerPlugin("com.github.spinalhdl" % "spinalhdl-idsl-plugin_2.11" % spinalVersion)
)
lazy val mylib = (project in file("."))
.settings(
name := "SpinalTemplateSbt",
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
)
fork := true fork := true
EclipseKeys.withSource := true

View File

@@ -1,13 +0,0 @@
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")
}

View File

@@ -1 +1 @@
sbt.version=1.6.0 sbt.version=1.3.3

View File

@@ -1 +1,4 @@
addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6") addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4")
addSbtPlugin("com.eed3si9n" % "sbt-assembly" % "0.14.10")

View File

@@ -1,22 +1,67 @@
/*
* 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._
// Hardware definition import scala.util.Random
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)
val counter = Reg(UInt(8 bits)) init 0 when(io.cond0){
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

@@ -1,24 +0,0 @@
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))
})
}

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

View File

@@ -1,30 +1,37 @@
package mylib package mylib
import spinal.core._ import spinal.core._
import spinal.sim._
import spinal.core.sim._ import spinal.core.sim._
object MyTopLevelSim extends App { import scala.util.Random
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()
// Wait a rising edge on the clock //MyTopLevel's testbench
dut.clockDomain.waitRisingEdge() 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)
// Check that the dut values match with the reference model ones var modelState = 0
val modelFlag = modelState == 0 || dut.io.cond1.toBoolean for(idx <- 0 to 99){
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()
// Update the reference model value //Wait a rising edge on the clock
if (dut.io.cond0.toBoolean) { dut.clockDomain.waitRisingEdge()
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
}
} }
} }
} }