14 Commits

Author SHA1 Message Date
Côme
040345203c Merge 789f0f18d5 into 3b84555158 2024-04-20 09:50:16 -04:00
Dolu1990
3b84555158 SpinalHDL 1.10.1 2024-02-01 10:35:36 +01:00
Dolu1990
51249d4c6e SpinalHDL 1.10.0 2024-01-04 10:10:33 +01:00
Dolu1990
17607424ab Merge pull request #36 from IanBoyanZhang/patch-1
Fix typo in README
2023-11-06 11:46:07 +01:00
Ian Zhang
f3256ed4e1 Fix typo in README 2023-11-04 16:35:54 -07:00
Dolu1990
766b80b3f1 SpinalHDL 1.9.4 2023-11-01 09:41:06 +01:00
Dolu1990
f47ac2f65f SpinalHDL 1.9.3 2023-08-16 10:01:33 +02:00
Dolu1990
9fe5ded40a SpinalHDL 1.9.0 for build.sc too <3 2023-07-21 17:46:38 +02:00
Dolu1990
2bf3acd857 SpinalHDL 1.9.0 2023-07-21 17:42:13 +02:00
Dolu1990
a4eb1e65ef SpinalHDL 1.8.1 2023-03-27 09:57:17 +02:00
Côme ALLART
789f0f18d5 add tb folder 2022-12-07 20:38:14 +01:00
Côme ALLART
bcae56d0c7 add helpers to quickly write beautiful code 2022-12-07 20:02:11 +01:00
Dolu1990
88fb4a7f49 SpinalHDL 1.8.0 2022-12-05 20:26:59 +01:00
Dolu1990
950e9c2c72 Merge pull request #27 from SpinalHDL/25-readme-pointing-to-getting-started-from-rtd
Readme pointing to Getting started from RTD
2022-11-30 18:39:16 +01:00
9 changed files with 234 additions and 7 deletions

View File

@@ -1,5 +1,40 @@
version = 3.6.0 version = 3.6.0
runner.dialect = scala212 runner.dialect = scala212
align.preset = some align.preset = some
maxColumn = 120 align.tokens."+" = [
{
code = "="
owners = [{
regex = "Defn\\.Val"
}]
}
{
code = ":="
owners = [{
regex = "Term\\.ApplyInfix"
parents = ["Term\\.Block|Template"]
}]
}
{
code = "#="
owners = [{
regex = "Term\\.ApplyInfix"
parents = ["Term\\.Block|Template"]
}]
}
{
code = "port"
owners = [{
regex = "Term\\.ApplyInfix"
parents = ["Defn\\.Val"]
}]
}
{
code = "->"
owners = [{
regex = "Term\\.ApplyInfix"
}]
}
]
docstrings.wrap = no docstrings.wrap = no
docstrings.oneline = fold

190
.vscode/SpinalHDL.code-snippets vendored Normal file
View File

@@ -0,0 +1,190 @@
{
"Import spinal.core": {
"scope": "scala",
"prefix": "importcore",
"body": ["import spinal.core._", ""]
},
"Import spinal.lib": {
"scope": "scala",
"prefix": "importlib",
"body": ["import spinal.lib.${1:_}", ""]
},
"Import spinal.core.sim": {
"scope": "scala",
"prefix": "importsim",
"body": ["import spinal.core.sim._", ""]
},
"New component": {
"scope": "scala",
"prefix": "component",
"body": [
"case class $1($2) extends Component {",
" val io = new Bundle {",
" $0",
" }",
"",
" ",
"}"
],
},
"Component to function": {
"scope": "scala",
"prefix": "fncomp",
"body": [
"object ${1/\\(.*//} {",
" def apply($2: $3): $4 = {",
" val ${1/([^(]*).*/${1:/camelcase}/} = $1($6)",
" ${1/([^(]*).*/${1:/camelcase}/}.io.$2 := $2",
" ${1/([^(]*).*/${1:/camelcase}/}.io.$5",
" }",
"}"
],
},
"Component to function2": {
"scope": "scala",
"prefix": "fncomp2",
"body": [
"object ${1/\\(.*//} {",
" def apply($2: $3, $4: $5): $6 = {",
" val ${1/([^(]*).*/${1:/camelcase}/} = $1($8)",
" ${1/([^(]*).*/${1:/camelcase}/}.io.$2 := $2",
" ${1/([^(]*).*/${1:/camelcase}/}.io.$4 := $4",
" ${1/([^(]*).*/${1:/camelcase}/}.io.$7",
" }",
"}"
],
},
"New configurable component": {
"scope": "scala",
"prefix": "compcfg",
"body": [
"case class ${2:${1}Cfg} (",
" $3",
")",
"",
"class $1(cfg: $2) extends Component {",
" val io = new Bundle {",
" $0",
" }",
"",
" ",
"}"
],
},
"New entity/architecture-like": {
"scope": "scala",
"prefix": "entarch",
"body": [
"abstract class $1$2 extends Component {",
" val io = new Bundle {",
" $0",
" }",
"}",
"",
"class $1$3 extends $1$4 {",
" ",
"}",
],
},
"New input": {
"scope": "scala",
"prefix": "pin",
"body": "val $1 = in port ",
},
"New output": {
"scope": "scala",
"prefix": "pout",
"body": "val $1 = out port ",
},
"New master port": {
"scope": "scala",
"prefix": "pmaster",
"body": "val $1 = master port ",
},
"New slave port": {
"scope": "scala",
"prefix": "pslave",
"body": "val $1 = slave port ",
},
"Bits": {
"scope": "scala",
"prefix": "nbits",
"body": "Bits($1 bits)",
},
"UInt": {
"scope": "scala",
"prefix": "nuint",
"body": "UInt($1 bits)",
},
"SInt": {
"scope": "scala",
"prefix": "nsint",
"body": "SInt($1 bits)",
},
"...ing flag": {
"scope": "scala",
"prefix": "doing",
"body": ["val ${2:${1}ing} = False", "def $1(): Unit = $2 := True", ""]
},
"...Flag flag": {
"scope": "scala",
"prefix": "flag",
"body": ["val ${2:${1}Flag} = False", "def $1(): Unit = $2 := True", ""]
},
"'def' function mux": {
"scope": "scala",
"prefix": "fnmux",
"body": ["$1 := $2", "def $3(): Unit = $1 := $0"]
},
"BlackBox wrapper": {
"scope": "scala",
"prefix": "blackboxwrapper",
"body": [
"class $1 extends Area {",
" val io = new Bundle {",
" ${0:// Direction-less Spinal ports}",
" }",
"",
" class $1 extends BlackBox {",
" // Ports of the blackboxed item",
" }",
"",
" val bb = new $1",
" bb.setPartialName(\"\")",
"",
" // Connection logic",
"}"
]
},
"State machine": {
"scope": "scala",
"prefix": "fsm",
"body": [
"val $1 = new StateMachine {",
" val $2, $3 = new State",
" setEntry($2)",
"",
" $0",
"}"
]
}
}

View File

@@ -13,7 +13,7 @@ More specifically:
* instructions to get this repository locally are available in the [Create a SpinalHDL project](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#create-a-spinalhdl-project) section. * instructions to get this repository locally are available in the [Create a SpinalHDL project](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#create-a-spinalhdl-project) section.
### TL;DR Things have arleady been set up in my environment, how do I run things to try SpinalHDL? ### TL;DR Things have already been set up in my environment, how do I run things to try SpinalHDL?
Once in the `SpinalTemplateSbt` directory, when tools are installed, the commands below can be run to use `sbt`. Once in the `SpinalTemplateSbt` directory, when tools are installed, the commands below can be run to use `sbt`.

View File

@@ -1,8 +1,8 @@
ThisBuild / version := "1.0" ThisBuild / version := "1.0"
ThisBuild / scalaVersion := "2.12.16" ThisBuild / scalaVersion := "2.12.18"
ThisBuild / organization := "org.example" ThisBuild / organization := "org.example"
val spinalVersion = "1.7.3" val spinalVersion = "1.10.1"
val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion
val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion
val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion) val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion)
@@ -10,6 +10,7 @@ val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-
lazy val projectname = (project in file(".")) lazy val projectname = (project in file("."))
.settings( .settings(
Compile / scalaSource := baseDirectory.value / "hw" / "spinal", Compile / scalaSource := baseDirectory.value / "hw" / "spinal",
Test / scalaSource := baseDirectory.value / "tb" / "spinal",
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin) libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
) )

View File

@@ -1,12 +1,13 @@
import mill._, scalalib._ import mill._, scalalib._
val spinalVersion = "1.7.3" val spinalVersion = "1.10.1"
object projectname extends SbtModule { object projectname extends SbtModule {
def scalaVersion = "2.12.16" def scalaVersion = "2.12.18"
override def millSourcePath = os.pwd override def millSourcePath = os.pwd
def sources = T.sources( def sources = T.sources(
millSourcePath / "hw" / "spinal" millSourcePath / "hw" / "spinal",
millSourcePath / "tb" / "spinal"
) )
def ivyDeps = Agg( def ivyDeps = Agg(
ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion", ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion",

0
tb/verilog/.gitignore vendored Normal file
View File

0
tb/vhdl/.gitignore vendored Normal file
View File