36 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
Dolu1990
8e8b22f6ec SpinalHDL 1.7.3 2022-09-19 13:29:58 +02:00
Dolu1990
4570b17a29 Merge pull request #17 from numero-744/patch-2
Update scala version to latest maintenance release
2022-08-03 10:23:32 +02:00
Dolu1990
a9de93a481 Update build.sbt 2022-08-03 10:23:18 +02:00
Côme
310df743af Update scala version to latest maintenance release
https://www.scala-lang.org/download/2.12.16.html
2022-07-27 09:52:35 +02:00
Dolu1990
599a1e6daf SpinalHDL 1.7.1 2022-07-11 12:29:06 +02:00
Dolu1990
23f8152f1f Merge pull request #14 from numero-744/patch-1
Update sbt
2022-05-25 10:56:26 +02:00
Côme
3a93d0fe88 Update sbt
The previously chosen version of SBT does not work with JDK18.
2022-05-25 10:27:00 +02:00
Dolu1990
e2c55528af SpinalHDL 1.7.0a 2022-05-09 11:32:08 +02:00
Charles Papon
993e66c242 Update mill spinalhdl version 2022-05-05 10:54:40 +02:00
Dolu1990
1e8a644b8a Add formal comment 2022-04-29 15:26:32 +02:00
Dolu1990
df28313eea SpinalHDL 1.7.0 + formal example 2022-04-29 15:18:33 +02:00
Dolu1990
181684644c SpinalHDL 1.6.4 2022-02-16 14:27:15 +01:00
Dolu1990
884c4a7ca6 SpinalHDL 1.6.2 2022-02-05 12:09:54 +01:00
Dolu1990
16cca3e7ca Merge pull request #11 from name1e5s/master
SpinalHDL 1.6.0
2021-10-13 19:10:32 +01:00
name1e5s
2e50a23fcc SpinalHDL 1.6.0 2021-07-16 20:10:07 +08:00
Dolu1990
5502e4f7f6 update readme 2021-07-09 09:42:47 +02:00
Dolu1990
666dcbba79 SpinalHDL 1.5.0 2021-06-15 15:53:45 +02:00
Dolu1990
9c0aed7c0d Merge pull request #10 from typingArtist/sbt-mill-unification
Sbt mill unification
2021-06-14 19:34:46 +02:00
Matthias Wächter
ef4d9b7db3 reverted Scala to 2.11.12 and sbt to 1.4.7 2021-06-14 17:05:43 +02:00
Matthias Wächter
9b3093e193 add support for Mill 2021-06-14 08:35:22 +02:00
Matthias Wächter
bb5f15798e restructure build.sbt according to latest sbt docs 2021-06-14 07:29:01 +02:00
Matthias Wächter
08d79c6134 Add gitignore for metals 2021-06-14 07:03:42 +02:00
Matthias Wächter
131c6e7654 bump sbt (1.5.3) and Scala (2.12.14) 2021-06-14 06:59:20 +02:00
Dolu1990
e03a66e8f9 Notes about eclipse added #8 2021-04-12 13:05:33 +02:00
Dolu1990
8acbd1d747 update verilator version 2021-04-09 16:25:56 +02:00
Dolu1990
173bbb9bb8 Remove eclipse plugin 2021-04-06 11:32:10 +02:00
Dolu1990
162e9b5c6b Merge pull request #7 from azaparov/patch-1
Fix to correct verilator branch
2021-03-29 12:58:43 +02:00
Alexey Zaparovanny
c7e1834cb4 Fix to correct verilator branch
Update README.md to reflect correct verilator branch for checkout
2021-03-28 13:42:26 -04:00
Dolu1990
754351b8a1 SpinalHDL 1.4.3 2021-02-01 12:33:12 +01:00
Dolu1990
fd7f2b7165 SpinalHDL 1.4.2 2020-10-15 12:41:48 +02:00
12 changed files with 152 additions and 96 deletions

6
.gitignore vendored
View File

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

1
.mill-version Normal file
View File

@@ -0,0 +1 @@
0.9.8

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

@@ -21,8 +21,9 @@ sudo update-alternatives --config javac
You need to install SBT
```sh
echo "deb https://dl.bintray.com/sbt/debian /" | sudo tee -a /etc/apt/sources.list.d/sbt.list
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2EE0EA64E40A89B84B2DF73499E82A75642AC823
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
```
@@ -36,7 +37,7 @@ 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 verilator_3_916
git checkout v4.040
autoconf # Create ./configure script
./configure
make -j$(nproc)
@@ -89,6 +90,8 @@ 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
@@ -100,9 +103,38 @@ You need to install :
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)
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,13 +1,16 @@
name := "SpinalTemplateSbt"
version := "1.0"
scalaVersion := "2.11.12"
val spinalVersion = "1.4.0"
ThisBuild / version := "1.0"
ThisBuild / scalaVersion := "2.12.16"
ThisBuild / organization := "org.example"
libraryDependencies ++= Seq(
"com.github.spinalhdl" % "spinalhdl-core_2.11" % spinalVersion,
"com.github.spinalhdl" % "spinalhdl-lib_2.11" % spinalVersion,
compilerPlugin("com.github.spinalhdl" % "spinalhdl-idsl-plugin_2.11" % spinalVersion)
)
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)
lazy val mylib = (project in file("."))
.settings(
name := "SpinalTemplateSbt",
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
)
fork := true
EclipseKeys.withSource := true

13
build.sc Normal file
View 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")
}

View File

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

View File

@@ -1,2 +1 @@
addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4")
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
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 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
}
//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

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

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
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
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 #= Random.nextBoolean()
dut.io.cond1 #= Random.nextBoolean()
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
// Wait a rising edge on the clock
dut.clockDomain.waitRisingEdge()
//Check that the dut values match with the reference model ones
// 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
}
}
}