Hello Hardware World
The Basic DFHDL Program
Since DFHDL is a Scala library, we are creating a Scala program that takes DFHDL designs and compiles (transpiles) them into lower representations (e.g., VHDL or Verilog). As such, some of DFHDL's compilation process is done statically via the Scala compiler and the rest during the Scala runtime execution. The Scala code below describes a program that runs the DFHDL compiler on an 8-bit overlapping counter design, Counter8
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25 | import dfhdl.* //import all the DFHDL goodness
/** Generates an 8-bit overlapping count */
@top class Counter8 extends RTDesign:
val cnt = UInt(8) <> OUT.REG init 0
cnt.din := cnt + 1
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Elaboration Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Uncomment to set different clock and reset configurations:
// given options.ElaborationOptions.DefaultClkCfg = ClkCfg(ClkCfg.Edge.Rising)
// given options.ElaborationOptions.DefaultRstCfg = RstCfg(RstCfg.Mode.Async, RstCfg.Active.Low)
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Compiler Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Enables printing the generated chosen backend code:
given options.CompilerOptions.PrintBackendCode = true
// Uncomment to select vhdl compilation (default is verilog):
// given options.CompilerOptions.Backend = backends.vhdl
// Uncomment to enable printing design code after elaboration (before compilation):
// given options.ElaborationOptions.PrintDFHDLCode = true
// Uncomment to enable printing design code after compilation:
// given options.CompilerOptions.PrintDFHDLCode = true
////////////////////////////////////////////////////////////////////////////////////////////////
|
Writing a DFHDL compilation program – as easy as 01-10-11!
import dfhdl.*
once per source file, to import all the required namespace objects, types, and functionality.
class _design_name_ extends RTDesign:
to define your register-transfer (RT) domain design. Populate your design with the required interface and functionality. DFHDL supports two additional design domains: dataflow (DF), and event-driven (ED).
- Add
@top
annotation to your top-level design (e.g., @top class top_design_name_ ...
) to automatically create a compilation program entry point for the design, instantiate it, elaborate it, compile it to Verilog or VHDL (see compiler options), and finally commit the files to disk.
Run It In Your Browser
Run it here
import dfhdl.* //import all the DFHDL goodness
/** Generates an 8-bit overlapping count */
@top class Counter8 extends RTDesign:
val cnt = UInt(8) <> OUT.REG init 0
cnt.din := cnt + 1
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Elaboration Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Uncomment to set different clock and reset configurations:
// given options.ElaborationOptions.DefaultClkCfg = ClkCfg(ClkCfg.Edge.Rising)
// given options.ElaborationOptions.DefaultRstCfg = RstCfg(RstCfg.Mode.Async, RstCfg.Active.Low)
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Compiler Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Enables printing the generated chosen backend code:
given options.CompilerOptions.PrintBackendCode = true
// Uncomment to select vhdl compilation (default is verilog):
// given options.CompilerOptions.Backend = backends.vhdl
// Uncomment to enable printing design code after elaboration (before compilation):
// given options.ElaborationOptions.PrintDFHDLCode = true
// Uncomment to enable printing design code after compilation:
// given options.CompilerOptions.PrintDFHDLCode = true
////////////////////////////////////////////////////////////////////////////////////////////////
For more examples that are available to run in your browser, see the relevant section.
Run It On Your System
To run this example on your system, make sure to first follow the initial setup instructions.
You have several options to run Scala programs on your system:
- For this simple
Counter8
example, you can just use the simplest scala-single-file approach.
- For common DFHDL projects, we recommend using the scala project approach.
- For complex, full-production DFHDL projects, you may need to use an sbt project, but this is usually not required.
Scala Single File
View the scala single file example
Counter8.scala |
---|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30 | //> using scala 3.5.2
//> using dep io.github.dfianthdl::dfhdl::0.9.0
//> using plugin io.github.dfianthdl:::dfhdl-plugin:0.9.0
//> using option -deprecation -language:implicitConversions
import dfhdl.* //import all the DFHDL goodness
/** Generates an 8-bit overlapping count */
@top class Counter8 extends RTDesign:
val cnt = UInt(8) <> OUT.REG init 0
cnt.din := cnt + 1
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Elaboration Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Uncomment to set different clock and reset configurations:
// given options.ElaborationOptions.DefaultClkCfg = ClkCfg(ClkCfg.Edge.Rising)
// given options.ElaborationOptions.DefaultRstCfg = RstCfg(RstCfg.Mode.Async, RstCfg.Active.Low)
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Compiler Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Enables printing the generated chosen backend code:
given options.CompilerOptions.PrintBackendCode = true
// Uncomment to select vhdl compilation (default is verilog):
// given options.CompilerOptions.Backend = backends.vhdl
// Uncomment to enable printing design code after elaboration (before compilation):
// given options.ElaborationOptions.PrintDFHDLCode = true
// Uncomment to enable printing design code after compilation:
// given options.CompilerOptions.PrintDFHDLCode = true
////////////////////////////////////////////////////////////////////////////////////////////////
|
Download and run in your terminalcurl -o Counter8.scala https://dfianthdl.github.io/getting-started/hello-world/scala-single-file/Counter8.scala
scala run ./Counter8.scala
For more information, please run scala run --help
or consult the online documentation.
Scala Project
View the scala project files example
projectFolder/project.scala |
---|
| //> using scala 3.5.2
//> using dep io.github.dfianthdl::dfhdl::0.9.0
//> using plugin io.github.dfianthdl:::dfhdl-plugin:0.9.0
//> using option -deprecation -language:implicitConversions
|
projectFolder/Counter8.scala |
---|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25 | import dfhdl.* //import all the DFHDL goodness
/** Generates an 8-bit overlapping count */
@top class Counter8 extends RTDesign:
val cnt = UInt(8) <> OUT.REG init 0
cnt.din := cnt + 1
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Elaboration Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Uncomment to set different clock and reset configurations:
// given options.ElaborationOptions.DefaultClkCfg = ClkCfg(ClkCfg.Edge.Rising)
// given options.ElaborationOptions.DefaultRstCfg = RstCfg(RstCfg.Mode.Async, RstCfg.Active.Low)
////////////////////////////////////////////////////////////////////////////////////////////////
// DFHDL Compiler Options: //
////////////////////////////////////////////////////////////////////////////////////////////////
// Enables printing the generated chosen backend code:
given options.CompilerOptions.PrintBackendCode = true
// Uncomment to select vhdl compilation (default is verilog):
// given options.CompilerOptions.Backend = backends.vhdl
// Uncomment to enable printing design code after elaboration (before compilation):
// given options.ElaborationOptions.PrintDFHDLCode = true
// Uncomment to enable printing design code after compilation:
// given options.CompilerOptions.PrintDFHDLCode = true
////////////////////////////////////////////////////////////////////////////////////////////////
|
Download and run in your terminalcurl -o project.scala https://dfianthdl.github.io/getting-started/hello-world/scala-project/project.scala
curl -o Counter8.scala https://dfianthdl.github.io/getting-started/hello-world/scala-project/Counter8.scala
scala run .
For more information, please run scala run --help
or consult the online documentation.
sbt Project
The best way to get started with a DFHDL sbt project is to clone our template from GitHub:
Clone and run in your terminalgit clone https://github.com/DFiantHDL/dfhdl-template
cd dfhdl-template
sbt run
For more information, please consult the sbt documentation.
We recommend actively using Scalafmt, a code formatter for Scala that integrates well with your toolchain. The following setting is recommended for DFHDL designs:
View the Scalafmt recommended configuration file
projectFolder/.scalafmt.conf |
---|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15 | version = 3.8.3
runner.dialect = scala3
maxColumn = 100
align.tokens = [{code = "<>"}, {code = "="}, {code = "=>"}, {code = ":="}, {code = ":=="}]
rewrite.scala3.removeOptionalBraces = oldSyntaxToo
rewrite.scala3.insertEndMarkerMinLines = 15
binPack.literalArgumentLists = true
binPack.literalsMinArgCount = 5
binPack.literalsInclude = [".*"]
binPack.literalsIncludeSimpleExpr = true
binPack.literalsSingleLine = false
newlines.selectChains = keep
|
Download it via your terminalcurl -o .scalafmt.conf https://dfianthdl.github.io/getting-started/hello-world/scala-project/.scalafmt.conf
For more information, please consult the Scalafmt documentation.