mirror of
				https://github.com/SpinalHDL/SpinalTemplateSbt.git
				synced 2025-10-25 16:58:45 +08:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
			0af6230168
			...
			master
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 324e3dce52 | ||
|   | 976ceca3a3 | ||
|   | 2aefabbbad | ||
|   | 52417f9d8c | 
| @@ -1,40 +1,5 @@ | |||||||
| version = 3.6.0 | version = 3.6.0 | ||||||
| runner.dialect = scala212 | runner.dialect = scala212 | ||||||
| align.preset = some | align.preset = some | ||||||
| align.tokens."+" = [ | maxColumn = 120 | ||||||
|     { |  | ||||||
|         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
									
									
								
							
							
						
						
									
										190
									
								
								.vscode/SpinalHDL.code-snippets
									
									
									
									
										vendored
									
									
								
							| @@ -1,190 +0,0 @@ | |||||||
| { |  | ||||||
| 	"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", |  | ||||||
| 			"}" |  | ||||||
| 		] |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @@ -2,15 +2,15 @@ ThisBuild / version := "1.0" | |||||||
| ThisBuild / scalaVersion := "2.13.14" | ThisBuild / scalaVersion := "2.13.14" | ||||||
| ThisBuild / organization := "org.example" | ThisBuild / organization := "org.example" | ||||||
|  |  | ||||||
| val spinalVersion = "1.10.2a" | val spinalVersion = "1.12.3" | ||||||
| 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) | ||||||
|  |  | ||||||
| lazy val projectname = (project in file(".")) | lazy val projectname = (project in file(".")) | ||||||
|   .settings( |   .settings( | ||||||
|  |     name := "myproject",  | ||||||
|     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) | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								build.sc
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								build.sc
									
									
									
									
									
								
							| @@ -1,13 +1,12 @@ | |||||||
| import mill._, scalalib._ | import mill._, scalalib._ | ||||||
|  |  | ||||||
| val spinalVersion = "1.10.2a" | val spinalVersion = "1.12.3" | ||||||
|  |  | ||||||
| object projectname extends SbtModule { | object projectname extends SbtModule { | ||||||
|   def scalaVersion = "2.13.14" |   def scalaVersion = "2.13.14" | ||||||
|   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", | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ object Config { | |||||||
|     defaultConfigForClockDomains = ClockDomainConfig( |     defaultConfigForClockDomains = ClockDomainConfig( | ||||||
|       resetActiveLevel = HIGH |       resetActiveLevel = HIGH | ||||||
|     ), |     ), | ||||||
|     onlyStdLogicVectorAtTopLevelIo = true |     onlyStdLogicVectorAtTopLevelIo = false | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   def sim = SimConfig.withConfig(spinal).withFstWave |   def sim = SimConfig.withConfig(spinal).withFstWave | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								tb/verilog/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										0
									
								
								tb/verilog/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
								
								
									
										0
									
								
								tb/vhdl/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										0
									
								
								tb/vhdl/.gitignore
									
									
									
									
										vendored
									
									
								
							
		Reference in New Issue
	
	Block a user