mirror of
https://github.com/SpinalHDL/SpinalTemplateSbt.git
synced 2025-10-22 15:48:45 +08:00
Compare commits
5 Commits
fc2aca8a3e
...
45502f0a57
Author | SHA1 | Date | |
---|---|---|---|
![]() |
45502f0a57 | ||
![]() |
17607424ab | ||
![]() |
f3256ed4e1 | ||
![]() |
789f0f18d5 | ||
![]() |
bcae56d0c7 |
@@ -1,5 +1,40 @@
|
||||
version = 3.6.0
|
||||
runner.dialect = scala212
|
||||
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.oneline = fold
|
||||
|
190
.vscode/SpinalHDL.code-snippets
vendored
Normal file
190
.vscode/SpinalHDL.code-snippets
vendored
Normal 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",
|
||||
"}"
|
||||
]
|
||||
}
|
||||
}
|
@@ -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.
|
||||
|
||||
|
||||
### 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`.
|
||||
|
||||
|
@@ -10,6 +10,7 @@ val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-
|
||||
lazy val projectname = (project in file("."))
|
||||
.settings(
|
||||
Compile / scalaSource := baseDirectory.value / "hw" / "spinal",
|
||||
Test / scalaSource := baseDirectory.value / "tb" / "spinal",
|
||||
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
|
||||
)
|
||||
|
||||
|
3
build.sc
3
build.sc
@@ -6,7 +6,8 @@ object projectname extends SbtModule {
|
||||
def scalaVersion = "2.12.16"
|
||||
override def millSourcePath = os.pwd
|
||||
def sources = T.sources(
|
||||
millSourcePath / "hw" / "spinal"
|
||||
millSourcePath / "hw" / "spinal",
|
||||
millSourcePath / "tb" / "spinal"
|
||||
)
|
||||
def ivyDeps = Agg(
|
||||
ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion",
|
||||
|
0
tb/verilog/.gitignore
vendored
Normal file
0
tb/verilog/.gitignore
vendored
Normal file
0
tb/vhdl/.gitignore
vendored
Normal file
0
tb/vhdl/.gitignore
vendored
Normal file
Reference in New Issue
Block a user